2 #include "nlohmann/json_fwd.hpp" 3 #include "util/uuid.hpp" 4 #include "util/uuid_provider.hpp" 5 #include "common/lut.hpp" 10 #include <yaml-cpp/yaml.h> 21 enum class Direction {
33 Pin(
const UUID &uu,
const YAML::Node &n);
41 Direction direction = Direction::INPUT;
43 static const std::vector<std::pair<Pin::Direction, std::string>> direction_names;
54 json serialize()
const;
55 void serialize_yaml(YAML::Emitter &em)
const;
56 UUID get_uuid()
const;
68 static Unit new_from_file(
const std::string &filename);
70 Unit(
const UUID &uu,
const YAML::Node &n);
73 std::string manufacturer;
74 std::map<UUID, Pin> pins;
75 json serialize()
const;
76 void serialize_yaml(YAML::Emitter &em)
const;
77 UUID get_uuid()
const;
a class to store JSON values
Definition: json.hpp:161
Interface for objects that have a UUID.
Definition: uuid_provider.hpp:9
std::vector< std::string > names
The Pin's alternate names.
Definition: unit.hpp:52
A Unit is the template for a Gate inside of an Entity.
Definition: unit.hpp:63
unsigned int swap_group
Pins of the same swap_group can be pinswapped.
Definition: unit.hpp:48
A Pin represents a logical pin of a Unit.
Definition: unit.hpp:19
std::string primary_name
The Pin's primary name.
Definition: unit.hpp:40
This class encapsulates a UUID and allows it to be uses as a value type.
Definition: uuid.hpp:16
basic_json<> json
default JSON class
Definition: json_fwd.hpp:61