Horizon
Loading...
Searching...
No Matches
rule_hole_size.hpp
1#pragma once
2#include "common/common.hpp"
3#include "rules/rule.hpp"
4
5namespace horizon {
6class RuleHoleSize : public Rule {
7public:
8 static const auto id = RuleID::HOLE_SIZE;
9 RuleID get_id() const override
10 {
11 return id;
12 }
13
14 RuleHoleSize(const UUID &uu);
15 RuleHoleSize(const UUID &uu, const json &j, const RuleImportMap &import_map);
16 json serialize() const override;
17
18 std::string get_brief(const class Block *block = nullptr, class IPool *pool = nullptr) const override;
19 bool can_export() const override;
20
21 uint64_t diameter_min = 0.1_mm;
22 uint64_t diameter_max = 10_mm;
23 RuleMatch match;
24};
25} // namespace horizon
A block is one level of hierarchy in the netlist.
Definition block.hpp:29
Definition ipool.hpp:15
Definition rule_hole_size.hpp:6
Definition rule.hpp:38
Definition rule_match.hpp:9
Definition rule.hpp:58
This class encapsulates a UUID and allows it to be uses as a value type.
Definition uuid.hpp:16
a class to store JSON values
Definition json.hpp:177