Horizon
rule_hole_size.hpp
1 #pragma once
2 #include "common/common.hpp"
3 #include "rules/rule.hpp"
4 
5 namespace horizon {
6 class RuleHoleSize : public Rule {
7 public:
8  RuleHoleSize(const UUID &uu);
9  RuleHoleSize(const UUID &uu, const json &j);
10  json serialize() const override;
11 
12  std::string get_brief(const class Block *block = nullptr) const override;
13 
14  uint64_t diameter_min = 0.1_mm;
15  uint64_t diameter_max = 10_mm;
16  RuleMatch match;
17 };
18 } // namespace horizon
horizon::RuleMatch
Definition: rule_match.hpp:8
horizon::Rule
Definition: rule.hpp:33
horizon::RuleHoleSize
Definition: rule_hole_size.hpp:6
horizon::Block
A block is one level of hierarchy in the netlist.
Definition: block.hpp:25
nlohmann::basic_json
a class to store JSON values
Definition: json.hpp:166
horizon::UUID
This class encapsulates a UUID and allows it to be uses as a value type.
Definition: uuid.hpp:16
libzip::uint64_t
zip_uint64_t uint64_t
zip_uint64_t_t typedef.
Definition: zip.hpp:108