diff options
Diffstat (limited to 'python/pykde/sip/kio/kacl.sip')
-rw-r--r-- | python/pykde/sip/kio/kacl.sip | 166 |
1 files changed, 166 insertions, 0 deletions
diff --git a/python/pykde/sip/kio/kacl.sip b/python/pykde/sip/kio/kacl.sip new file mode 100644 index 00000000..3745dabe --- /dev/null +++ b/python/pykde/sip/kio/kacl.sip @@ -0,0 +1,166 @@ +// +// Copyright 2006 Jim Bublitz <jbublitz@nwinternet.com> +// Earlier copyrights 1998 - 2005 Jim Bublitz and/or Phil Thompson +// may also apply + + +// Generated by preSip +// module kio 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., +// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + + +%If ( KDE_3_5_0 - ) + +class KACL +{ +%TypeHeaderCode +#include <kacl.h> +%End + + +public: + KACL (const QString&); + KACL (const KACL&); + KACL (mode_t); + KACL (); + bool operator == (const KACL&) const; + bool operator != (const KACL&) const; + bool isValid () const; + ushort ownerPermissions () const; + bool setOwnerPermissions (ushort); + ushort owningGroupPermissions () const; + bool setOwningGroupPermissions (ushort); + ushort othersPermissions () const; + bool setOthersPermissions (ushort); + mode_t basePermissions () const; + bool isExtended () const; + ushort maskPermissions (bool&) const; + bool setMaskPermissions (ushort); + ushort namedUserPermissions (const QString&, bool*) const; + bool setNamedUserPermissions (const QString&, ushort); + ACLUserPermissionsList allUserPermissions () const; + bool setAllUserPermissions (const ACLUserPermissionsList&); + ushort namedGroupPermissions (const QString&, bool*) const; + bool setNamedGroupPermissions (const QString&, ushort); + ACLGroupPermissionsList allGroupPermissions () const; + bool setAllGroupPermissions (const ACLGroupPermissionsList&); + bool setACL (const QString&); + QString asString () const; + +protected: + virtual void virtual_hook (int, void*); + +}; // class KACL + +%End + + +%If ( KDE_3_5_0 - ) +typedef QPair<QString,unsigned short> ACLUserPermissions; +typedef QValueList<ACLUserPermissions> ACLUserPermissionsList; +//igx typedef QValueListIterator<ACLUserPermissions> ACLUserPermissionsIterator; +//igx typedef QValueListConstIterator<ACLUserPermissions> ACLUserPermissionsConstIterator; +//igx typedef QPair<QString,unsigned short> ACLGroupPermissions; +//igx typedef QValueList<ACLGroupPermissions> ACLGroupPermissionsList; +//igx typedef QValueListIterator<ACLGroupPermissions> ACLGroupPermissionsIterator; +//igx typedef QValueListConstIterator<ACLGroupPermissions> ACLGroupPermissionsConstIterator; +//igx QDataStream& operator << (QDataStream&, const KACL&); +//igx QDataStream& operator >> (QDataStream&, KACL&); +//force +typedef ACLUserPermissionsList ACLGroupPermissionsList; +//end +%End + + +%MappedType QValueList<ACLUserPermissions> +//converts a Python list of ACLUserPermissions tuples (QString, int) +{ +%TypeHeaderCode +#include <qvaluelist.h> +#include <qstring.h> +#include <kacl.h> +#include <sipqtQString.h> +#include <sipkioKACL.h> +%End + +%ConvertFromTypeCode + if (!sipCpp) + return PyList_New(0); + + // Create the list + PyObject *pylist; + if ((pylist = PyList_New(0)) == NULL) + return NULL; + + QValueList<ACLUserPermissions> *cpplist = (QValueList<ACLUserPermissions> *)sipCpp; + PyObject *inst; + + // Get it. + QValueList<ACLUserPermissions>::Iterator it; + for( it = cpplist->begin(); it != cpplist->end(); ++it ) + { + QString s = (*it).first; + ushort u = (*it).second; + PyObject *pys = sipBuildResult (NULL, "N", new QString (s), sipClass_QString); + if ((pys == NULL) || ((inst = Py_BuildValue ("Ni", pys, u)) == NULL) + || PyList_Append (pylist, inst) < 0) + { + Py_XDECREF (inst); + Py_XDECREF (pys); + Py_DECREF (pylist); + return NULL; + } + } + + return pylist; +%End + + +%ConvertToTypeCode + if (sipIsErr == NULL) + return PyList_Check(sipPy); + + QValueList<ACLUserPermissions> *cpplist = new QValueList<ACLUserPermissions>; + + QString p1; + int iserr = 0; + + for (int i = 0; i < PyList_Size (sipPy); i++) + { + PyObject *elem = PyList_GET_ITEM (sipPy, i); + PyObject *pyp1 = PyTuple_GET_ITEM (elem, 0); + p1 = *(QString *)sipForceConvertTo_QString (pyp1, &iserr); + + if (iserr) + { + *sipIsErr = 1; + delete cpplist; + return 0; + } + ushort p2 = (ushort)(PyInt_AS_LONG (PyTuple_GET_ITEM (elem, 1))); + + cpplist->append (ACLUserPermissions (p1, p2)); + } + + *sipCppPtr = cpplist; + + return 1; +%End +}; + + |