aboutsummaryrefslogtreecommitdiffstats
path: root/library
diff options
context:
space:
mode:
authorvvvv <vvvv@ydb.tech>2022-10-30 10:41:16 +0300
committervvvv <vvvv@ydb.tech>2022-10-30 10:41:16 +0300
commita34b8d13197580c648158c2d2a29812d0b211713 (patch)
treed9cbcbb05c3157d7c140b35901bf6b5c600e9072 /library
parent8985a698521744e4065500f5945d44ca52f797a9 (diff)
downloadydb-a34b8d13197580c648158c2d2a29812d0b211713.tar.gz
[pg] initialize tx timestamps
влияет на функции now, statement_timestamp - они будут брать кешированное значение с момента инициализации comp graph. clock_timestamp сейчас всегда возвращает некешированное системное время - это потом надо будет увести в TimeProvider
Diffstat (limited to 'library')
-rw-r--r--library/cpp/yt/memory/serialize-inl.h35
-rw-r--r--library/cpp/yt/memory/serialize.h28
-rw-r--r--library/cpp/yt/memory/unittests/intrusive_ptr_ut.cpp2
3 files changed, 44 insertions, 21 deletions
diff --git a/library/cpp/yt/memory/serialize-inl.h b/library/cpp/yt/memory/serialize-inl.h
new file mode 100644
index 0000000000..493ba9101e
--- /dev/null
+++ b/library/cpp/yt/memory/serialize-inl.h
@@ -0,0 +1,35 @@
+#ifndef SERIALIZE_PTR_INL_H_
+#error "Direct inclusion of this file is not allowed, include serialize.h"
+// For the sake of sane code completion.
+#include "serialize.h"
+#endif
+
+#include "new.h"
+
+////////////////////////////////////////////////////////////////////////////////
+
+template <class T>
+void TSerializer<NYT::TIntrusivePtr<T>>::Save(IOutputStream* output, const NYT::TIntrusivePtr<T>& ptr)
+{
+ bool hasValue = ptr.operator bool();
+ ::Save(output, hasValue);
+ if (hasValue) {
+ ::Save(output, *ptr);
+ }
+}
+
+template <class T>
+void TSerializer<NYT::TIntrusivePtr<T>>::Load(IInputStream* input, NYT::TIntrusivePtr<T>& ptr)
+{
+ bool hasValue;
+ ::Load(input, hasValue);
+ if (hasValue) {
+ auto tmp = NYT::New<T>();
+ ::Load(input, *tmp);
+ ptr = std::move(tmp);
+ } else {
+ ptr.Reset();
+ }
+}
+
+////////////////////////////////////////////////////////////////////////////////
diff --git a/library/cpp/yt/memory/serialize.h b/library/cpp/yt/memory/serialize.h
index 03fc286515..c113e04961 100644
--- a/library/cpp/yt/memory/serialize.h
+++ b/library/cpp/yt/memory/serialize.h
@@ -1,6 +1,6 @@
#pragma once
-#include "new.h"
+#include "intrusive_ptr.h"
////////////////////////////////////////////////////////////////////////////////
@@ -8,27 +8,13 @@ template <class T>
class TSerializer<NYT::TIntrusivePtr<T>>
{
public:
- static inline void Save(IOutputStream* out, const NYT::TIntrusivePtr<T>& ptr)
- {
- bool hasValue = ptr.operator bool();
- ::Save(out, hasValue);
- if (hasValue) {
- ::Save(out, *ptr);
- }
- }
+ static inline void Save(IOutputStream* output, const NYT::TIntrusivePtr<T>& ptr);
- static inline void Load(IInputStream* in, NYT::TIntrusivePtr<T>& ptr)
- {
- bool hasValue;
- ::Load(in, hasValue);
- if (hasValue) {
- auto tmp = NYT::New<T>();
- ::Load(in, *tmp);
- ptr = std::move(tmp);
- } else {
- ptr.Reset();
- }
- }
+ static inline void Load(IInputStream* input, NYT::TIntrusivePtr<T>& ptr);
};
////////////////////////////////////////////////////////////////////////////////
+
+#define SERIALIZE_PTR_INL_H_
+#include "serialize-inl.h"
+#undef SERIALIZE_PTR_INL_H_
diff --git a/library/cpp/yt/memory/unittests/intrusive_ptr_ut.cpp b/library/cpp/yt/memory/unittests/intrusive_ptr_ut.cpp
index 9a94c82411..6171dc7aee 100644
--- a/library/cpp/yt/memory/unittests/intrusive_ptr_ut.cpp
+++ b/library/cpp/yt/memory/unittests/intrusive_ptr_ut.cpp
@@ -5,7 +5,9 @@
#include <library/cpp/yt/memory/serialize.h>
#include <util/generic/buffer.h>
+
#include <util/stream/buffer.h>
+
#include <util/ysaveload.h>
namespace NYT {