HAL
action_add_items_to_object.h
Go to the documentation of this file.
1 // MIT License
2 //
3 // Copyright (c) 2019 Ruhr University Bochum, Chair for Embedded Security. All Rights reserved.
4 // Copyright (c) 2019 Marc Fyrbiak, Sebastian Wallat, Max Hoffmann ("ORIGINAL AUTHORS"). All rights reserved.
5 // Copyright (c) 2021 Max Planck Institute for Security and Privacy. All Rights reserved.
6 // Copyright (c) 2021 Jörn Langheinrich, Julian Speith, Nils Albartus, René Walendy, Simon Klix ("ORIGINAL AUTHORS"). All Rights reserved.
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to deal
10 // in the Software without restriction, including without limitation the rights
11 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 // copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
14 //
15 // The above copyright notice and this permission notice shall be included in all
16 // copies or substantial portions of the Software.
17 //
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
24 // SOFTWARE.
25 
26 #pragma once
27 #include "user_action.h"
28 #include "gui/gui_def.h"
29 #include <QSet>
30 
31 namespace hal
32 {
42  {
43  QSet<u32> mModules;
44  QSet<u32> mGates;
45  QSet<u32> mNets;
46  QSet<u32> mPins;
47  PlacementHint mPlacementHint;
48  Node mPlacementOrigin;
49  bool mUsedInCreateContext;
50  bool mDeleteSource;
51 
52  public:
62  const QSet<u32>& gats = QSet<u32>(),
63  const QSet<u32>& nets = QSet<u32>(),
64  const QSet<u32>& pins = QSet<u32>())
65  : mModules(mods), mGates(gats), mNets(nets), mPins(pins),
66  mPlacementHint(PlacementHint::Standard), mUsedInCreateContext(false),
67  mDeleteSource(true)
68  {;}
69  bool exec() override;
70 
76  void setPlacementHint(PlacementHint hint) { mPlacementHint = hint; }
77 
83  void setUsedInCreateContext() { mUsedInCreateContext = true; }
84  QString tagname() const override;
85  void writeToXml(QXmlStreamWriter& xmlOut) const override;
86  void readFromXml(QXmlStreamReader& xmlIn) override;
87  void addToHash(QCryptographicHash& cryptoHash) const override;
88  };
89 
95  {
96  public:
98  UserAction* newAction() const;
100  };
101 }
UserActionFactory for ActionAddItemsToObject.
static ActionAddItemsToObjectFactory * sFactory
Adds an item to a module or grouping.
void writeToXml(QXmlStreamWriter &xmlOut) const override
ActionAddItemsToObject(const QSet< u32 > &mods=QSet< u32 >(), const QSet< u32 > &gats=QSet< u32 >(), const QSet< u32 > &nets=QSet< u32 >(), const QSet< u32 > &pins=QSet< u32 >())
void setPlacementHint(PlacementHint hint)
void readFromXml(QXmlStreamReader &xmlIn) override
void addToHash(QCryptographicHash &cryptoHash) const override
The Node class object represents a module or a gate.
Definition: gui_def.h:61
The PlacementHint class object provides hints for the layouter how new box objects are placed on a vi...
Definition: gui_def.h:196
The UserActionFactory is the abstract base class for registration.
Definition: user_action.h:225
The UserAction class is the abstract base class for user interactions.
Definition: user_action.h:57
std::vector< PinInformation > pins