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