summaryrefslogtreecommitdiffstats
path: root/kexi/core/kexipartinfo.h
diff options
context:
space:
mode:
Diffstat (limited to 'kexi/core/kexipartinfo.h')
-rw-r--r--kexi/core/kexipartinfo.h160
1 files changed, 160 insertions, 0 deletions
diff --git a/kexi/core/kexipartinfo.h b/kexi/core/kexipartinfo.h
new file mode 100644
index 00000000..43cf5b87
--- /dev/null
+++ b/kexi/core/kexipartinfo.h
@@ -0,0 +1,160 @@
+/* This file is part of the KDE project
+ Copyright (C) 2003 Lucijan Busch <[email protected]>
+ Copyright (C) 2003,2005 Jaroslaw Staniek <[email protected]>
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; either
+ version 2 of the License, or (at your option) any later version.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this library; see the file COPYING.LIB. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+*/
+
+#ifndef KEXIPARTINFO_H
+#define KEXIPARTINFO_H
+
+#include "kexipartmanager.h"
+
+class KexiMainWindowImpl;
+class KexiProject;
+class KexiDialogBase;
+
+namespace KexiPart
+{
+
+ class Manager;
+ class Item;
+ class Part;
+
+/**
+ * @short Information about a Kexi Part (plugin).
+ */
+class KEXICORE_EXPORT Info
+{
+ public:
+ Info(KService::Ptr service);
+ ~Info();
+
+ /**
+ * @return a i18n'ed group name e.g. "Tables"
+ */
+ QString groupName() const;
+
+ /**
+ * @return the internal mime type of this part
+ */
+ QCString mimeType() const;
+
+// /**
+// * @return the icon for groups
+// */
+// inline QString groupIcon() const { return m_groupIcon; }
+
+ /**
+ * @return the icon for a item
+ */
+ QString itemIcon() const;
+
+ /**
+ * @return the icon for a item
+ */
+ QString createItemIcon() const;
+
+ /**
+ * @return the object name associated with this part (e.g. "table")
+ */
+ QString objectName() const;
+
+ /**
+ * @return the project-part-id
+ */
+ int projectPartID() const;
+
+ /**
+ * @return the KService::Ptr associated with this part
+ */
+ KService::Ptr ptr() const;
+
+ /**
+ * @return true if loading was tried but failed
+ */
+ bool isBroken() const;
+
+ /**
+ * \return true if the part should be visible in the Project Navigator (as a folder).
+ */
+ bool isVisibleInNavigator() const;
+
+ /**
+ * \return true if the part supports data exporting.
+ */
+ bool isDataExportSupported() const;
+
+ /**
+ * \return true if the part supports data printing.
+ */
+ bool isPrintingSupported() const;
+
+ /**
+ * \return true if the part supports execution. This is as
+ * example the case for the Macro and the Scripting plugins.
+ */
+ bool isExecuteSupported() const;
+
+ protected:
+ /**
+ * Used in StaticInfo
+ */
+ Info();
+
+ friend class Manager;
+ friend class ::KexiProject;
+ friend class ::KexiMainWindowImpl;
+ friend class ::KexiDialogBase;
+
+ /**
+ * Sets the project-part-id.
+ */
+ void setProjectPartID(int id);
+
+ /**
+ * Sets the broken flag and error message.
+ * Most likely to be called by @ref KexiPart::Manager
+ */
+ void setBroken(bool broken, const QString& errorMessage);
+
+ /**
+ * \return i18n'd error message set by setBroken().
+ */
+ QString errorMessage() const;
+
+ void setIdStoredInPartDatabase(bool set);
+
+ /**
+ * \return true if ID of the part is stored in project's database
+ * false by default. This flag is updated in Manager::checkProject()
+ * and set to true on first successful execution of KexiDialogBase::storeNewData()
+ * @internal
+ */
+ bool isIdStoredInPartDatabase() const;
+
+ class Private;
+ Private *d;
+};
+
+/*! \return "create" KAction's name for part defined by \a info.
+ The result is like "tablepart_create". Used in Part::createGUIClients()
+ and KexiBrowser. */
+KEXICORE_EXPORT QCString nameForCreateAction(const Info& info);
+
+}
+
+#endif