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"
31 unsigned int update_nets();
37 static unsigned int get_app_version();
44 void expand(
bool careful =
false);
47 void operator=(
const Schematic &sch) =
delete;
84 void swap_gates(
const UUID &comp,
const UUID &g1,
const UUID &g2);
86 std::map<UUIDPath<2>, std::string> get_unplaced_gates()
const;
88 static Glib::RefPtr<Glib::Regex> get_sheetref_regex();
93 std::map<UUID, Sheet> sheets;
95 bool group_tag_visible =
false;
102 enum class Order { RIGHT_DOWN, DOWN_RIGHT };
103 Order order = Order::RIGHT_DOWN;
105 enum class Mode { SEQUENTIAL, SHEET_100, SHEET_1000 };
106 Mode mode = Mode::SHEET_100;
108 bool fill_gaps =
true;
110 bool ignore_unknown =
false;
111 json serialize()
const;
121 json serialize()
const;
122 void save_pictures(
const std::string &dir)
const;
123 void load_pictures(
const std::string &dir);
125 ItemSet get_pool_items_used()
const;
A block is one level of hierarchy in the netlist.
Definition: block.hpp:26
Definition: file_version.hpp:8
LineNet is similar to Line, except it denotes electrical connection.
Definition: line_net.hpp:17
Definition: pdf_export_settings.hpp:9
Definition: schematic_rules.hpp:10
Definition: schematic_symbol.hpp:17
Definition: schematic.hpp:98
A Schematic is the visual representation of a Block.
Definition: schematic.hpp:29
void expand(bool careful=false)
This is where the magic happens.
Definition: schematic.cpp:466
void smash_symbol(Sheet *sheet, SchematicSymbol *sym)
Turns sym's texts to regular text objects.
Definition: schematic.cpp:241
void unsmash_symbol(Sheet *sheet, SchematicSymbol *sym)
Undoes what smash_symbol did.
Definition: schematic.cpp:274
void autoconnect_symbol(Sheet *sheet, SchematicSymbol *sym)
Connects unconnected pins of sym to Nets specified by junctions coincident with pins.
Definition: schematic.cpp:103
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:1035
void disconnect_symbol(Sheet *sheet, SchematicSymbol *sym)
Removes all connections from sym and connects the dangling net lines to junctions.
Definition: schematic.cpp:205
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
basic_json<> json
default JSON class
Definition: json_fwd.hpp:61