2 #include "util/uuid.hpp"
3 #include "nlohmann/json_fwd.hpp"
4 #include "pool/unit.hpp"
5 #include "block/block.hpp"
7 #include "schematic_rules.hpp"
8 #include "common/pdf_export_settings.hpp"
9 #include <glibmm/regex.h>
13 #include "util/file_version.hpp"
14 #include "util/template_util.hpp"
32 unsigned int update_nets();
40 static unsigned int get_app_version();
48 void expand_connectivity(
bool carful =
false);
51 void operator=(
const Schematic &sch) =
delete;
89 void swap_gates(
const UUID &comp,
const UUID &g1,
const UUID &g2);
93 std::map<UUIDPath<2>, std::string> get_unplaced_gates()
const;
96 void delete_sheet(
const UUID &uu);
97 Sheet &get_sheet_at_index(
unsigned int index);
98 const Sheet &get_sheet_at_index(
unsigned int index)
const;
100 static Glib::RefPtr<Glib::Regex> get_sheetref_regex();
105 std::map<UUID, Sheet> sheets;
107 bool group_tag_visible =
false;
114 enum class Order { RIGHT_DOWN, DOWN_RIGHT };
115 Order order = Order::RIGHT_DOWN;
117 enum class Mode { SEQUENTIAL, SHEET_100, SHEET_1000 };
118 Mode mode = Mode::SHEET_100;
120 bool fill_gaps =
true;
122 bool ignore_unknown =
false;
123 json serialize()
const;
131 std::map<UUIDVec, unsigned int> sheet_numbers;
132 unsigned int sheet_total;
136 void update(
const Schematic &sch,
const UUIDVec &instance_path);
141 void update_sheet_mapping();
144 SheetItem(make_const_ref_t<c, Sheet> sh,
unsigned int i, make_const_ref_t<c, Schematic> sch,
const UUIDVec &p)
145 : sheet(sh), sheet_index(i), schematic(sch), instance_path(p)
148 make_const_ref_t<c, Sheet> sheet;
149 unsigned int sheet_index;
150 make_const_ref_t<c, Schematic> schematic;
151 UUIDVec instance_path;
154 std::vector<SheetItem<false>> get_all_sheets();
155 std::vector<SheetItem<true>> get_all_sheets()
const;
161 json serialize()
const;
162 void load_pictures(
const std::string &dir);
164 ItemSet get_pool_items_used()
const;
166 std::vector<Sheet *> get_sheets_sorted();
167 std::vector<const Sheet *> get_sheets_sorted()
const;
A block is one level of hierarchy in the netlist.
Definition: block.hpp:29
Definition: file_version.hpp:9
Definition: iblock_symbol_and_schematic_provider.hpp:6
Definition: iinstancce_mapping_provider.hpp:4
LineNet is similar to Line, except it denotes electrical connection.
Definition: line_net.hpp:17
Definition: pdf_export_settings.hpp:9
Definition: schematic_block_symbol.hpp:12
Definition: schematic_rules.hpp:10
Definition: schematic_symbol.hpp:17
Definition: schematic.hpp:110
Definition: schematic.hpp:129
A Schematic is the visual representation of a Block.
Definition: schematic.hpp:30
void smash_symbol(Sheet *sheet, SchematicSymbol *sym)
Turns sym's texts to regular text objects.
Definition: schematic.cpp:330
void unsmash_symbol(Sheet *sheet, SchematicSymbol *sym)
Undoes what smash_symbol did.
Definition: schematic.cpp:363
void autoconnect_symbol(Sheet *sheet, SchematicSymbol *sym)
Connects unconnected pins of sym to Nets specified by junctions coincident with pins.
Definition: schematic.cpp:106
void update_refs()
objects owned by the Sheets may hold pointers to other objects of the same sheet or the Block associa...
Definition: schematic.cpp:1278
void disconnect_symbol(Sheet *sheet, SchematicSymbol *sym)
Removes all connections from sym and connects the dangling net lines to junctions.
Definition: schematic.cpp:267
void expand(bool careful=false, const class IInstanceMappingProvider *inst_map=nullptr)
This is where the magic happens.
Definition: schematic.cpp:823
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
basic_json<> json
default JSON class
Definition: json_fwd.hpp:62
Definition: schematic.hpp:143