// Copyright 2024 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef TESTING_LIBFUZZER_RESEARCH_DOMATOLPM_DOMATOLPM_H_ #define TESTING_LIBFUZZER_RESEARCH_DOMATOLPM_DOMATOLPM_H_ #include #include #include #include #include "base/strings/string_number_conversions.h" namespace domatolpm { // SampleBuilder is used by the internal runtime DomatoLPM generated code to // build the current sample. // This is a very dumb interface, but allows for modularity and extensibility // without changing the generated code. class SampleBuilder { public: virtual ~SampleBuilder() = default; virtual std::string_view view() = 0; virtual void append(std::string_view) = 0; }; // TextSampleBuilder builds a sample into a string. class TextSampleBuilder : public SampleBuilder { public: TextSampleBuilder() = default; ~TextSampleBuilder() override = default; std::string_view view() override; void append(std::string_view v) override; private: std::string data_; }; // Context is used by the internal runtime DomatoLPM generated code to interact // with the current context. It is used to retrieve the current sample builder // and interact with existing variables. class Context { public: Context() = default; SampleBuilder* GetBuilder(); bool HasVar(const std::string& var_type); void SetVar(const std::string& var_type, const std::string& var_name); std::string_view GetVar(const std::string& var_type, int32_t id); std::string GetNewID(); private: TextSampleBuilder builder_; std::unordered_map> vars_; uint64_t id_ = 0; }; } // namespace domatolpm #endif // TESTING_LIBFUZZER_RESEARCH_DOMATOLPM_DOMATOLPM_H_