Horizon
rule_clearance_copper.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 RuleClearanceCopper : public Rule {
8 public:
9  RuleClearanceCopper(const UUID &uu);
10  RuleClearanceCopper(const UUID &uu, const json &j);
11  json serialize() const override;
12 
13  std::string get_brief(const class Block *block = nullptr) const override;
14  bool is_match_all() const override;
15 
16  RuleMatch match_1;
17  RuleMatch match_2;
18  int layer = 10000;
19  uint64_t routing_offset = 0.05_mm;
20 
21  uint64_t get_clearance(PatchType a, PatchType b) const;
22  void set_clearance(PatchType a, PatchType b, uint64_t c);
23  uint64_t get_max_clearance() const;
24 
25 private:
26  std::array<uint64_t, static_cast<size_t>(PatchType::N_TYPES) * static_cast<size_t>(PatchType::N_TYPES)> clearances;
27 };
28 } // namespace horizon
horizon::RuleMatch
Definition: rule_match.hpp:8
horizon::Rule
Definition: rule.hpp:33
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
horizon::RuleClearanceCopper
Definition: rule_clearance_copper.hpp:7
libzip::uint64_t
zip_uint64_t uint64_t
zip_uint64_t_t typedef.
Definition: zip.hpp:108