[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);
  }