diff options
author | Guido van Rossum <guido@python.org> | 1993-01-04 09:09:59 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1993-01-04 09:09:59 (GMT) |
commit | a2b7f40513ba5d75a2063c3fabe47377cd8c0416 (patch) | |
tree | a49810320cbb0291ed16424b8d7ca980b5c2b1b1 /Modules | |
parent | 349f2b516b89c46f915a57029ed2bd33f85ff363 (diff) | |
download | cpython-a2b7f40513ba5d75a2063c3fabe47377cd8c0416.zip cpython-a2b7f40513ba5d75a2063c3fabe47377cd8c0416.tar.gz cpython-a2b7f40513ba5d75a2063c3fabe47377cd8c0416.tar.bz2 |
* Configure.py: use #!/usr/local/bin/python
* posixmodule.c: move extern function declarations to top
* listobject.c: cmp() arguments must be void* if __STDC__
* Makefile, allobjects.h, panelmodule.c, modsupport.c: get rid of
strdup() -- it is a portability risk
* Makefile: enclosed ranlib command in parentheses for Sequent Make
which aborts if the command is not found even if '-' is present
* timemodule.c: time() returns a floating point number, in microsecond
precision if BSD_TIME is defined.
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/config.c.in | 2 | ||||
-rw-r--r-- | Modules/posixmodule.c | 35 | ||||
-rw-r--r-- | Modules/timemodule.c | 18 |
3 files changed, 37 insertions, 18 deletions
diff --git a/Modules/config.c.in b/Modules/config.c.in index 6189c33..cfe82d7 100644 --- a/Modules/config.c.in +++ b/Modules/config.c.in @@ -45,7 +45,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #ifdef __DATE__ #define DATE __DATE__ #else -#define DATE ">= 10 Aug 1992" +#define DATE ">= 1 Jan 1993" #endif #include <stdio.h> diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c index a263f1b..e861d08 100644 --- a/Modules/posixmodule.c +++ b/Modules/posixmodule.c @@ -75,7 +75,24 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "modsupport.h" #include "ceval.h" +/* XXX Aren't these always declared in unistd.h? */ extern char *strerror PROTO((int)); +extern int chmod PROTO((const char *, mode_t)); +extern char *getcwd PROTO((char *, int)); /* XXX or size_t? */ +extern int mkdir PROTO((const char *, mode_t)); +extern int chdir PROTO((const char *)); +extern int link PROTO((const char *, const char *)); +extern int rename PROTO((const char *, const char *)); +extern int rmdir PROTO((const char *)); +extern int stat PROTO((const char *, struct stat *)); +extern int unlink PROTO((const char *)); +extern int pclose PROTO((FILE *)); +#ifdef NO_LSTAT +#define lstat stat +#else +extern int lstat PROTO((const char *, struct stat *)); +extern int symlink PROTO((const char *, const char *)); +#endif /* Return a dictionary corresponding to the POSIX environment table */ @@ -225,7 +242,6 @@ posix_chdir(self, args) object *self; object *args; { - extern int chdir PROTO((const char *)); return posix_1str(args, chdir); } @@ -234,7 +250,6 @@ posix_chmod(self, args) object *self; object *args; { - extern int chmod PROTO((const char *, mode_t)); return posix_strint(args, chmod); } @@ -245,7 +260,6 @@ posix_getcwd(self, args) { char buf[1026]; char *res; - extern char *getcwd PROTO((char *, int)); if (!getnoarg(args)) return NULL; BGN_SAVE @@ -262,7 +276,6 @@ posix_link(self, args) object *self; object *args; { - extern int link PROTO((const char *, const char *)); return posix_2str(args, link); } #endif /* !MSDOS */ @@ -342,7 +355,6 @@ posix_mkdir(self, args) object *self; object *args; { - extern int mkdir PROTO((const char *, mode_t)); return posix_strint(args, mkdir); } @@ -366,7 +378,6 @@ posix_rename(self, args) object *self; object *args; { - extern int rename PROTO((const char *, const char *)); return posix_2str(args, rename); } @@ -375,7 +386,6 @@ posix_rmdir(self, args) object *self; object *args; { - extern int rmdir PROTO((const char *)); return posix_1str(args, rmdir); } @@ -384,7 +394,6 @@ posix_stat(self, args) object *self; object *args; { - extern int stat PROTO((const char *, struct stat *)); return posix_do_stat(self, args, stat); } @@ -424,19 +433,19 @@ posix_unlink(self, args) object *self; object *args; { - extern int unlink PROTO((const char *)); return posix_1str(args, unlink); } #ifndef NO_UNAME #include <sys/utsname.h> +extern int uname PROTO((struct utsname *)); + static object * posix_uname(self, args) object *self; object *args; { - extern int uname PROTO((struct utsname *)); struct utsname u; object *v; int res; @@ -696,7 +705,6 @@ posix_popen(self, args) object *self; object *args; { - extern int pclose PROTO((FILE *)); char *name, *mode; FILE *fp; if (!getargs(args, "(ss)", &name, &mode)) @@ -759,10 +767,6 @@ posix_lstat(self, args) object *self; object *args; { -#ifdef NO_LSTAT -#define lstat stat -#endif - extern int lstat PROTO((const char *, struct stat *)); return posix_do_stat(self, args, lstat); } @@ -798,7 +802,6 @@ posix_symlink(self, args) err_setstr(PosixError, "symlink not implemented on this system"); return NULL; #else - extern int symlink PROTO((const char *, const char *)); return posix_2str(args, symlink); #endif } diff --git a/Modules/timemodule.c b/Modules/timemodule.c index 69a0c88..17dff19 100644 --- a/Modules/timemodule.c +++ b/Modules/timemodule.c @@ -33,6 +33,10 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include <signal.h> #include <setjmp.h> +#ifdef BSD_TIME +#define HAVE_GETTIMEOFDAY +#endif + #ifdef macintosh #define NO_UNISTD #endif @@ -79,6 +83,17 @@ time_time(self, args) object *self; object *args; { +#ifdef HAVE_GETTIMEOFDAY + struct timeval t; + struct timezone tz; + if (!getnoarg(args)) + return NULL; + if (gettimeofday(&t, &tz) != 0) { + err_errno(IOError); + return NULL; + } + return newfloatobject(t.tv_sec*1.0 + t.tv_usec*0.000001); +#else /* !HAVE_GETTIMEOFDAY */ time_t secs; if (!getnoarg(args)) return NULL; @@ -90,7 +105,8 @@ time_time(self, args) (((1970-1904)*365L + (1970-1904)/4) * 24 * 3600)) secs -= TIMEDIFF; #endif - return newintobject((long)secs); + return newfloatobject((double)secs); +#endif /* !HAVE_GETTIMEOFDAY */ } static jmp_buf sleep_intr; |