File indexing completed on 2024-09-08 04:55:45

0001 /*
0002  *   SPDX-FileCopyrightText: 2003 Waldo Bastian <bastian@kde.org>
0003  *
0004  *   SPDX-License-Identifier: GPL-2.0-only
0005  *
0006  */
0007 
0008 #ifndef menufile_h
0009 #define menufile_h
0010 
0011 #include <qdom.h>
0012 
0013 #include <QList>
0014 #include <QStringList>
0015 
0016 class MenuFile
0017 {
0018 public:
0019     static const QString MF_MENU, MF_PUBLIC_ID, MF_SYSTEM_ID, MF_NAME, MF_INCLUDE, MF_EXCLUDE, MF_FILENAME, MF_DELETED, MF_NOTDELETED, MF_MOVE, MF_OLD, MF_NEW,
0020         MF_DIRECTORY, MF_LAYOUT, MF_MENUNAME, MF_SEPARATOR, MF_MERGE;
0021 
0022     explicit MenuFile(const QString &file);
0023     ~MenuFile();
0024 
0025     bool load();
0026     bool save();
0027     void create();
0028     QString error() const
0029     {
0030         return m_error;
0031     } // Returns the last error message
0032 
0033     void restoreMenuSystem(const QString &);
0034 
0035     enum ActionType {
0036         ADD_ENTRY = 0,
0037         REMOVE_ENTRY,
0038         ADD_MENU,
0039         REMOVE_MENU,
0040         MOVE_MENU,
0041     };
0042 
0043     struct ActionAtom {
0044         ActionType action;
0045         QString arg1;
0046         QString arg2;
0047     };
0048 
0049     /**
0050      * Create action atom and push it on the stack
0051      */
0052     ActionAtom *pushAction(ActionType action, const QString &arg1, const QString &arg2);
0053 
0054     /**
0055      * Pop @p atom from the stack.
0056      * @p atom must be last item on the stack
0057      */
0058     void popAction(ActionAtom *atom);
0059 
0060     /**
0061      * Perform the specified action
0062      */
0063     void performAction(const ActionAtom *);
0064 
0065     /**
0066      * Perform all actions currently on the stack, remove them from the stack and
0067      * save result
0068      * @return whether save was successful
0069      */
0070     bool performAllActions();
0071 
0072     /**
0073      * Returns whether the stack contains any actions
0074      */
0075     bool dirty() const;
0076 
0077     void addEntry(const QString &menuName, const QString &menuId);
0078     void removeEntry(const QString &menuName, const QString &menuId);
0079 
0080     void addMenu(const QString &menuName, const QString &menuFile);
0081     void moveMenu(const QString &oldMenu, const QString &newMenu);
0082     void removeMenu(const QString &menuName);
0083 
0084     void setLayout(const QString &menuName, const QStringList &layout);
0085 
0086     /**
0087      * Returns a unique menu-name for a new menu under @p menuName
0088      * inspired by @p newMenu and not part of @p excludeList
0089      */
0090     QString uniqueMenuName(const QString &menuName, const QString &newMenu, const QStringList &excludeList);
0091 
0092 protected:
0093     /**
0094      * Finds menu @p menuName in @p elem.
0095      * If @p create is true, the menu is created if it doesn't exist yet.
0096      * @return The menu dom-node of @p menuName
0097      */
0098     QDomElement findMenu(QDomElement elem, const QString &menuName, bool create);
0099 
0100 private:
0101     QString m_error;
0102     QString m_fileName;
0103 
0104     QDomDocument m_doc;
0105     bool m_bDirty;
0106 
0107     QList<ActionAtom *> m_actionList;
0108     QStringList m_removedEntries;
0109 };
0110 
0111 #endif