1 | #pragma once |
2 | |
3 | /**************************************************************************************** |
4 | ** GitQlient is an application to manage and operate one or several Git repositories. With |
5 | ** GitQlient you will be able to add commits, branches and manage all the options Git provides. |
6 | ** Copyright (C) 2021 Francesc Martinez |
7 | ** |
8 | ** LinkedIn: www.linkedin.com/in/cescmm/ |
9 | ** Web: www.francescmm.com |
10 | ** |
11 | ** This program is free software; you can redistribute it and/or |
12 | ** modify it under the terms of the GNU Lesser General Public |
13 | ** License as published by the Free Software Foundation; either |
14 | ** version 2 of the License, or (at your option) any later version. |
15 | ** |
16 | ** This program is distributed in the hope that it will be useful, |
17 | ** but WITHOUT ANY WARRANTY; without even the implied warranty of |
18 | ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
19 | ** Lesser General Public License for more details. |
20 | ** |
21 | ** You should have received a copy of the GNU Lesser General Public |
22 | ** License along with this library; if not, write to the Free Software |
23 | ** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
24 | ***************************************************************************************/ |
25 | |
26 | #include <QMenu> |
27 | |
28 | class GitBase; |
29 | |
30 | /*! |
31 | \brief The StashesContextMenu shows the different options that can be performed to the stashes. |
32 | |
33 | */ |
34 | class : public QMenu |
35 | { |
36 | Q_OBJECT |
37 | |
38 | signals: |
39 | /*! |
40 | \brief Signal triggered if a stash was removed. |
41 | |
42 | */ |
43 | void (); |
44 | /*! |
45 | \brief Signal triggered when the main GitQlient UI needs to be updated because of a change in the stashes. |
46 | |
47 | */ |
48 | void (); |
49 | |
50 | public: |
51 | /*! |
52 | \brief Default constructor. |
53 | |
54 | \param git The git object to perform Git operations. |
55 | \param stashId The stash ID that will be used to perform operations into. |
56 | \param parent The parent widget if needed. |
57 | */ |
58 | explicit (const QSharedPointer<GitBase> &git, const QString &stashId, QWidget *parent = nullptr); |
59 | |
60 | private: |
61 | QSharedPointer<GitBase> ; |
62 | QString ; |
63 | |
64 | /*! |
65 | \brief Drops a stash. |
66 | |
67 | */ |
68 | void (); |
69 | /*! |
70 | \brief Clears the stash. |
71 | |
72 | */ |
73 | void (); |
74 | /*! |
75 | \brief Creates a branch where the stash is located. |
76 | |
77 | */ |
78 | void (); |
79 | }; |
80 | |