Horizon
rule_parameters.hpp
1 #pragma once
2 #include "common/common.hpp"
3 #include "rules/rule.hpp"
4 
5 namespace horizon {
6 class RuleParameters : public Rule {
7 public:
8  static const auto id = RuleID::PARAMETERS;
9  RuleID get_id() const override
10  {
11  return id;
12  }
13 
15  RuleParameters(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  return true;
22  }
23 
24  uint64_t solder_mask_expansion = 0.1_mm;
25  uint64_t paste_mask_contraction = 0;
26  uint64_t courtyard_expansion = 0.25_mm;
27  uint64_t via_solder_mask_expansion = 0.1_mm;
28  uint64_t hole_solder_mask_expansion = 0.1_mm;
29 };
30 } // namespace horizon
A block is one level of hierarchy in the netlist.
Definition: block.hpp:29
Definition: ipool.hpp:14
Definition: rule.hpp:34
Definition: rule_parameters.hpp:6
Definition: rule.hpp:54
a class to store JSON values
Definition: json.hpp:177
zip_uint64_t uint64_t
zip_uint64_t_t typedef.
Definition: zip.hpp:108