aboutsummaryrefslogtreecommitdiffstats
path: root/yt/yt/core/yson/string_merger.h
blob: e91b858a8eeeb3dfaef8ddff42bec1798b33f74d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#pragma once

#include <yt/yt/core/ypath/public.h>

#include <library/cpp/yt/yson_string/public.h>

namespace NYT::NYson {

////////////////////////////////////////////////////////////////////////////////

//! Given parts of YSON and their destinations, merges several YSON strings into one.
//! Faster alternative to casting everything to YSON nodes, merging them and casting
//! this merged YSON back to YSON string.
//! YSON strings `ysonStringBufs` can be of any format, but type must be EYsonType::Node.
//! In a case when one path is prefix of another,
//! only YSON string corresponding to the shortest path will be used.
TYsonString MergeYsonStrings(
    std::vector<NYPath::TYPath> paths,
    std::vector<TYsonStringBuf> ysonStringBufs,
    EYsonFormat format = EYsonFormat::Binary);

////////////////////////////////////////////////////////////////////////////////

} // namespace NYT::NYson