Compare commits
2 Commits
master
...
extend-slk
Author | SHA1 | Date | |
---|---|---|---|
|
31d4a414c3 | ||
|
65f22b9728 |
@ -1,20 +1,20 @@
|
|||||||
repos:
|
repos:
|
||||||
- repo: https://github.com/pre-commit/pre-commit-hooks
|
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||||
rev: v2.3.0
|
rev: v4.4.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: check-yaml
|
- id: check-yaml
|
||||||
- id: end-of-file-fixer
|
- id: end-of-file-fixer
|
||||||
- id: trailing-whitespace
|
- id: trailing-whitespace
|
||||||
- repo: https://github.com/psf/black
|
- repo: https://github.com/psf/black
|
||||||
rev: 22.8.0
|
rev: 23.1.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: black
|
- id: black
|
||||||
- repo: https://github.com/pycqa/isort
|
- repo: https://github.com/pycqa/isort
|
||||||
rev: 5.10.1
|
rev: 5.12.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: isort
|
- id: isort
|
||||||
name: isort (python)
|
name: isort (python)
|
||||||
- repo: https://github.com/pre-commit/mirrors-clang-format
|
- repo: https://github.com/pre-commit/mirrors-clang-format
|
||||||
rev: v13.0.0
|
rev: v15.0.7
|
||||||
hooks:
|
hooks:
|
||||||
- id: clang-format
|
- id: clang-format
|
||||||
|
4
init
4
init
@ -149,9 +149,9 @@ python3 -m pre_commit install
|
|||||||
|
|
||||||
# Install py format tools
|
# Install py format tools
|
||||||
echo "Install black formatter"
|
echo "Install black formatter"
|
||||||
python3 -m pip install black==22.8.*
|
python3 -m pip install black==23.1.*
|
||||||
echo "Install isort"
|
echo "Install isort"
|
||||||
python3 -m pip install isort==5.10.*
|
python3 -m pip install isort==5.12.*
|
||||||
|
|
||||||
# Link `include/mgp.py` with `release/mgp/mgp.py`
|
# Link `include/mgp.py` with `release/mgp/mgp.py`
|
||||||
ln -v -f include/mgp.py release/mgp/mgp.py
|
ln -v -f include/mgp.py release/mgp/mgp.py
|
||||||
|
78
src/slk/loopback.hpp
Normal file
78
src/slk/loopback.hpp
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
// Copyright 2023 Memgraph Ltd.
|
||||||
|
//
|
||||||
|
// Use of this software is governed by the Business Source License
|
||||||
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
||||||
|
// License, and you may not use this file except in compliance with the Business Source License.
|
||||||
|
//
|
||||||
|
// As of the Change Date specified in that file, in accordance with
|
||||||
|
// the Business Source License, use of this software will be governed
|
||||||
|
// by the Apache License, Version 2.0, included in the file
|
||||||
|
// licenses/APL.txt.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <iostream>
|
||||||
|
#include <memory>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include <fmt/format.h>
|
||||||
|
|
||||||
|
#include "slk/streams.hpp"
|
||||||
|
#include "utils/logging.hpp"
|
||||||
|
|
||||||
|
namespace memgraph::slk {
|
||||||
|
|
||||||
|
/// Class used for basic SLK use-cases.
|
||||||
|
/// It creates a `memgraph::slk::Builder` that can be written to. After you
|
||||||
|
/// have written the data to the builder, you can get a `memgraph::slk::Reader`
|
||||||
|
/// and try to decode the encoded data.
|
||||||
|
class Loopback {
|
||||||
|
public:
|
||||||
|
Loopback() = default;
|
||||||
|
Loopback(const Loopback &) = delete;
|
||||||
|
Loopback &operator=(const Loopback &) = delete;
|
||||||
|
Loopback(Loopback &&) = delete;
|
||||||
|
Loopback &operator=(Loopback &&) = delete;
|
||||||
|
|
||||||
|
~Loopback() {
|
||||||
|
MG_ASSERT(builder_, "You haven't created a builder!");
|
||||||
|
MG_ASSERT(reader_, "You haven't created a reader!");
|
||||||
|
reader_->Finalize();
|
||||||
|
}
|
||||||
|
|
||||||
|
memgraph::slk::Builder *GetBuilder() {
|
||||||
|
MG_ASSERT(!builder_, "You have already allocated a builder!");
|
||||||
|
builder_ = std::make_unique<memgraph::slk::Builder>(
|
||||||
|
[this](const uint8_t *data, size_t size, bool have_more) { Write(data, size, have_more); });
|
||||||
|
return builder_.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
memgraph::slk::Reader *GetReader() {
|
||||||
|
MG_ASSERT(builder_, "You must first get a builder before getting a reader!");
|
||||||
|
MG_ASSERT(!reader_, "You have already allocated a reader!");
|
||||||
|
builder_->Finalize();
|
||||||
|
auto ret = memgraph::slk::CheckStreamComplete(data_.data(), data_.size());
|
||||||
|
MG_ASSERT(ret.status == memgraph::slk::StreamStatus::COMPLETE);
|
||||||
|
MG_ASSERT(ret.stream_size == data_.size());
|
||||||
|
size_ = ret.encoded_data_size;
|
||||||
|
reader_ = std::make_unique<memgraph::slk::Reader>(data_.data(), data_.size());
|
||||||
|
return reader_.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t size() const { return size_; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
void Write(const uint8_t *data, size_t size, bool have_more) {
|
||||||
|
for (size_t i = 0; i < size; ++i) {
|
||||||
|
data_.push_back(data[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<uint8_t> data_;
|
||||||
|
std::unique_ptr<memgraph::slk::Builder> builder_;
|
||||||
|
std::unique_ptr<memgraph::slk::Reader> reader_;
|
||||||
|
size_t size_{0};
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace memgraph::slk
|
@ -1,4 +1,4 @@
|
|||||||
// Copyright 2022 Memgraph Ltd.
|
// Copyright 2023 Memgraph Ltd.
|
||||||
//
|
//
|
||||||
// Use of this software is governed by the Business Source License
|
// Use of this software is governed by the Business Source License
|
||||||
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
||||||
@ -46,7 +46,7 @@ static_assert(kSegmentMaxDataSize <= std::numeric_limits<SegmentSize>::max(),
|
|||||||
/// Builder used to create a SLK segment stream.
|
/// Builder used to create a SLK segment stream.
|
||||||
class Builder {
|
class Builder {
|
||||||
public:
|
public:
|
||||||
Builder(std::function<void(const uint8_t *, size_t, bool)> write_func);
|
explicit Builder(std::function<void(const uint8_t *, size_t, bool)> write_func);
|
||||||
|
|
||||||
/// Function used internally by SLK to serialize the data.
|
/// Function used internally by SLK to serialize the data.
|
||||||
void Save(const uint8_t *data, uint64_t size);
|
void Save(const uint8_t *data, uint64_t size);
|
||||||
|
Loading…
Reference in New Issue
Block a user