Horizon
rule_diffpair.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 RuleDiffpair : public Rule {
8 public:
9  static const auto id = RuleID::DIFFPAIR;
10  RuleID get_id() const override
11  {
12  return id;
13  }
14 
15  RuleDiffpair(const UUID &uu);
16  RuleDiffpair(const UUID &uu, const json &j, const RuleImportMap &import_map);
17  json serialize() const override;
18 
19  std::string get_brief(const class Block *block = nullptr, class IPool *pool = nullptr) const override;
20  bool can_export() const override
21  {
22  return true;
23  }
24 
25  UUID net_class;
26  int layer = 10000;
27 
28  uint64_t track_width = .2_mm;
29  uint64_t track_gap = .2_mm;
30  uint64_t via_gap = .2_mm;
31 };
32 } // namespace horizon
A block is one level of hierarchy in the netlist.
Definition: block.hpp:29
Definition: ipool.hpp:14
Definition: rule_diffpair.hpp:7
Definition: rule.hpp:34
Definition: rule.hpp:54
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
zip_uint64_t uint64_t
zip_uint64_t_t typedef.
Definition: zip.hpp:108