// // Copyright 2006 Jim Bublitz // Earlier copyrights 1998 - 2005 Jim Bublitz and/or Phil Thompson // may also apply // Generated by preSip // module tdecore version KDE 3.5.3 // This software is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as // published by the Free Software Foundation; either version 2 of // the License, or (at your option) any later version. // // This software 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 General Public License for more details. // // You should have received a copy of the GNU General Public // License along with this library; see the file COPYING. // If not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. class KConfig : KConfigBase { %TypeHeaderCode #include %End public: KConfig (const TQString& = TQString ::null , bool = 0, bool = 1, const char* = "config"); %If ( KDE_3_2_0 - ) KConfig (KConfigBackEnd*, bool = 0); %End virtual void rollback (bool = 1); virtual TQStringList groupList () const; virtual TQMap entryMap (const TQString&) const; virtual void reparseConfiguration (); void setFileWriteMode (int); void setForceGlobal (bool); bool forceGlobal () const; %If ( KDE_3_1_0 - ) void checkUpdate (const TQString&, const TQString&); %If ( KDE_3_2_0 - ) KConfig* copyTo (const TQString&, KConfig* = 0) const; %If ( KDE_3_3_0 - ) KLockFile::Ptr lockFile (bool = 0); %End %End %End protected: virtual bool internalHasGroup (const TQCString&) const; virtual KEntryMap internalEntryMap (const TQString&) const; virtual KEntryMap internalEntryMap () const; virtual void putData (const KEntryKey&, const KEntry&, bool = 1); virtual KEntry lookupData (const KEntryKey&) const; private: KConfig (const KConfig&); protected: //igx virtual void virtual_hook (int, void*); }; // class KConfig %If ( KDE_3_2_0 - ) class KSharedConfig : KConfig, KShared { %TypeHeaderCode #include %End public: //ig typedef KSharedPtr Ptr; public: static KSharedConfig::Ptr openConfig (const TQString&, bool = 0, bool = 1); private: KSharedConfig (const TQString&, bool, bool); ~KSharedConfig (); }; // class KSharedConfig %End %MappedType TQMap //converts a Python dict of TQString:TQString { %TypeHeaderCode #include %End %ConvertFromTypeCode // Convert to a Python dict if (!sipCpp) return PyDict_New(); PyObject *dict; // Create the dictionary. if ((dict = PyDict_New()) == NULL) return NULL; // Get it. const TQMap cppmap = *sipCpp; TQMap::ConstIterator it; for (it = cppmap.begin (); it != cppmap.end (); ++it) { TQString acpp = it.key (); TQString bcpp = it.data (); PyObject *ainst; PyObject *binst = NULL; if (((ainst = sipConvertFromNewType(new TQString(acpp), sipType_QString, sipTransferObj)) == NULL) || ((binst = sipConvertFromNewType(new TQString(bcpp), sipType_QString, sipTransferObj)) == NULL) || (PyDict_SetItem (dict, ainst, binst) < 0)) { Py_XDECREF (ainst); Py_XDECREF (binst); Py_DECREF (dict); return NULL; } } return dict; %End %ConvertToTypeCode // Convert a Python dictionary to a TQMap on the heap. if (sipIsErr == NULL) return PyDict_Check(sipPy); TQMap *cppmap = new TQMap; PyObject *aelem, *belem; SIP_SSIZE_T pos = 0; TQString *acpp; TQString *bcpp; while (PyDict_Next(sipPy, &pos, &aelem, &belem)) { int iserr = 0, acpp_state, bcpp_state; acpp = (TQString *)sipForceConvertToType(aelem, sipType_QString, sipTransferObj, SIP_NOT_NONE, &acpp_state, &iserr); bcpp = (TQString *)sipForceConvertToType(belem, sipType_QString, sipTransferObj, SIP_NOT_NONE, &bcpp_state, &iserr); if (iserr) { if (acpp) sipReleaseType(acpp, sipType_QString, acpp_state); *sipIsErr = 1; delete cppmap; return 0; } cppmap->insert (*acpp, *bcpp); sipReleaseType(acpp, sipType_QString, acpp_state); sipReleaseType(bcpp, sipType_QString, bcpp_state); } *sipCppPtr = cppmap; return 1; %End }; %If (KDE_3_2_0 - ) %MappedType KSharedConfig::Ptr //converts KSharedConfig { %TypeHeaderCode #include #include %End %ConvertFromTypeCode // Convert to a Python instance if (!sipCpp) return NULL; KSharedPtr *cPtr = new KSharedPtr (*(KSharedPtr *)sipCpp); KSharedConfig *cpp = cPtr->data (); PyObject *obj = sipConvertFromInstance (cpp, sipClass_KSharedConfig, sipTransferObj); return obj; %End %ConvertToTypeCode // Convert a Python instance to a Ptr on the heap. if (sipIsErr == NULL) return PyInstance_Check(sipPy); int iserr = 0; KSharedConfig *cpp = (KSharedConfig *)sipForceConvertToType(sipPy, sipType_KSharedConfig, sipTransferObj, SIP_NO_CONVERTORS, NULL, &iserr); if (iserr) { *sipIsErr = 1; return 0; } *sipCppPtr = new KSharedPtr (cpp); return 1; %End }; %End