Horizon
rule_track_width.hpp
1 #pragma once
2 #include "common/common.hpp"
3 #include "rules/rule.hpp"
4 #include "rules/rule_match.hpp"
5 
6 namespace horizon {
7 class RuleTrackWidth : public Rule {
8 public:
9  class Widths {
10  public:
11  Widths();
12  Widths(const json &j);
13  json serialize() const;
14 
15  uint64_t min = .1_mm;
16  uint64_t max = 10_mm;
17  uint64_t def = .2_mm;
18  };
19 
20  RuleTrackWidth(const UUID &uu);
21  RuleTrackWidth(const UUID &uu, const json &j, const RuleImportMap &import_map);
22  json serialize() const override;
23 
24  std::string get_brief(const class Block *block = nullptr) const override;
25  bool is_match_all() const override;
26  bool can_export() const override;
27 
28  RuleMatch match;
29  std::map<int, Widths> widths;
30 };
31 } // namespace horizon
A block is one level of hierarchy in the netlist.
Definition: block.hpp:26
Definition: rule.hpp:33
Definition: rule_match.hpp:8
Definition: rule_track_width.hpp:9
Definition: rule_track_width.hpp:7
Definition: rule.hpp:53
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:166
zip_uint64_t uint64_t
zip_uint64_t_t typedef.
Definition: zip.hpp:108