[Python-checkins] CVS: python/dist/src/RISCOS/Modules riscosmodule.c,1.1,1.2
Guido van Rossum
gvanrossum@users.sourceforge.net
Thu, 18 Oct 2001 13:34:28 -0700
Update of /cvsroot/python/python/dist/src/RISCOS/Modules
In directory usw-pr-cvs1:/tmp/cvs-serv7266/RISCOS/Modules
Modified Files:
riscosmodule.c
Log Message:
SF patch #462296: Add attributes to os.stat results; by Nick Mathewson.
This is a big one, touching lots of files. Some of the platforms
aren't tested yet. Briefly, this changes the return value of the
os/posix functions stat(), fstat(), statvfs(), fstatvfs(), and the
time functions localtime(), gmtime(), and strptime() from tuples into
pseudo-sequences. When accessed as a sequence, they behave exactly as
before. But they also have attributes like st_mtime or tm_year. The
stat return value, moreover, has a few platform-specific attributes
that are not available through the sequence interface (because
everybody expects the sequence to have a fixed length, these couldn't
be added there). If your platform's struct stat doesn't define
st_blksize, st_blocks or st_rdev, they won't be accessible from Python
either.
(Still missing is a documentation update.)
Index: riscosmodule.c
===================================================================
RCS file: /cvsroot/python/python/dist/src/RISCOS/Modules/riscosmodule.c,v
retrieving revision 1.1
retrieving revision 1.2
diff -C2 -d -r1.1 -r1.2
*** riscosmodule.c 2001/03/02 05:57:54 1.1
--- riscosmodule.c 2001/10/18 20:34:25 1.2
***************
*** 114,119 ****
}
static PyObject *riscos_stat(PyObject *self,PyObject *args)
! { char *path;
int ob,len;
bits t=0;
--- 114,157 ----
}
+ static char stat_result__doc__[] =
+ "stat_result: Result from stat or lstat.\n\n\
+ This object may be accessed either as a tuple of\n\
+ (mode,ino,dev,nlink,uid,gid,size,atime,mtime,ctime)\n\
+ or via the attributes st_mode, st_ino, st_dev, st_nlink, st_uid, and so on.\n\
+ \n\
+ RiscOS: The fields st_ftype, st_attrs, and st_obtype are also available.\n\
+ \n\
+ See os.stat for more information.\n";
+
+ static PyStructSequence_Field stat_result_fields[] = {
+ { "st_mode", "protection bits" },
+ { "st_ino", "inode" },
+ { "st_dev", "device" },
+ { "st_nlink", "number of hard links" },
+ { "st_uid", "user ID of owner" },
+ { "st_gid", "group ID of owner" },
+ { "st_size", "total size, in bytes" },
+ { "st_atime", "time of last access" },
+ { "st_mtime", "time of last modification" },
+ { "st_ctime", "time of last change" },
+ { "st_ftype", "file type" },
+ { "st_attrs", "attributes" },
+ { "st_obtype", "object type" }
+ { 0 }
+ };
+
+ static PyStructSequence_Desc stat_result_desc = {
+ "stat_result",
+ stat_result__doc__,
+ stat_result_fields,
+ 13
+ };
+
+ static PyTypeObject StatResultType;
+
static PyObject *riscos_stat(PyObject *self,PyObject *args)
! {
! PyObject *v;
! char *path;
int ob,len;
bits t=0;
***************
*** 131,149 ****
mode|=(at&7)<<6;
mode|=((at&112)*9)>>4;
! return Py_BuildValue("(lllllllllllll)",
! (long)mode,/*st_mode*/
! 0,/*st_ino*/
! 0,/*st_dev*/
! 0,/*st_nlink*/
! 0,/*st_uid*/
! 0,/*st_gid*/
! (long)len,/*st_size*/
! (long)t,/*st_atime*/
! (long)t,/*st_mtime*/
! (long)t,/*st_ctime*/
! (long)ft,/*file type*/
! (long)at,/*attributes*/
! (long)ob/*object type*/
! );
}
--- 169,200 ----
mode|=(at&7)<<6;
mode|=((at&112)*9)>>4;
!
! v = PyStructSequence_New(&StatResultType);
!
! PyStructSequence_SET_ITEM(v, 0,
! PyInt_FromLong((long) mode)); /*st_mode*/
! PyStructSequence_SET_ITEM(v, 1, PyInt_FromLong((long) 0)); /*st_ino*/
! PyStructSequence_SET_ITEM(v, 2, PyInt_FromLong((long) 0)); /*st_dev*/
! PyStructSequence_SET_ITEM(v, 3, PyInt_FromLong((long) 0)); /*st_nlink*/
! PyStructSequence_SET_ITEM(v, 4, PyInt_FromLong((long) 0)); /*st_uid*/
! PyStructSequence_SET_ITEM(v, 5, PyInt_FromLong((long) 0)); /*st_gid*/
! PyStructSequence_SET_ITEM(v, 6,
! PyInt_FromLong((long) len)); /*st_size*/
! PyStructSequence_SET_ITEM(v, 7, PyInt_FromLong((long) t)); /*st_atime*/
! PyStructSequence_SET_ITEM(v, 8, PyInt_FromLong((long) t)); /*st_mtime*/
! PyStructSequence_SET_ITEM(v, 9, PyInt_FromLong((long) t)); /*st_ctime*/
! PyStructSequence_SET_ITEM(v, 10,
! PyInt_FromLong((long) ft)); /*file type*/
! PyStructSequence_SET_ITEM(v, 11,
! PyInt_FromLong((long) at)); /*attributes*/
! PyStructSequence_SET_ITEM(v, 12,
! PyInt_FromLong((long) ot)); /*object type*/
!
! if (PyErr_Occurred()) {
! Py_DECREF(v);
! return NULL;
! }
!
! return v;
}
***************
*** 272,276 ****
initriscos()
{
! PyObject *m, *d;
m = Py_InitModule("riscos", riscos_methods);
--- 323,327 ----
initriscos()
{
! PyObject *m, *d, *stat_m;
m = Py_InitModule("riscos", riscos_methods);
***************
*** 281,283 ****
--- 332,337 ----
if (RiscosError == NULL || PyDict_SetItemString(d, "error", RiscosError) != 0)
Py_FatalError("can't define riscos.error");
+
+ PyStructSequence_InitType(&StatResultType, &stat_result_desc);
+ PyDict_SetItemString(d, "stat_result", (PyObject*) &StatResultType);
}