HAL
gatelibrary_tab_pin.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
28
#include "
gatelibrary_tab_interface.h
"
29
#include "
gui/selection_details_widget/gate_details_widget/pin_tree_model.h
"
30
#include "
hal_core/defines.h
"
31
#include "
hal_core/netlist/gate_library/gate_type.h
"
32
33
#include <QGridLayout>
34
#include <QLabel>
35
#include <QTreeView>
36
#include <
gui/pin_model/pin_model.h
>
37
38
namespace
hal
39
{
40
class
PinTreeView
:
public
QTreeView
41
{
42
Q_OBJECT
43
44
/* controll tree navigation using arrow keys
45
protected:
46
QModelIndex moveCursor(QAbstractItemView::CursorAction cursorAction, Qt::KeyboardModifiers modifiers) override;
47
*/
48
49
public
Q_SLOTS
:
50
void
handleEditNewDone
(
const
QModelIndex
& index);
51
52
public
:
53
PinTreeView
(
QWidget
*
parent
=
nullptr
);
54
};
55
59
class
GateLibraryTabPin
:
public
GateLibraryTabInterface
60
{
61
Q_OBJECT
62
63
public
:
64
GateLibraryTabPin
(
bool
editable =
false
,
QWidget
*
parent
=
nullptr
);
65
QTreeView
*
getTreeView
();
66
PinModel
*
getPinModel
();
67
68
void
update
(
GateType
* gate)
override
;
69
70
71
private
:
72
PinModel
* mPinModel;
73
PinTreeView
* mTreeView;
74
75
QGridLayout
* mGridLayout;
76
77
78
};
79
80
}
hal::GateLibraryTabInterface
Definition:
gatelibrary_tab_interface.h:39
hal::GateLibraryTabPin
Definition:
gatelibrary_tab_pin.h:60
hal::GateLibraryTabPin::GateLibraryTabPin
GateLibraryTabPin(bool editable=false, QWidget *parent=nullptr)
Definition:
gatelibrary_tab_pin.cpp:54
hal::GateLibraryTabPin::getPinModel
PinModel * getPinModel()
Definition:
gatelibrary_tab_pin.cpp:94
hal::GateLibraryTabPin::getTreeView
QTreeView * getTreeView()
Definition:
gatelibrary_tab_pin.cpp:89
hal::GateType
Definition:
gate_type.h:52
hal::PinModel
Definition:
pin_model.h:50
hal::PinTreeView
Definition:
gatelibrary_tab_pin.h:41
hal::PinTreeView::handleEditNewDone
void handleEditNewDone(const QModelIndex &index)
Definition:
gatelibrary_tab_pin.cpp:40
hal::PinTreeView::PinTreeView
PinTreeView(QWidget *parent=nullptr)
Definition:
gatelibrary_tab_pin.cpp:13
defines.h
gate_type.h
gatelibrary_tab_interface.h
hal
Definition:
parser_liberty.cpp:10
pin_model.h
pin_tree_model.h
QGridLayout
QModelIndex
QObject::Q_OBJECT
Q_OBJECTQ_OBJECT
QObject::Q_SLOTS
Q_SLOTSQ_SLOTS
QObject::parent
QObject * parent() const const
QTreeView
QWidget
QWidget::update
void update()
plugins
gui
include
gui
gatelibrary_management
gatelibrary_tab_widgets
gatelibrary_tab_pin.h
Generated on Fri Feb 14 2025 14:22:41 for HAL by
1.9.1