2003-07-27 16:20:21 +00:00
|
|
|
|
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001, 2003 Free Software Foundation, Inc.
|
1996-07-25 22:56:11 +00:00
|
|
|
|
*
|
2003-04-05 19:15:35 +00:00
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
1996-07-25 22:56:11 +00:00
|
|
|
|
*
|
2003-04-05 19:15:35 +00:00
|
|
|
|
* This library 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
|
|
|
|
|
|
* Lesser General Public License for more details.
|
1996-07-25 22:56:11 +00:00
|
|
|
|
*
|
2003-04-05 19:15:35 +00:00
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
*/
|
1999-12-12 02:36:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2003-03-25 23:58:31 +00:00
|
|
|
|
#if HAVE_CONFIG_H
|
|
|
|
|
|
# include <config.h>
|
|
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-03-10 01:07:06 +00:00
|
|
|
|
/* Make GNU/Linux libc declare everything it has. */
|
|
|
|
|
|
#define _GNU_SOURCE
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#include <stdio.h>
|
* _scm.h: Removed #include <errno.h>.
* error.c, net_db.c, putenv.c, stime.c: Removed declaration of
errno variable (can be a macro on some systems, for example when
using linux libc with threads).
* error.c, filesys.c, gc.c, ioext.c, iselect.c, net_db.c, ports.c,
posix.c, print.c, putenv.c, scmsigs.c, script.c, simpos.c, smob.c,
socket.c, srcprop.c, stime.c, strop.c, unif.c, vports.c: Added
#include <errno.h> in these 20 out of 100 files.
2001-03-10 16:56:09 +00:00
|
|
|
|
#include <errno.h>
|
|
|
|
|
|
|
2000-04-21 14:16:44 +00:00
|
|
|
|
#include "libguile/_scm.h"
|
|
|
|
|
|
#include "libguile/fports.h"
|
|
|
|
|
|
#include "libguile/scmsigs.h"
|
|
|
|
|
|
#include "libguile/feature.h"
|
|
|
|
|
|
#include "libguile/strings.h"
|
|
|
|
|
|
#include "libguile/vectors.h"
|
2002-01-22 23:31:39 +00:00
|
|
|
|
#include "libguile/lang.h"
|
2000-04-21 14:16:44 +00:00
|
|
|
|
|
|
|
|
|
|
#include "libguile/validate.h"
|
|
|
|
|
|
#include "libguile/posix.h"
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
1996-08-02 23:26:33 +00:00
|
|
|
|
#ifdef HAVE_STRING_H
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#ifdef TIME_WITH_SYS_TIME
|
|
|
|
|
|
# include <sys/time.h>
|
|
|
|
|
|
# include <time.h>
|
|
|
|
|
|
#else
|
|
|
|
|
|
# if HAVE_SYS_TIME_H
|
|
|
|
|
|
# include <sys/time.h>
|
|
|
|
|
|
# else
|
|
|
|
|
|
# include <time.h>
|
|
|
|
|
|
# endif
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
|
|
#include <unistd.h>
|
1996-08-07 09:46:41 +00:00
|
|
|
|
#else
|
|
|
|
|
|
#ifndef ttyname
|
|
|
|
|
|
extern char *ttyname();
|
|
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
1996-11-10 00:14:45 +00:00
|
|
|
|
#ifdef LIBC_H_WITH_UNISTD_H
|
On NextStep, <utime.h> doesn't define struct utime, unless we
#define _POSIX_SOURCE before #including it.
* aclocal.m4 (GUILE_STRUCT_UTIMBUF): New test.
* acconfig.h: New comment text for above CPP symbol.
* configure.in: Call it.
* posix.c: #define _POSIX_SOURCE if it seems necessary.
* configure.in (AC_CHECK_HEADERS): Include sys/utime.h and utime.h
in the list.
* posix.c: Check HAVE_SYS_UTIME_H and HAVE_UTIME_H, instead of
testing for __EMX__.
* posix.c: #include <libc.h>, if it exists.
* posix.c: Cast the return result to GETGROUPS_T, not gid_t; we
don't even know if the latter exists.
* posix.c (s_sys_setpgid, s_sys_setsid, s_sys_ctermid,
s_sys_tcgetpgrp, s_sys_tcsetpgrp): Renamed from s_setpgid,
s_setsid, s_ctermid, s_tcgetpgrp, s_tcsetpgrp, for consistency.
* posix.c (R_OK, W_OK, X_OK, F_OK): #define these if the system's
header files don't.
(scm_init_posix): Use them when initializing the Scheme constants
of the same name.
1996-09-03 04:43:15 +00:00
|
|
|
|
#include <libc.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
1996-08-01 10:54:50 +00:00
|
|
|
|
#include <sys/types.h>
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#include <sys/stat.h>
|
|
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_PWD_H
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#include <pwd.h>
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef HAVE_IO_H
|
|
|
|
|
|
#include <io.h>
|
|
|
|
|
|
#endif
|
2002-07-10 19:40:43 +00:00
|
|
|
|
#ifdef HAVE_WINSOCK2_H
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#include <winsock2.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
|
/* Some defines for Windows here. */
|
2001-07-03 15:27:56 +00:00
|
|
|
|
# include <process.h>
|
2001-06-26 17:53:09 +00:00
|
|
|
|
# define pipe(fd) _pipe (fd, 256, O_BINARY)
|
|
|
|
|
|
#endif /* __MINGW32__ */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
#if HAVE_SYS_WAIT_H
|
|
|
|
|
|
# include <sys/wait.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
#ifndef WEXITSTATUS
|
|
|
|
|
|
# define WEXITSTATUS(stat_val) ((unsigned)(stat_val) >> 8)
|
|
|
|
|
|
#endif
|
|
|
|
|
|
#ifndef WIFEXITED
|
|
|
|
|
|
# define WIFEXITED(stat_val) (((stat_val) & 255) == 0)
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#include <signal.h>
|
|
|
|
|
|
|
|
|
|
|
|
extern char ** environ;
|
|
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_GRP_H
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#include <grp.h>
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef HAVE_SYS_UTSNAME_H
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#include <sys/utsname.h>
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SETLOCALE
|
|
|
|
|
|
#include <locale.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#if HAVE_LIBCRYPT && HAVE_CRYPT_H
|
|
|
|
|
|
# include <crypt.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
|
|
# include <sys/resource.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_SYS_FILE_H
|
|
|
|
|
|
# include <sys/file.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
On NextStep, <utime.h> doesn't define struct utime, unless we
#define _POSIX_SOURCE before #including it.
* aclocal.m4 (GUILE_STRUCT_UTIMBUF): New test.
* acconfig.h: New comment text for above CPP symbol.
* configure.in: Call it.
* posix.c: #define _POSIX_SOURCE if it seems necessary.
* configure.in (AC_CHECK_HEADERS): Include sys/utime.h and utime.h
in the list.
* posix.c: Check HAVE_SYS_UTIME_H and HAVE_UTIME_H, instead of
testing for __EMX__.
* posix.c: #include <libc.h>, if it exists.
* posix.c: Cast the return result to GETGROUPS_T, not gid_t; we
don't even know if the latter exists.
* posix.c (s_sys_setpgid, s_sys_setsid, s_sys_ctermid,
s_sys_tcgetpgrp, s_sys_tcsetpgrp): Renamed from s_setpgid,
s_setsid, s_ctermid, s_tcgetpgrp, s_tcsetpgrp, for consistency.
* posix.c (R_OK, W_OK, X_OK, F_OK): #define these if the system's
header files don't.
(scm_init_posix): Use them when initializing the Scheme constants
of the same name.
1996-09-03 04:43:15 +00:00
|
|
|
|
/* Some Unix systems don't define these. CPP hair is dangerous, but
|
|
|
|
|
|
this seems safe enough... */
|
|
|
|
|
|
#ifndef R_OK
|
|
|
|
|
|
#define R_OK 4
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef W_OK
|
|
|
|
|
|
#define W_OK 2
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef X_OK
|
|
|
|
|
|
#define X_OK 1
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef F_OK
|
|
|
|
|
|
#define F_OK 0
|
|
|
|
|
|
#endif
|
1996-09-04 06:34:02 +00:00
|
|
|
|
|
|
|
|
|
|
/* On NextStep, <utime.h> doesn't define struct utime, unless we
|
|
|
|
|
|
#define _POSIX_SOURCE before #including it. I think this is less
|
|
|
|
|
|
of a kludge than defining struct utimbuf ourselves. */
|
|
|
|
|
|
#ifdef UTIMBUF_NEEDS_POSIX
|
|
|
|
|
|
#define _POSIX_SOURCE
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_UTIME_H
|
|
|
|
|
|
#include <sys/utime.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_UTIME_H
|
|
|
|
|
|
#include <utime.h>
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/* Please don't add any more #includes or #defines here. The hack
|
|
|
|
|
|
above means that _POSIX_SOURCE may be #defined, which will
|
|
|
|
|
|
encourage header files to do strange things. */
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
1998-10-09 12:46:31 +00:00
|
|
|
|
SCM_SYMBOL (sym_read_pipe, "read pipe");
|
|
|
|
|
|
SCM_SYMBOL (sym_write_pipe, "write pipe");
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_pipe, "pipe", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return a newly created pipe: a pair of ports which are linked\n"
|
|
|
|
|
|
"together on the local machine. The @emph{car} is the input\n"
|
|
|
|
|
|
"port and the @emph{cdr} is the output port. Data written (and\n"
|
|
|
|
|
|
"flushed) to the output port can be read from the input port.\n"
|
|
|
|
|
|
"Pipes are commonly used for communication with a newly forked\n"
|
|
|
|
|
|
"child process. The need to flush the output port can be\n"
|
|
|
|
|
|
"avoided by making it unbuffered using @code{setvbuf}.\n"
|
|
|
|
|
|
"\n"
|
|
|
|
|
|
"Writes occur atomically provided the size of the data in bytes\n"
|
|
|
|
|
|
"is not greater than the value of @code{PIPE_BUF}. Note that\n"
|
|
|
|
|
|
"the output port is likely to block if too much data (typically\n"
|
|
|
|
|
|
"equal to @code{PIPE_BUF}) has been written but not yet read\n"
|
|
|
|
|
|
"from the input port.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_pipe
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int fd[2], rv;
|
|
|
|
|
|
SCM p_rd, p_wt;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
rv = pipe (fd);
|
|
|
|
|
|
if (rv)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
* ioext.c (scm_do_read_line): Rewritten to use memchr to find the
newline. A bit faster, and definitely hairier.
(scm_read_line): Count newlines here instead.
* strings.c (scm_take_str): New function.
(scm_take0str): Reimplement in terms of scm_take_str. * strings.h
(scm_take_str): New declaration. * ioext.c (scm_read_line): Use
scm_take_str, to avoid copying the string.
Add some simple-minded support for line buffered ports.
* ports.h (SCM_BUFLINE): New flag for ports.
* init.c (scm_init_standard_ports): Request line-buffering on
the standard output port.
* * ports.c (scm_mode_bits): Recognize 'l' as a request for line
buffering.
(scm_putc, scm_puts, scm_lfwrite): If the port is line-buffered,
and there's a newline to be written, flush the port.
* ports.c: (scm_lseek): clear buffers even if just reading current
position.
* fports.c (local_fclose): call local_fflush unconditionally.
(various): don't use the scm_must... memory procs.
* ports.h (scm_port): make read_pos a pointer to const.
strports.c: take care of rw_active and rw_randow.
fports.c: scm_fport_drain_input: removed. do it all in ports.c.
strports.c (scm_mkstrport): check that pos is reasonable.
ioext.c (scm_ftell, scm_fseek): use lseek.
(SCM_CLEAR_BUFFERS): macro deleted.
ioext.c (redirect_port: use ptob fflush, read_flush.
ports.h (scm_ptobfuns): add ftruncate.
ports.c (scm_newptob): set ftruncate.
adjust ptob tables.
* ports.c (scm_ftruncate): new procedure.
fports.c (local_ftrunate), strports.c (str_ftruncate): new procs.
strports.c (st_seek, st_grow_port): new procs.
fports.h (scm_port): change size types from int to off_t.
ports.c (scm_init_ports): initialise the seek symbols here
instead of in ioext.c.
strports.c (scm_call_with_output_string): start with an empty
string, so seek and ftruncate can be used.
* ports.h (scm_ptobfuns): add a read_flush procedure which is the
equivalent to fflush for the read buffer.
* ports.c (scm_newptob): set read_flush.
ports.c (void_port_ptob): set read_flush.
fports.c (local_read_flush): new proc. add to ptob.
strport.c (st_read_flush): likewise.
vport.c (sf_read_flush): likewise.
fports.h (struct scm_fport): remove random member. there's nothing
left but fdes. leaving it as a struct to allow for future changes.
fports.c: replace usage of scm_fport::random with scm_port::rw_random.
ports.c: (scm_putc, scm_puts, scm_lfwrite): call the read_flush
ptob proc if the read buffer is filled.
* ports.h (scm_port): add a rw_random member and replace
reading and writing members with rw_active member.
SCM_PORT_READ/SCM_PORT_WRITE: new values.
* ports.h (struct scm_port_table): add writing and reading members
to replace write_needs_seek: it isn't good enough for non-fports.
ports.c, ioext.c, fports.c: corresponding changes.
(struct scm_port_table): give it a typedef and rename to scm_port.
ports.c, fports.c, strports.c, vports.c, ioext.c, ports.h:
corresponding changes.
* ports.c (scm_newptob): bugfix: set seek member.
* * (scm_lseek): new procedure, using code from ioext.c:scm_fseek
and generalised to all port types.
* scmsigs.c (scm_init_scmsigs): set the SA_RESTART flag for all
signals (it was only being done for handlers installed from Scheme).
Otherwise (for example) SIGSTOP followed by SIGCONT on an interpreter
waiting for input caused an EINTR error from read.
* ports.h (struct scm_port_table): make all the char members
unsigned, so they convert to int without becoming negative if large.
* fports.c (scm_fdes_wait_for_input): forgot to check compilation
with threads enabled. rename this procedure to
fport_wait_for_input and take a port instead of a fdes.
use scm_fport_input_waiting_p instead of scm_fdes_waiting_p.
* readline.c (scm_readline): Applied a patch from Greg Harvey to
get readline support working again: use fdopen to get FILE objects.
* gc.c (scm_init_storage): install an atexit proc to flush the
ports.
(cleanup): the new proc. it sets a global variable which can be
checked by the ptob flush procs to avoid trying to throw
exceptions during exit. not very pleasant but it seems more reliable.
* fports.c (local_fflush): check terminating variable and if set
don't throw exception.
* CHECKME: that the atexit proc is installed if unexec used.
* throw.c (scm_handle_by_message): don't flush all ports here.
it still causes bus errors.
* fports.h (SCM_FPORT_CLEAR_BUFFERS): rename to SCM_CLEAR_BUFFERS
and move to ioext.c.
* fports.c (scm_fdes_waiting_p): merged into fport_input_waiting_p.
* ports.c (scm_char_ready_p): check the port buffer and call the
ptob entry if needed.
* ports.h (scm_ptobfuns): input_waiting_p added. change all the
ptob initialisers. use it in char-ready
* ioext.c (scm_do_read_line): moved from ports.c. make it static.
* vports.c (sfflush): modified to write a char (since softports
currently use shortbuf.)
* fports.c (scm_standard_stream_to_port): moved to init.c and
made static.
* init.c (scm_init_standard_ports): make stdout and stderr
unbuffered if connected to a terminal. with stdio they
were line-buffered by default.
* ports.h (scm_ptobfuns): change fflush return to void.
change flush proc definitions.
* strports.c (scm_call_with_output_string): get size from
buffer instead of port stream.
(scm_strprint_obj): likewise.
(st_flush): new proc.
* ports.h (struct scm_port_table): added write_end member,
as an optimisation. set it where write_buf_size is set.
* ports.h (struct scm_port_table): change stream from void *
back to SCM. SCM presumably must be large enough to hold a
pointer (and probably vice versa but who knows.)
(SCM_SSTREAM): deleted. change users back to SCM_STREAM.
(scm_puts): rewritten
* fports.c (local_ffwrite, local_fputs): removed.
* strports.c (stputc, stputs, stwrite): dyked out (FIXME)
* vports.c (sfputc, sfputs, sfwrite) likewise.
* ports.c (write_void_port, puts_void_port): removed.
(putc_void_port, getc_void_port, fgets_void_port): likewise.
* ports.c (scm_lfwrite): rewritten using fport.c version.
* fports.c (local_fputc): deleted.
* ports.c (scm_add_to_port_table): initialise write_needs_seek.
* ports.h (scm_ptobfuns): add seek function pointer.
* fports.c: set it to local_seek, new procedure.
* fports.h (SCM_MAYBE_DRAIN_INPUT): moved to ports.c.
use ptob for seek. take ptob instead of fport arg.
* ports.h (struct scm_port_table): new member write_needs_seek,
replaces reading member in fport struct.
* vports.c (sfgetc): store the getted char into the buffer.
rename to sf_fill_buffer and install it for fill-buffer in ptob.
the Scheme interface is still a procedure that gets a char.
(scm_make_soft_port): set up the port buffer (shortbuf).
* fports.c (local_fgetc, local_fgets): deleted.
* strports.c (stgetc): likewise.
* ports.c: scm_generic_fgets: likewise.
* ports.h (scm_ptobfuns): add fill_buffer.
* ports.c (scm_newptob): assign it.
* strports.c (scm_mkstrport): set up the buffer.
put just the string into the stream, not cons (pos stream).
(stfill_buffer): new proc.
* ports.h: fport buffer moved into port table: to be
used for all port types.
* throw.c (scm_handle_by_message): flush ports at exit.
* socket.c (scm_sock_fd_to_port): use scm_fdes_to_port.
(scm_getsockopt, scm_setsockopt, scm_shutdown, scm_connect,
scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_recv, scm_send, scm_recvfrom,
scm_sendto,
use SCM_FPORT_FDES. use SCM_OPFPORTP not SCM_FPORTP.
* posix.c (scm_getgroups): use SCM_ALLOW/DEFER_INTS.
(scm_ttyname): use SCM_FPORT_FDES.
(scm_tcgetpgrp, scm_tcsetpgrp): likewise.
* ioext.c (scm_isatty_p): use SCM_FPORT_FDES.
(scm_fdes_to_ports): modified.
(scm_fdopen): use scm_fdes_to_port.
* ports.c (scm_init_ports): don't try to flush ports using
atexit(). it's too late, errors will cause SEGV.
* fports.c (scm_fport_buffer_add): new procedure.
* fports.h (SCM_FDES_RANDOM_P): new macro. use it in
scm_fdes_to_port and scm_redirect_port.
* ioext.c (scm_redirect_port): use setvbuf to set buffers in the
new port. reset fp->random.
* fports.c (scm_fdes_to_port), ports.c (scm_void_port),
filesys.c (scm_opendir):
restore defer interrupts while the port is constructed.
* (scm_setvbuf): if mode is _IOFBF and size is not supplied,
derive buffer size from fdes or use a default.
(scm_fdes_to_port): use setvbuf instead of creating the buffers
directly.
vports.c (various places): use SCM_SSTREAM.
strports.c: likewise.
* gdbint.c: likewise.
* ports.h (SCM_SSTREAM): new macro.
* fports.c (scm_input_waiting_p): use scm_return_first, since port
may be removed from the stack by the tail call to scm_fdes_waiting_p.
* fports.h (SCM_CLEAR_BUFFERS): new macro.
* ports.c (scm_force_output): call scm_fflush.
* print.c (scm_newline): don't check errno for EPIPE (it wouldn't
* reach this point.) don't flush port (if scm_cur_outp).
* fports.h (SCM_FPORT_FDES): new macro.
* vports.c (sfflush): don't need to set errno.
* ports.c: install scm_flush_all_ports to be run on exit.
ports.c fports.c ioext.c posix.c socket.c net_db.c filesys.c:
removed all uses of SCM_DEFER/ALLOW ints for now. they were mainly
just protecting errno. some may need to be put back.
* scmsigs.c (take_signal): save and restore errno while this
proc runs.
*fports.c (print_pipe_port, local_pclose, scm_pipob): deleted.
* open-pipe, close-pipe are emulated in (ice-9 popen)
ports.c (scm_ports_prehistory): don't init scm_pipob.
ports.h (scm_tc16_pipe): deleted.
posix.c (scm_open_pipe, scm_close_pipe): deleted.
* ioext.c (scm_primitive_move_to_fdes): use fport.
* fport.c (scm_fport_fill_buffer): flush write buffer if needed.
change arg type from scm_fport to SCM port.
fport.h (SCM_SETFDES): removed.
(SCM_MAYBE_DRAIN_INPUT): new macro.
* ioext.c (scm_dup_to_fdes): use SCM_FSTREAM.
(scm_ftell): always use lseek and account for the buffer.
(scm_fileno): use fport buffer.
(scm_fseek): clear fport buffers. always use lseek.
* posix.c (scm_pipe): use fport buffer.
* unif.c: include fports.h instead of genio.h.
* fports.c (scm_fdes_wait_for_input, scm_fport_fill_buffer): new
procedures.
(local_fgetc): use them.
(local_ffwrite): use buffer.
(local_fgets): use buffer.
(scm_setbuf0): deleted.
(scm_setvbuf): set the buffer.
(scm_setfileno): deleted.
(scm_evict_ports): set fdes directly.
* (scm_freopen): deleted. doesn't seem useful in Guile.
(scm_stdio_to_port): deleted.
fports.h (struct scm_fport): add shortbuf member to avoid separate
code for unbuffered ports.
(SCM_FPORTP, SCM_OPFPORTP, SCM_OPINFPORTP, SCM_OPOUTFPORTP): moved
from ports.h.
* genio.c, genio.h: move contents into ports.c, ports.h. The
division wasn't useful.
* fports.c, fports.h (scm_fport_drain_input): new procedure.
* ports.c (scm_drain_input): call scm_fport_drain_input.
* scm_fdes_waiting_p: new procedure.
* fports.c (scm_fdes_to_port): allocate read and/or write buffers.
(scm_input_waiting_p): check the buffer.
(local_fgetc, local_fflush, local_fputc): likewise.
* fports.h (scm_fport): read/write_buf,_pos,_buf_end,,_buf_size:
new members.
* init.c (scm_init_standard_ports): pass fdes instead of FILE *.
* * ports.c (scm_drain_input): new procedure.
ports.h: prototype.
* fports.c (FPORT_READ_SAFE, FPORT_WRITE_SAFE, FPORT_ALL_OKAY,
pre_read, pre_write): removed.
(local_fputc, local_fputs, local_ffwrite): use write, not stdio.
(scm_standard_stream_to_port): change first arg from FILE * to
int fdes.
(local_fflush): flush fdes, not FILE *.
* fports.h (SCM_NOFTELL): removed.
* genio.c, ports.c: don't include filesys.h.
* genio.c (scm_getc): don't use scm_internal_select if FPORT.
do it in fports.c:local_fgetc.
* genio.c: don't use SCM_SYSCALL when calling ptob procedures.
do it where it's needed in the port smobs.
* filesys.c (scm_input_waiting_p): moved to fports.c, stdio
buffer support removed. take SCM arg, not FILE *.
* filesys.h: prototype moved too.
* fports.c (scm_fdes_to_port): new procedure.
(local_fgetc): use read not fgetc.
(local_fclose): use close, not fclose.
(local_fgets): use read, not fgets
* fports.h: prototype for scm_fdes_to_port.
* fports.h (scm_fport): new struct.
* fports.c (scm_open_file): use open, not fopen.
#include fcntl.h
* ports.h (struct scm_port_table): change stream from SCM to void *.
* ports.c (scm_add_to_port_table): check for memory allocation error.
(scm_prinport): remove MSDOS hair.
(scm_void_port): set stream to 0 instead of SCM_BOOL_F.
(scm_close_port): don't throw errors: do it in fports.c.
1999-06-09 12:19:58 +00:00
|
|
|
|
|
|
|
|
|
|
p_rd = scm_fdes_to_port (fd[0], "r", sym_read_pipe);
|
|
|
|
|
|
p_wt = scm_fdes_to_port (fd[1], "w", sym_write_pipe);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
return scm_cons (p_rd, p_wt);
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#ifdef HAVE_GETGROUPS
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getgroups, "getgroups", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return a vector of integers representing the current\n"
|
2002-03-15 10:37:40 +00:00
|
|
|
|
"supplementary group IDs.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getgroups
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM result;
|
2000-11-01 17:55:41 +00:00
|
|
|
|
int ngroups;
|
* validate.h
(SCM_NUM2{SIZE,PTRDIFF,SHORT,USHORT,BITS,UBITS,INT,UINT}[_DEF]):
new macros.
* unif.h: type renaming:
scm_array -> scm_array_t
scm_array_dim -> scm_array_dim_t
the old names are deprecated, all in-Guile uses changed.
* tags.h (scm_ubits_t): new typedef, representing unsigned
scm_bits_t.
* stacks.h: type renaming:
scm_info_frame -> scm_info_frame_t
scm_stack -> scm_stack_t
the old names are deprecated, all in-Guile uses changed.
* srcprop.h: type renaming:
scm_srcprops -> scm_srcprops_t
scm_srcprops_chunk -> scm_srcprops_chunk_t
the old names are deprecated, all in-Guile uses changed.
* gsubr.c, procs.c, print.c, ports.c, read.c, rdelim.c, ramap.c,
rw.c, smob.c, sort.c, srcprop.c, stacks.c, strings.c, strop.c,
strorder.c, strports.c, struct.c, symbols.c, unif.c, values.c,
vectors.c, vports.c, weaks.c:
various int/size_t -> size_t/scm_bits_t changes.
* random.h: type renaming:
scm_rstate -> scm_rstate_t
scm_rng -> scm_rng_t
scm_i_rstate -> scm_i_rstate_t
the old names are deprecated, all in-Guile uses changed.
* procs.h: type renaming:
scm_subr_entry -> scm_subr_entry_t
the old name is deprecated, all in-Guile uses changed.
* options.h (scm_option_t.val): unsigned long -> scm_bits_t.
type renaming:
scm_option -> scm_option_t
the old name is deprecated, all in-Guile uses changed.
* objects.c: various long -> scm_bits_t changes.
(scm_i_make_class_object): flags: unsigned long -> scm_ubits_t
* numbers.h (SCM_FIXNUM_BIT): deprecated, renamed to
SCM_I_FIXNUM_BIT.
* num2integral.i.c: new file, multiply included by numbers.c, used
to "templatize" the various integral <-> num conversion routines.
* numbers.c (scm_mkbig, scm_big2num, scm_adjbig, scm_normbig,
scm_copybig, scm_2ulong2big, scm_dbl2big, scm_big2dbl):
deprecated.
(scm_i_mkbig, scm_i_big2inum, scm_i_adjbig, scm_i_normbig,
scm_i_copybig, scm_i_short2big, scm_i_ushort2big, scm_i_int2big,
scm_i_uint2big, scm_i_long2big, scm_i_ulong2big, scm_i_bits2big,
scm_i_ubits2big, scm_i_size2big, scm_i_ptrdiff2big,
scm_i_long_long2big, scm_i_ulong_long2big, scm_i_dbl2big,
scm_i_big2dbl, scm_short2num, scm_ushort2num, scm_int2num,
scm_uint2num, scm_bits2num, scm_ubits2num, scm_size2num,
scm_ptrdiff2num, scm_num2short, scm_num2ushort, scm_num2int,
scm_num2uint, scm_num2bits, scm_num2ubits, scm_num2ptrdiff,
scm_num2size): new functions.
* modules.c (scm_module_reverse_lookup): i, n: int -> scm_bits_t.x
* load.c: change int -> size_t in various places (where the
variable is used to store a string length).
(search-path): call scm_done_free, not scm_done_malloc.
* list.c (scm_ilength): return a scm_bits_t, not long.
some other {int,long} -> scm_bits_t changes.
* hashtab.c: various [u]int -> scm_bits_t changes.
scm_ihashx_closure -> scm_ihashx_closure_t (and made a typedef).
(scm_ihashx): n: uint -> scm_bits_t
use scm_bits2num instead of scm_ulong2num.
* gsubr.c: various int -> scm_bits_t changes.
* gh_data.c (gh_scm2double): no loss of precision any more.
* gh.h (gh_str2scm): len: int -> size_t
(gh_{get,set}_substr): start: int -> scm_bits_t,
len: int -> size_t
(gh_<num>2scm): n: int -> scm_bits_t
(gh_*vector_length): return scm_[u]size_t, not unsigned long.
(gh_length): return scm_bits_t, not unsigned long.
* fports.h: type renaming:
scm_fport -> scm_fport_t
the old name is deprecated, all in-Guile uses changed.
* fports.c (fport_fill_input): count: int -> scm_bits_t
(fport_flush): init_size, remaining, count: int -> scm_bits_t
* debug.h (scm_lookup_cstr, scm_lookup_soft, scm_evstr): removed
those prototypes, as the functions they prototype don't exist.
* fports.c (default_buffer_size): int -> size_t
(scm_fport_buffer_add): read_size, write_size: int -> scm_bits_t
default_size: int -> size_t
(scm_setvbuf): csize: int -> scm_bits_t
* fluids.c (n_fluids): int -> scm_bits_t
(grow_fluids): old_length, i: int -> scm_bits_t
(next_fluid_num, scm_fluid_ref, scm_fluid_set_x): n: int ->
scm_bits_t
(scm_c_with_fluids): flen, vlen: int -> scm_bits_t
* filesys.c (s_scm_open_fdes): changed calls to SCM_NUM2LONG to
the new and shiny SCM_NUM2INT.
* extensions.c: extension -> extension_t (and made a typedef).
* eval.h (SCM_IFRAME): cast to scm_bits_t, not int. just so
there are no nasty surprises if/when the various deeply magic tag
bits move somewhere else.
* eval.c: changed the locals used to store results of SCM_IFRAME,
scm_ilength and such to be of type scm_bits_t (and not int/long).
(iqq): depth, edepth: int -> scm_bits_t
(scm_eval_stack): int -> scm_bits_t
(SCM_CEVAL): various vars are not scm_bits_t instead of int.
(check_map_args, scm_map, scm_for_each): len: long -> scm_bits_t
i: int -> scm_bits_t
* environments.c: changed the many calls to scm_ulong2num to
scm_ubits2num.
(import_environment_fold): proc_as_ul: ulong -> scm_ubits_t
* dynwind.c (scm_dowinds): delta: long -> scm_bits_t
* debug.h: type renaming:
scm_debug_info -> scm_debug_info_t
scm_debug_frame -> scm_debug_frame_t
the old names are deprecated, all in-Guile uses changed.
(scm_debug_eframe_size): int -> scm_bits_t
* debug.c (scm_init_debug): use scm_c_define instead of the
deprecated scm_define.
* continuations.h: type renaming:
scm_contregs -> scm_contregs_t
the old name is deprecated, all in-Guile uses changed.
(scm_contregs_t.num_stack_items): size_t -> scm_bits_t
(scm_contregs_t.num_stack_items): ulong -> scm_ubits_t
* continuations.c (scm_make_continuation): change the type of
stack_size form long to scm_bits_t.
* ports.h: type renaming:
scm_port_rw_active -> scm_port_rw_active_t (and made a typedef)
scm_port -> scm_port_t
scm_ptob_descriptor -> scm_ptob_descriptor_t
the old names are deprecated, all in-Guile uses changed.
(scm_port_t.entry): int -> scm_bits_t.
(scm_port_t.line_number): int -> long.
(scm_port_t.putback_buf_size): int -> size_t.
* __scm.h (long_long, ulong_long): deprecated (they pollute the
global namespace and have little value besides that).
(SCM_BITS_LENGTH): new, is the bit size of scm_bits_t (i.e. of an
SCM handle).
(ifdef spaghetti): include sys/types.h and sys/stdtypes.h, if they
exist (for size_t & ptrdiff_t)
(scm_sizet): deprecated.
* Makefile.am (noinst_HEADERS): add num2integral.i.c
2001-05-24 00:50:51 +00:00
|
|
|
|
size_t size;
|
2000-11-01 17:55:41 +00:00
|
|
|
|
GETGROUPS_T *groups;
|
|
|
|
|
|
|
|
|
|
|
|
ngroups = getgroups (0, NULL);
|
|
|
|
|
|
if (ngroups <= 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
2000-11-01 17:55:41 +00:00
|
|
|
|
|
|
|
|
|
|
size = ngroups * sizeof (GETGROUPS_T);
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
groups = scm_malloc (size);
|
2000-11-01 17:55:41 +00:00
|
|
|
|
getgroups (ngroups, groups);
|
|
|
|
|
|
|
2003-07-27 16:20:21 +00:00
|
|
|
|
result = scm_c_make_vector (ngroups, SCM_BOOL_F);
|
|
|
|
|
|
while (--ngroups >= 0)
|
|
|
|
|
|
SCM_VECTOR_SET (result, ngroups, scm_ulong2num (groups[ngroups]));
|
2000-11-01 17:55:41 +00:00
|
|
|
|
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
free (groups);
|
2002-07-21 17:46:23 +00:00
|
|
|
|
return result;
|
1999-12-12 02:36:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2003-07-27 16:20:21 +00:00
|
|
|
|
#ifdef HAVE_SETGROUPS
|
|
|
|
|
|
SCM_DEFINE (scm_setgroups, "setgroups", 1, 0, 0,
|
|
|
|
|
|
(SCM group_vec),
|
|
|
|
|
|
"Set the supplementary group IDs to those found in the vector argument.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_setgroups
|
|
|
|
|
|
{
|
|
|
|
|
|
size_t ngroups;
|
|
|
|
|
|
size_t size;
|
|
|
|
|
|
size_t i;
|
|
|
|
|
|
int result;
|
|
|
|
|
|
int save_errno;
|
|
|
|
|
|
GETGROUPS_T *groups;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_VECTOR (SCM_ARG1, group_vec);
|
|
|
|
|
|
|
|
|
|
|
|
ngroups = SCM_VECTOR_LENGTH (group_vec);
|
|
|
|
|
|
|
|
|
|
|
|
/* validate before allocating, so we don't have to worry about leaks */
|
|
|
|
|
|
for (i = 0; i < ngroups; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
unsigned long ulong_gid;
|
|
|
|
|
|
GETGROUPS_T gid;
|
|
|
|
|
|
SCM_VALIDATE_ULONG_COPY (1, SCM_VECTOR_REF (group_vec, i), ulong_gid);
|
|
|
|
|
|
gid = ulong_gid;
|
|
|
|
|
|
if (gid != ulong_gid)
|
|
|
|
|
|
SCM_OUT_OF_RANGE (1, SCM_VECTOR_REF (group_vec, i));
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
size = ngroups * sizeof (GETGROUPS_T);
|
|
|
|
|
|
/* XXX - if (size / sizeof (GETGROUPS_T) != ngroups) out-of-range */
|
|
|
|
|
|
groups = scm_malloc (size);
|
|
|
|
|
|
for(i = 0; i < ngroups; i++)
|
|
|
|
|
|
groups [i] = SCM_NUM2ULONG (1, SCM_VECTOR_REF (group_vec, i));
|
|
|
|
|
|
|
|
|
|
|
|
result = setgroups (ngroups, groups);
|
|
|
|
|
|
save_errno = errno; /* don't let free() touch errno */
|
|
|
|
|
|
free (groups);
|
|
|
|
|
|
errno = save_errno;
|
|
|
|
|
|
if (result < 0)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_GETPWENT
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getpwuid, "getpw", 0, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM user),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Look up an entry in the user database. @var{obj} can be an integer,\n"
|
|
|
|
|
|
"a string, or omitted, giving the behaviour of getpwuid, getpwnam\n"
|
|
|
|
|
|
"or getpwent respectively.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getpwuid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
struct passwd *entry;
|
|
|
|
|
|
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM result = scm_c_make_vector (7, SCM_UNSPECIFIED);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (SCM_UNBNDP (user) || SCM_FALSEP (user))
|
|
|
|
|
|
{
|
|
|
|
|
|
SCM_SYSCALL (entry = getpwent ());
|
1997-05-16 08:06:17 +00:00
|
|
|
|
if (! entry)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
else if (SCM_INUMP (user))
|
|
|
|
|
|
{
|
|
|
|
|
|
entry = getpwuid (SCM_INUM (user));
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, user);
|
|
|
|
|
|
entry = getpwnam (SCM_STRING_CHARS (user));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
if (!entry)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_MISC_ERROR ("entry not found", SCM_EOL);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 0, scm_makfrom0str (entry->pw_name));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 1, scm_makfrom0str (entry->pw_passwd));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 2, scm_ulong2num ((unsigned long) entry->pw_uid));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 3, scm_ulong2num ((unsigned long) entry->pw_gid));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 4, scm_makfrom0str (entry->pw_gecos));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (!entry->pw_dir)
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 5, scm_makfrom0str (""));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
else
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 5, scm_makfrom0str (entry->pw_dir));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (!entry->pw_shell)
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 6, scm_makfrom0str (""));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
else
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 6, scm_makfrom0str (entry->pw_shell));
|
|
|
|
|
|
return result;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_GETPWENT */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#ifdef HAVE_SETPWENT
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setpwent, "setpw", 0, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM arg),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If called with a true argument, initialize or reset the password data\n"
|
|
|
|
|
|
"stream. Otherwise, close the stream. The @code{setpwent} and\n"
|
|
|
|
|
|
"@code{endpwent} procedures are implemented on top of this.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setpwent
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
if (SCM_UNBNDP (arg) || SCM_FALSEP (arg))
|
|
|
|
|
|
endpwent ();
|
|
|
|
|
|
else
|
|
|
|
|
|
setpwent ();
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_GETGRENT
|
1996-07-25 22:56:11 +00:00
|
|
|
|
/* Combines getgrgid and getgrnam. */
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getgrgid, "getgr", 0, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM name),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Look up an entry in the group database. @var{obj} can be an integer,\n"
|
|
|
|
|
|
"a string, or omitted, giving the behaviour of getgrgid, getgrnam\n"
|
|
|
|
|
|
"or getgrent respectively.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getgrgid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
struct group *entry;
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM result = scm_c_make_vector (4, SCM_UNSPECIFIED);
|
2002-07-20 14:08:34 +00:00
|
|
|
|
|
2000-04-04 12:13:41 +00:00
|
|
|
|
if (SCM_UNBNDP (name) || SCM_FALSEP (name))
|
1997-05-16 08:06:17 +00:00
|
|
|
|
{
|
|
|
|
|
|
SCM_SYSCALL (entry = getgrent ());
|
|
|
|
|
|
if (! entry)
|
|
|
|
|
|
{
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
1996-07-25 22:56:11 +00:00
|
|
|
|
else if (SCM_INUMP (name))
|
|
|
|
|
|
SCM_SYSCALL (entry = getgrgid (SCM_INUM (name)));
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, name);
|
|
|
|
|
|
SCM_SYSCALL (entry = getgrnam (SCM_STRING_CHARS (name)));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
if (!entry)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 0, scm_makfrom0str (entry->gr_name));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 1, scm_makfrom0str (entry->gr_passwd));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 2, scm_ulong2num ((unsigned long) entry->gr_gid));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 3, scm_makfromstrs (-1, entry->gr_mem));
|
|
|
|
|
|
return result;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setgrent, "setgr", 0, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM arg),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If called with a true argument, initialize or reset the group data\n"
|
|
|
|
|
|
"stream. Otherwise, close the stream. The @code{setgrent} and\n"
|
|
|
|
|
|
"@code{endgrent} procedures are implemented on top of this.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setgrent
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
if (SCM_UNBNDP (arg) || SCM_FALSEP (arg))
|
|
|
|
|
|
endgrent ();
|
|
|
|
|
|
else
|
|
|
|
|
|
setgrent ();
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_GETGRENT */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_kill, "kill", 2, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM pid, SCM sig),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Sends a signal to the specified process or group of processes.\n\n"
|
|
|
|
|
|
"@var{pid} specifies the processes to which the signal is sent:\n\n"
|
|
|
|
|
|
"@table @r\n"
|
|
|
|
|
|
"@item @var{pid} greater than 0\n"
|
|
|
|
|
|
"The process whose identifier is @var{pid}.\n"
|
|
|
|
|
|
"@item @var{pid} equal to 0\n"
|
|
|
|
|
|
"All processes in the current process group.\n"
|
|
|
|
|
|
"@item @var{pid} less than -1\n"
|
|
|
|
|
|
"The process group whose identifier is -@var{pid}\n"
|
|
|
|
|
|
"@item @var{pid} equal to -1\n"
|
|
|
|
|
|
"If the process is privileged, all processes except for some special\n"
|
|
|
|
|
|
"system processes. Otherwise, all processes with the current effective\n"
|
|
|
|
|
|
"user ID.\n"
|
|
|
|
|
|
"@end table\n\n"
|
|
|
|
|
|
"@var{sig} should be specified using a variable corresponding to\n"
|
|
|
|
|
|
"the Unix symbolic name, e.g.,\n\n"
|
|
|
|
|
|
"@defvar SIGHUP\n"
|
|
|
|
|
|
"Hang-up signal.\n"
|
|
|
|
|
|
"@end defvar\n\n"
|
|
|
|
|
|
"@defvar SIGINT\n"
|
|
|
|
|
|
"Interrupt signal.\n"
|
|
|
|
|
|
"@end defvar")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_kill
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, pid);
|
|
|
|
|
|
SCM_VALIDATE_INUM (2, sig);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
/* Signal values are interned in scm_init_posix(). */
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_KILL
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (kill ((int) SCM_INUM (pid), (int) SCM_INUM (sig)) != 0)
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#else
|
|
|
|
|
|
if ((int) SCM_INUM (pid) == getpid ())
|
|
|
|
|
|
if (raise ((int) SCM_INUM (sig)) != 0)
|
|
|
|
|
|
#endif
|
|
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
1999-12-28 21:50:52 +00:00
|
|
|
|
#ifdef HAVE_WAITPID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_waitpid, "waitpid", 1, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM pid, SCM options),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"This procedure collects status information from a child process which\n"
|
|
|
|
|
|
"has terminated or (optionally) stopped. Normally it will\n"
|
|
|
|
|
|
"suspend the calling process until this can be done. If more than one\n"
|
|
|
|
|
|
"child process is eligible then one will be chosen by the operating system.\n\n"
|
|
|
|
|
|
"The value of @var{pid} determines the behaviour:\n\n"
|
|
|
|
|
|
"@table @r\n"
|
|
|
|
|
|
"@item @var{pid} greater than 0\n"
|
|
|
|
|
|
"Request status information from the specified child process.\n"
|
|
|
|
|
|
"@item @var{pid} equal to -1 or WAIT_ANY\n"
|
|
|
|
|
|
"Request status information for any child process.\n"
|
|
|
|
|
|
"@item @var{pid} equal to 0 or WAIT_MYPGRP\n"
|
|
|
|
|
|
"Request status information for any child process in the current process\n"
|
|
|
|
|
|
"group.\n"
|
|
|
|
|
|
"@item @var{pid} less than -1\n"
|
|
|
|
|
|
"Request status information for any child process whose process group ID\n"
|
|
|
|
|
|
"is -@var{PID}.\n"
|
|
|
|
|
|
"@end table\n\n"
|
|
|
|
|
|
"The @var{options} argument, if supplied, should be the bitwise OR of the\n"
|
|
|
|
|
|
"values of zero or more of the following variables:\n\n"
|
|
|
|
|
|
"@defvar WNOHANG\n"
|
|
|
|
|
|
"Return immediately even if there are no child processes to be collected.\n"
|
|
|
|
|
|
"@end defvar\n\n"
|
|
|
|
|
|
"@defvar WUNTRACED\n"
|
|
|
|
|
|
"Report status information for stopped processes as well as terminated\n"
|
|
|
|
|
|
"processes.\n"
|
|
|
|
|
|
"@end defvar\n\n"
|
|
|
|
|
|
"The return value is a pair containing:\n\n"
|
|
|
|
|
|
"@enumerate\n"
|
|
|
|
|
|
"@item\n"
|
|
|
|
|
|
"The process ID of the child process, or 0 if @code{WNOHANG} was\n"
|
|
|
|
|
|
"specified and no process was collected.\n"
|
|
|
|
|
|
"@item\n"
|
|
|
|
|
|
"The integer status value.\n"
|
|
|
|
|
|
"@end enumerate")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_waitpid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int i;
|
|
|
|
|
|
int status;
|
|
|
|
|
|
int ioptions;
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, pid);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (SCM_UNBNDP (options))
|
|
|
|
|
|
ioptions = 0;
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (2, options);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
/* Flags are interned in scm_init_posix. */
|
|
|
|
|
|
ioptions = SCM_INUM (options);
|
|
|
|
|
|
}
|
|
|
|
|
|
SCM_SYSCALL (i = waitpid (SCM_INUM (pid), &status, ioptions));
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (i == -1)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return scm_cons (SCM_MAKINUM (0L + i), SCM_MAKINUM (0L + status));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1999-12-28 21:50:52 +00:00
|
|
|
|
#endif /* HAVE_WAITPID */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifndef __MINGW32__
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_status_exit_val, "status:exit-val", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM status),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return the exit status value, as would be set if a process\n"
|
|
|
|
|
|
"ended normally through a call to @code{exit} or @code{_exit},\n"
|
|
|
|
|
|
"if any, otherwise @code{#f}.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_status_exit_val
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
{
|
1997-04-12 00:39:56 +00:00
|
|
|
|
int lstatus;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, status);
|
1997-04-12 00:39:56 +00:00
|
|
|
|
|
|
|
|
|
|
/* On Ultrix, the WIF... macros assume their argument is an lvalue;
|
|
|
|
|
|
go figure. SCM_INUM does not yield an lvalue. */
|
|
|
|
|
|
lstatus = SCM_INUM (status);
|
|
|
|
|
|
if (WIFEXITED (lstatus))
|
|
|
|
|
|
return (SCM_MAKINUM (WEXITSTATUS (lstatus)));
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
else
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1997-04-12 00:39:56 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_status_term_sig, "status:term-sig", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM status),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return the signal number which terminated the process, if any,\n"
|
|
|
|
|
|
"otherwise @code{#f}.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_status_term_sig
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
{
|
1997-04-12 00:39:56 +00:00
|
|
|
|
int lstatus;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, status);
|
1997-04-12 00:39:56 +00:00
|
|
|
|
|
|
|
|
|
|
lstatus = SCM_INUM (status);
|
|
|
|
|
|
if (WIFSIGNALED (lstatus))
|
|
|
|
|
|
return SCM_MAKINUM (WTERMSIG (lstatus));
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
else
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_status_stop_sig, "status:stop-sig", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM status),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return the signal number which stopped the process, if any,\n"
|
|
|
|
|
|
"otherwise @code{#f}.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_status_stop_sig
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
{
|
1997-04-12 00:39:56 +00:00
|
|
|
|
int lstatus;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, status);
|
1997-04-12 00:39:56 +00:00
|
|
|
|
|
|
|
|
|
|
lstatus = SCM_INUM (status);
|
|
|
|
|
|
if (WIFSTOPPED (lstatus))
|
|
|
|
|
|
return SCM_MAKINUM (WSTOPSIG (lstatus));
|
* ioext.c (scm_setfileno): throw a runtime error if SET_FILE_FD_FIELD
wan't defined. Don't include fd.h.
* Previously fd.h was regenerated whenever configure was run,
forcing a couple of files to be recompiled.
* fd.h.in: deleted, SET_FILE_FD_FIELD moved to ioext.c.
* configure.in: AC_DEFINE FD_SETTER instead of HAVE_FD_SETTER.
Check for _fileno as well as _file.
Don't output fd.h.
* ioext.c: don't fd.h.
* acconfig.h: remove duplicate HAVE_FD_SETTER and change the
other to FD_SETTER.
* Change the stratigy for getting information about errno
(and now signal number) values, e.g., ENOSYS, SIGKILL. Instead of
generating lists of symbols during the build process, which will
not always work, include comprehensive lists in the distribution.
To help keep the lists up to date, the "check_signals" and
"check_errnos" make targets can be used.
* configure.in: don't check for a command to extract errno codes.
* Makefile.am: update file lists, remove errnos.list and errnos.c
targets, add cpp_err_symbols.c, cpp_sig_symbols.c, check_signals,
check_errnos targets.
(CLEANFILES): remove errnos.c and errnos.list, add
cpp_err_symbols_here cpp_err_symbols_diff cpp_err_symbols_new
cpp_sig_symbols_here cpp_sig_symbols_diff cpp_sig_symbols_new
* errnos.default: deleted.
* cpp_signal.c: new file.
* cpp_errno.c: renamed from errnos_get.c.
* cpp_err_symbols, cpp_sig_symbols: new files.
* cpp_cnvt.awk: renamed from errnos_cnvt_awk.
* error.c (scm_init_error): #include cpp_err_symbols instead of
errnos.c.
* posix.c (scm_init_posix): don't intern signal symbols. #include
cpp_sig_symbols.c.
* strop.c (scm_i_index): allow the lower bound to be equal to the
length of the string, so a null string doesn't always give an error.
* posix.h: new prototypes.
* posix.c (scm_status_exit_val, scm_status_term_sig,
scm_status_stop_sig): new functions, as in scsh. They break down
process status values as returned by waitpid.
1997-03-29 18:42:43 +00:00
|
|
|
|
else
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* __MINGW32__ */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_GETPPID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getppid, "getppid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the process ID of the parent\n"
|
|
|
|
|
|
"process.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getppid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
return SCM_MAKINUM (0L + getppid ());
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_GETPPID */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifndef __MINGW32__
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getuid, "getuid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current real user ID.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getuid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
return SCM_MAKINUM (0L + getuid ());
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getgid, "getgid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current real group ID.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getgid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
return SCM_MAKINUM (0L + getgid ());
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_geteuid, "geteuid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current effective user ID.\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If the system does not support effective IDs, then the real ID\n"
|
2002-10-03 22:23:43 +00:00
|
|
|
|
"is returned. @code{(provided? 'EIDs)} reports whether the\n"
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"system supports effective IDs.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_geteuid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
#ifdef HAVE_GETEUID
|
|
|
|
|
|
return SCM_MAKINUM (0L + geteuid ());
|
|
|
|
|
|
#else
|
|
|
|
|
|
return SCM_MAKINUM (0L + getuid ());
|
|
|
|
|
|
#endif
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getegid, "getegid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current effective group ID.\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If the system does not support effective IDs, then the real ID\n"
|
2002-10-03 22:23:43 +00:00
|
|
|
|
"is returned. @code{(provided? 'EIDs)} reports whether the\n"
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"system supports effective IDs.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getegid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
#ifdef HAVE_GETEUID
|
|
|
|
|
|
return SCM_MAKINUM (0L + getegid ());
|
|
|
|
|
|
#else
|
|
|
|
|
|
return SCM_MAKINUM (0L + getgid ());
|
|
|
|
|
|
#endif
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setuid, "setuid", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM id),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Sets both the real and effective user IDs to the integer @var{id}, provided\n"
|
|
|
|
|
|
"the process has appropriate privileges.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setuid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, id);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (setuid (SCM_INUM (id)) != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setgid, "setgid", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM id),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Sets both the real and effective group IDs to the integer @var{id}, provided\n"
|
|
|
|
|
|
"the process has appropriate privileges.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setgid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, id);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (setgid (SCM_INUM (id)) != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_seteuid, "seteuid", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM id),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Sets the effective user ID to the integer @var{id}, provided the process\n"
|
|
|
|
|
|
"has appropriate privileges. If effective IDs are not supported, the\n"
|
2002-10-03 22:23:43 +00:00
|
|
|
|
"real ID is set instead -- @code{(provided? 'EIDs)} reports whether the\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"system supports effective IDs.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_seteuid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
1996-08-02 23:26:33 +00:00
|
|
|
|
int rv;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, id);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#ifdef HAVE_SETEUID
|
1996-08-02 23:26:33 +00:00
|
|
|
|
rv = seteuid (SCM_INUM (id));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#else
|
1996-08-02 23:26:33 +00:00
|
|
|
|
rv = setuid (SCM_INUM (id));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (rv != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-07-03 15:27:56 +00:00
|
|
|
|
#endif /* __MINGW32__ */
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#ifdef HAVE_SETEGID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setegid, "setegid", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM id),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Sets the effective group ID to the integer @var{id}, provided the process\n"
|
|
|
|
|
|
"has appropriate privileges. If effective IDs are not supported, the\n"
|
2002-10-03 22:23:43 +00:00
|
|
|
|
"real ID is set instead -- @code{(provided? 'EIDs)} reports whether the\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"system supports effective IDs.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setegid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
1996-08-02 23:26:33 +00:00
|
|
|
|
int rv;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, id);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#ifdef HAVE_SETEUID
|
1996-08-02 23:26:33 +00:00
|
|
|
|
rv = setegid (SCM_INUM (id));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#else
|
1996-08-02 23:26:33 +00:00
|
|
|
|
rv = setgid (SCM_INUM (id));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (rv != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
Changes to compile under gnu-win32, from Marcus Daniels:
* stime.c (tzset): If tzset isn't provided, make it a NOP.
(scm_localtime): Change SCM_EOF to SCM_EOL.
(scm_mktime): Likewise.
* socket.c: Don't include sys/un.h unless autoconf tells
us Unix domain sockets are available.
(scm_fill_sockaddr): Ignore Unix domain code.
(scm_addr_vector): Likewise.
(scm_init_addr_buffer): Likewise.
(scm_socketpair): Don't include unless socketpair was
found during autoconf.
* simpos.c (SYSTNAME): Treat cygwin like Unix.
* scmsigs.c (scm_pause): Don't include unless pause was found
during autoconf.
* posix.c (scm_getgroups): Don't include unless support function
was found during autoconf (in this case, getgroups).
(scm_setpwent): For setpwent.
(scm_setegid): For setegid.
* net_db.c (scm_inet_netof): Don't include unless support
function was found during autoconf (in this case, inet_netof).
(scm_lnaof): For inet_lnaof.
(scm_inet_makeaddr): For inet_makeaddr.
(scm_getnet): For getnetent, getnetbyname, getnetbyaddr.
(scm_getproto): For getprotoent.
(scm_getserv): For getservent.
(scm_sethost): For sethostent, endhostent.
(scm_setnet): For setnetent, endnetent.
(scm_setproto): For setprotoent, endprotoent.
(scm_setserv): For setservent, endservent.
* scmconfig.h.in: Regenerated.
1997-07-11 05:43:36 +00:00
|
|
|
|
#endif
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_GETPGRP
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getpgrp, "getpgrp", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current process group ID.\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"This is the POSIX definition, not BSD.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getpgrp
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int (*fn)();
|
1996-08-20 17:10:18 +00:00
|
|
|
|
fn = (int (*) ()) getpgrp;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
return SCM_MAKINUM (fn (0));
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_GETPGRP */
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_SETPGID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setpgid, "setpgid", 2, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM pid, SCM pgid),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Move the process @var{pid} into the process group @var{pgid}. @var{pid} or\n"
|
|
|
|
|
|
"@var{pgid} must be integers: they can be zero to indicate the ID of the\n"
|
|
|
|
|
|
"current process.\n"
|
|
|
|
|
|
"Fails on systems that do not support job control.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setpgid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, pid);
|
|
|
|
|
|
SCM_VALIDATE_INUM (2, pgid);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
/* FIXME(?): may be known as setpgrp. */
|
|
|
|
|
|
if (setpgid (SCM_INUM (pid), SCM_INUM (pgid)) != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_SETPGID */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_SETSID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setsid, "setsid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Creates a new session. The current process becomes the session leader\n"
|
|
|
|
|
|
"and is put in a new process group. The process will be detached\n"
|
|
|
|
|
|
"from its controlling terminal if it has one.\n"
|
|
|
|
|
|
"The return value is an integer representing the new process group ID.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setsid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
pid_t sid = setsid ();
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (sid == -1)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_SETSID */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_TTYNAME
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_ttyname, "ttyname", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM port),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return a string with the name of the serial terminal device\n"
|
|
|
|
|
|
"underlying @var{port}.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_ttyname
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-21 17:46:23 +00:00
|
|
|
|
char *result;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
int fd;
|
* filesys.c (scm_close, set_element, get_element, scm_chown,
scm_chmod, scm_stat, scm_truncate_file, scm_fcntl, scm_fsync): Use
SCM_COERCE_OUTPORT to cope with the printstate/port magic.
* ports.c (scm_port_revealed, scm_set_port_revealed_x,
scm_close_port, scm_port_line, scm_set_port_line_x,
scm_port_column, scm_set_port_column_x, scm_port_filename,
scm_set_port_filename_x, scm_port_mode,
scm_close_all_ports_except, scm_set_current_output_port,
scm_set_current_error_port): Likewise
* ioext.c (scm_redirect_port, scm_dup_to_fdes, scm_freopen,
scm_ftell, scm_fileno, scm_isatty_p, scm_primitive_move_to_fdes):
Likewise
* posix.c (scm_ttyname, scm_tcgetpgrp, scm_tcsetpgrp): Likewise
* backtrace.c (display_backtrace_body): Likewise
* fports (scm_setvbuf): Likewise
* socket.c (scm_getsockopt, scm_setsockopt, scm_shutdown,
scm_connect, scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_send, scm_sendto): Likewise
* unif.c (scm_uniform_array_write): Likewise
1997-10-25 21:54:12 +00:00
|
|
|
|
|
|
|
|
|
|
port = SCM_COERCE_OUTPORT (port);
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_OPPORT (1, port);
|
2001-01-25 17:18:41 +00:00
|
|
|
|
if (!SCM_FPORTP (port))
|
1996-07-25 22:56:11 +00:00
|
|
|
|
return SCM_BOOL_F;
|
* ioext.c (scm_do_read_line): Rewritten to use memchr to find the
newline. A bit faster, and definitely hairier.
(scm_read_line): Count newlines here instead.
* strings.c (scm_take_str): New function.
(scm_take0str): Reimplement in terms of scm_take_str. * strings.h
(scm_take_str): New declaration. * ioext.c (scm_read_line): Use
scm_take_str, to avoid copying the string.
Add some simple-minded support for line buffered ports.
* ports.h (SCM_BUFLINE): New flag for ports.
* init.c (scm_init_standard_ports): Request line-buffering on
the standard output port.
* * ports.c (scm_mode_bits): Recognize 'l' as a request for line
buffering.
(scm_putc, scm_puts, scm_lfwrite): If the port is line-buffered,
and there's a newline to be written, flush the port.
* ports.c: (scm_lseek): clear buffers even if just reading current
position.
* fports.c (local_fclose): call local_fflush unconditionally.
(various): don't use the scm_must... memory procs.
* ports.h (scm_port): make read_pos a pointer to const.
strports.c: take care of rw_active and rw_randow.
fports.c: scm_fport_drain_input: removed. do it all in ports.c.
strports.c (scm_mkstrport): check that pos is reasonable.
ioext.c (scm_ftell, scm_fseek): use lseek.
(SCM_CLEAR_BUFFERS): macro deleted.
ioext.c (redirect_port: use ptob fflush, read_flush.
ports.h (scm_ptobfuns): add ftruncate.
ports.c (scm_newptob): set ftruncate.
adjust ptob tables.
* ports.c (scm_ftruncate): new procedure.
fports.c (local_ftrunate), strports.c (str_ftruncate): new procs.
strports.c (st_seek, st_grow_port): new procs.
fports.h (scm_port): change size types from int to off_t.
ports.c (scm_init_ports): initialise the seek symbols here
instead of in ioext.c.
strports.c (scm_call_with_output_string): start with an empty
string, so seek and ftruncate can be used.
* ports.h (scm_ptobfuns): add a read_flush procedure which is the
equivalent to fflush for the read buffer.
* ports.c (scm_newptob): set read_flush.
ports.c (void_port_ptob): set read_flush.
fports.c (local_read_flush): new proc. add to ptob.
strport.c (st_read_flush): likewise.
vport.c (sf_read_flush): likewise.
fports.h (struct scm_fport): remove random member. there's nothing
left but fdes. leaving it as a struct to allow for future changes.
fports.c: replace usage of scm_fport::random with scm_port::rw_random.
ports.c: (scm_putc, scm_puts, scm_lfwrite): call the read_flush
ptob proc if the read buffer is filled.
* ports.h (scm_port): add a rw_random member and replace
reading and writing members with rw_active member.
SCM_PORT_READ/SCM_PORT_WRITE: new values.
* ports.h (struct scm_port_table): add writing and reading members
to replace write_needs_seek: it isn't good enough for non-fports.
ports.c, ioext.c, fports.c: corresponding changes.
(struct scm_port_table): give it a typedef and rename to scm_port.
ports.c, fports.c, strports.c, vports.c, ioext.c, ports.h:
corresponding changes.
* ports.c (scm_newptob): bugfix: set seek member.
* * (scm_lseek): new procedure, using code from ioext.c:scm_fseek
and generalised to all port types.
* scmsigs.c (scm_init_scmsigs): set the SA_RESTART flag for all
signals (it was only being done for handlers installed from Scheme).
Otherwise (for example) SIGSTOP followed by SIGCONT on an interpreter
waiting for input caused an EINTR error from read.
* ports.h (struct scm_port_table): make all the char members
unsigned, so they convert to int without becoming negative if large.
* fports.c (scm_fdes_wait_for_input): forgot to check compilation
with threads enabled. rename this procedure to
fport_wait_for_input and take a port instead of a fdes.
use scm_fport_input_waiting_p instead of scm_fdes_waiting_p.
* readline.c (scm_readline): Applied a patch from Greg Harvey to
get readline support working again: use fdopen to get FILE objects.
* gc.c (scm_init_storage): install an atexit proc to flush the
ports.
(cleanup): the new proc. it sets a global variable which can be
checked by the ptob flush procs to avoid trying to throw
exceptions during exit. not very pleasant but it seems more reliable.
* fports.c (local_fflush): check terminating variable and if set
don't throw exception.
* CHECKME: that the atexit proc is installed if unexec used.
* throw.c (scm_handle_by_message): don't flush all ports here.
it still causes bus errors.
* fports.h (SCM_FPORT_CLEAR_BUFFERS): rename to SCM_CLEAR_BUFFERS
and move to ioext.c.
* fports.c (scm_fdes_waiting_p): merged into fport_input_waiting_p.
* ports.c (scm_char_ready_p): check the port buffer and call the
ptob entry if needed.
* ports.h (scm_ptobfuns): input_waiting_p added. change all the
ptob initialisers. use it in char-ready
* ioext.c (scm_do_read_line): moved from ports.c. make it static.
* vports.c (sfflush): modified to write a char (since softports
currently use shortbuf.)
* fports.c (scm_standard_stream_to_port): moved to init.c and
made static.
* init.c (scm_init_standard_ports): make stdout and stderr
unbuffered if connected to a terminal. with stdio they
were line-buffered by default.
* ports.h (scm_ptobfuns): change fflush return to void.
change flush proc definitions.
* strports.c (scm_call_with_output_string): get size from
buffer instead of port stream.
(scm_strprint_obj): likewise.
(st_flush): new proc.
* ports.h (struct scm_port_table): added write_end member,
as an optimisation. set it where write_buf_size is set.
* ports.h (struct scm_port_table): change stream from void *
back to SCM. SCM presumably must be large enough to hold a
pointer (and probably vice versa but who knows.)
(SCM_SSTREAM): deleted. change users back to SCM_STREAM.
(scm_puts): rewritten
* fports.c (local_ffwrite, local_fputs): removed.
* strports.c (stputc, stputs, stwrite): dyked out (FIXME)
* vports.c (sfputc, sfputs, sfwrite) likewise.
* ports.c (write_void_port, puts_void_port): removed.
(putc_void_port, getc_void_port, fgets_void_port): likewise.
* ports.c (scm_lfwrite): rewritten using fport.c version.
* fports.c (local_fputc): deleted.
* ports.c (scm_add_to_port_table): initialise write_needs_seek.
* ports.h (scm_ptobfuns): add seek function pointer.
* fports.c: set it to local_seek, new procedure.
* fports.h (SCM_MAYBE_DRAIN_INPUT): moved to ports.c.
use ptob for seek. take ptob instead of fport arg.
* ports.h (struct scm_port_table): new member write_needs_seek,
replaces reading member in fport struct.
* vports.c (sfgetc): store the getted char into the buffer.
rename to sf_fill_buffer and install it for fill-buffer in ptob.
the Scheme interface is still a procedure that gets a char.
(scm_make_soft_port): set up the port buffer (shortbuf).
* fports.c (local_fgetc, local_fgets): deleted.
* strports.c (stgetc): likewise.
* ports.c: scm_generic_fgets: likewise.
* ports.h (scm_ptobfuns): add fill_buffer.
* ports.c (scm_newptob): assign it.
* strports.c (scm_mkstrport): set up the buffer.
put just the string into the stream, not cons (pos stream).
(stfill_buffer): new proc.
* ports.h: fport buffer moved into port table: to be
used for all port types.
* throw.c (scm_handle_by_message): flush ports at exit.
* socket.c (scm_sock_fd_to_port): use scm_fdes_to_port.
(scm_getsockopt, scm_setsockopt, scm_shutdown, scm_connect,
scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_recv, scm_send, scm_recvfrom,
scm_sendto,
use SCM_FPORT_FDES. use SCM_OPFPORTP not SCM_FPORTP.
* posix.c (scm_getgroups): use SCM_ALLOW/DEFER_INTS.
(scm_ttyname): use SCM_FPORT_FDES.
(scm_tcgetpgrp, scm_tcsetpgrp): likewise.
* ioext.c (scm_isatty_p): use SCM_FPORT_FDES.
(scm_fdes_to_ports): modified.
(scm_fdopen): use scm_fdes_to_port.
* ports.c (scm_init_ports): don't try to flush ports using
atexit(). it's too late, errors will cause SEGV.
* fports.c (scm_fport_buffer_add): new procedure.
* fports.h (SCM_FDES_RANDOM_P): new macro. use it in
scm_fdes_to_port and scm_redirect_port.
* ioext.c (scm_redirect_port): use setvbuf to set buffers in the
new port. reset fp->random.
* fports.c (scm_fdes_to_port), ports.c (scm_void_port),
filesys.c (scm_opendir):
restore defer interrupts while the port is constructed.
* (scm_setvbuf): if mode is _IOFBF and size is not supplied,
derive buffer size from fdes or use a default.
(scm_fdes_to_port): use setvbuf instead of creating the buffers
directly.
vports.c (various places): use SCM_SSTREAM.
strports.c: likewise.
* gdbint.c: likewise.
* ports.h (SCM_SSTREAM): new macro.
* fports.c (scm_input_waiting_p): use scm_return_first, since port
may be removed from the stack by the tail call to scm_fdes_waiting_p.
* fports.h (SCM_CLEAR_BUFFERS): new macro.
* ports.c (scm_force_output): call scm_fflush.
* print.c (scm_newline): don't check errno for EPIPE (it wouldn't
* reach this point.) don't flush port (if scm_cur_outp).
* fports.h (SCM_FPORT_FDES): new macro.
* vports.c (sfflush): don't need to set errno.
* ports.c: install scm_flush_all_ports to be run on exit.
ports.c fports.c ioext.c posix.c socket.c net_db.c filesys.c:
removed all uses of SCM_DEFER/ALLOW ints for now. they were mainly
just protecting errno. some may need to be put back.
* scmsigs.c (take_signal): save and restore errno while this
proc runs.
*fports.c (print_pipe_port, local_pclose, scm_pipob): deleted.
* open-pipe, close-pipe are emulated in (ice-9 popen)
ports.c (scm_ports_prehistory): don't init scm_pipob.
ports.h (scm_tc16_pipe): deleted.
posix.c (scm_open_pipe, scm_close_pipe): deleted.
* ioext.c (scm_primitive_move_to_fdes): use fport.
* fport.c (scm_fport_fill_buffer): flush write buffer if needed.
change arg type from scm_fport to SCM port.
fport.h (SCM_SETFDES): removed.
(SCM_MAYBE_DRAIN_INPUT): new macro.
* ioext.c (scm_dup_to_fdes): use SCM_FSTREAM.
(scm_ftell): always use lseek and account for the buffer.
(scm_fileno): use fport buffer.
(scm_fseek): clear fport buffers. always use lseek.
* posix.c (scm_pipe): use fport buffer.
* unif.c: include fports.h instead of genio.h.
* fports.c (scm_fdes_wait_for_input, scm_fport_fill_buffer): new
procedures.
(local_fgetc): use them.
(local_ffwrite): use buffer.
(local_fgets): use buffer.
(scm_setbuf0): deleted.
(scm_setvbuf): set the buffer.
(scm_setfileno): deleted.
(scm_evict_ports): set fdes directly.
* (scm_freopen): deleted. doesn't seem useful in Guile.
(scm_stdio_to_port): deleted.
fports.h (struct scm_fport): add shortbuf member to avoid separate
code for unbuffered ports.
(SCM_FPORTP, SCM_OPFPORTP, SCM_OPINFPORTP, SCM_OPOUTFPORTP): moved
from ports.h.
* genio.c, genio.h: move contents into ports.c, ports.h. The
division wasn't useful.
* fports.c, fports.h (scm_fport_drain_input): new procedure.
* ports.c (scm_drain_input): call scm_fport_drain_input.
* scm_fdes_waiting_p: new procedure.
* fports.c (scm_fdes_to_port): allocate read and/or write buffers.
(scm_input_waiting_p): check the buffer.
(local_fgetc, local_fflush, local_fputc): likewise.
* fports.h (scm_fport): read/write_buf,_pos,_buf_end,,_buf_size:
new members.
* init.c (scm_init_standard_ports): pass fdes instead of FILE *.
* * ports.c (scm_drain_input): new procedure.
ports.h: prototype.
* fports.c (FPORT_READ_SAFE, FPORT_WRITE_SAFE, FPORT_ALL_OKAY,
pre_read, pre_write): removed.
(local_fputc, local_fputs, local_ffwrite): use write, not stdio.
(scm_standard_stream_to_port): change first arg from FILE * to
int fdes.
(local_fflush): flush fdes, not FILE *.
* fports.h (SCM_NOFTELL): removed.
* genio.c, ports.c: don't include filesys.h.
* genio.c (scm_getc): don't use scm_internal_select if FPORT.
do it in fports.c:local_fgetc.
* genio.c: don't use SCM_SYSCALL when calling ptob procedures.
do it where it's needed in the port smobs.
* filesys.c (scm_input_waiting_p): moved to fports.c, stdio
buffer support removed. take SCM arg, not FILE *.
* filesys.h: prototype moved too.
* fports.c (scm_fdes_to_port): new procedure.
(local_fgetc): use read not fgetc.
(local_fclose): use close, not fclose.
(local_fgets): use read, not fgets
* fports.h: prototype for scm_fdes_to_port.
* fports.h (scm_fport): new struct.
* fports.c (scm_open_file): use open, not fopen.
#include fcntl.h
* ports.h (struct scm_port_table): change stream from SCM to void *.
* ports.c (scm_add_to_port_table): check for memory allocation error.
(scm_prinport): remove MSDOS hair.
(scm_void_port): set stream to 0 instead of SCM_BOOL_F.
(scm_close_port): don't throw errors: do it in fports.c.
1999-06-09 12:19:58 +00:00
|
|
|
|
fd = SCM_FPORT_FDES (port);
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_SYSCALL (result = ttyname (fd));
|
|
|
|
|
|
if (!result)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
2002-07-21 17:46:23 +00:00
|
|
|
|
/* result could be overwritten by another call to ttyname */
|
|
|
|
|
|
return (scm_makfrom0str (result));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_TTYNAME */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_CTERMID
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_ctermid, "ctermid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return a string containing the file name of the controlling\n"
|
|
|
|
|
|
"terminal for the current process.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_ctermid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
char *result = ctermid (NULL);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (*result == '\0')
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return scm_makfrom0str (result);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_CTERMID */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_TCGETPGRP
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_tcgetpgrp, "tcgetpgrp", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM port),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return the process group ID of the foreground process group\n"
|
|
|
|
|
|
"associated with the terminal open on the file descriptor\n"
|
|
|
|
|
|
"underlying @var{port}.\n"
|
|
|
|
|
|
"\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If there is no foreground process group, the return value is a\n"
|
|
|
|
|
|
"number greater than 1 that does not match the process group ID\n"
|
|
|
|
|
|
"of any existing process group. This can happen if all of the\n"
|
|
|
|
|
|
"processes in the job that was formerly the foreground job have\n"
|
|
|
|
|
|
"terminated, and no other job has yet been moved into the\n"
|
|
|
|
|
|
"foreground.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_tcgetpgrp
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int fd;
|
|
|
|
|
|
pid_t pgid;
|
* filesys.c (scm_close, set_element, get_element, scm_chown,
scm_chmod, scm_stat, scm_truncate_file, scm_fcntl, scm_fsync): Use
SCM_COERCE_OUTPORT to cope with the printstate/port magic.
* ports.c (scm_port_revealed, scm_set_port_revealed_x,
scm_close_port, scm_port_line, scm_set_port_line_x,
scm_port_column, scm_set_port_column_x, scm_port_filename,
scm_set_port_filename_x, scm_port_mode,
scm_close_all_ports_except, scm_set_current_output_port,
scm_set_current_error_port): Likewise
* ioext.c (scm_redirect_port, scm_dup_to_fdes, scm_freopen,
scm_ftell, scm_fileno, scm_isatty_p, scm_primitive_move_to_fdes):
Likewise
* posix.c (scm_ttyname, scm_tcgetpgrp, scm_tcsetpgrp): Likewise
* backtrace.c (display_backtrace_body): Likewise
* fports (scm_setvbuf): Likewise
* socket.c (scm_getsockopt, scm_setsockopt, scm_shutdown,
scm_connect, scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_send, scm_sendto): Likewise
* unif.c (scm_uniform_array_write): Likewise
1997-10-25 21:54:12 +00:00
|
|
|
|
|
|
|
|
|
|
port = SCM_COERCE_OUTPORT (port);
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_OPFPORT (1, port);
|
* ioext.c (scm_do_read_line): Rewritten to use memchr to find the
newline. A bit faster, and definitely hairier.
(scm_read_line): Count newlines here instead.
* strings.c (scm_take_str): New function.
(scm_take0str): Reimplement in terms of scm_take_str. * strings.h
(scm_take_str): New declaration. * ioext.c (scm_read_line): Use
scm_take_str, to avoid copying the string.
Add some simple-minded support for line buffered ports.
* ports.h (SCM_BUFLINE): New flag for ports.
* init.c (scm_init_standard_ports): Request line-buffering on
the standard output port.
* * ports.c (scm_mode_bits): Recognize 'l' as a request for line
buffering.
(scm_putc, scm_puts, scm_lfwrite): If the port is line-buffered,
and there's a newline to be written, flush the port.
* ports.c: (scm_lseek): clear buffers even if just reading current
position.
* fports.c (local_fclose): call local_fflush unconditionally.
(various): don't use the scm_must... memory procs.
* ports.h (scm_port): make read_pos a pointer to const.
strports.c: take care of rw_active and rw_randow.
fports.c: scm_fport_drain_input: removed. do it all in ports.c.
strports.c (scm_mkstrport): check that pos is reasonable.
ioext.c (scm_ftell, scm_fseek): use lseek.
(SCM_CLEAR_BUFFERS): macro deleted.
ioext.c (redirect_port: use ptob fflush, read_flush.
ports.h (scm_ptobfuns): add ftruncate.
ports.c (scm_newptob): set ftruncate.
adjust ptob tables.
* ports.c (scm_ftruncate): new procedure.
fports.c (local_ftrunate), strports.c (str_ftruncate): new procs.
strports.c (st_seek, st_grow_port): new procs.
fports.h (scm_port): change size types from int to off_t.
ports.c (scm_init_ports): initialise the seek symbols here
instead of in ioext.c.
strports.c (scm_call_with_output_string): start with an empty
string, so seek and ftruncate can be used.
* ports.h (scm_ptobfuns): add a read_flush procedure which is the
equivalent to fflush for the read buffer.
* ports.c (scm_newptob): set read_flush.
ports.c (void_port_ptob): set read_flush.
fports.c (local_read_flush): new proc. add to ptob.
strport.c (st_read_flush): likewise.
vport.c (sf_read_flush): likewise.
fports.h (struct scm_fport): remove random member. there's nothing
left but fdes. leaving it as a struct to allow for future changes.
fports.c: replace usage of scm_fport::random with scm_port::rw_random.
ports.c: (scm_putc, scm_puts, scm_lfwrite): call the read_flush
ptob proc if the read buffer is filled.
* ports.h (scm_port): add a rw_random member and replace
reading and writing members with rw_active member.
SCM_PORT_READ/SCM_PORT_WRITE: new values.
* ports.h (struct scm_port_table): add writing and reading members
to replace write_needs_seek: it isn't good enough for non-fports.
ports.c, ioext.c, fports.c: corresponding changes.
(struct scm_port_table): give it a typedef and rename to scm_port.
ports.c, fports.c, strports.c, vports.c, ioext.c, ports.h:
corresponding changes.
* ports.c (scm_newptob): bugfix: set seek member.
* * (scm_lseek): new procedure, using code from ioext.c:scm_fseek
and generalised to all port types.
* scmsigs.c (scm_init_scmsigs): set the SA_RESTART flag for all
signals (it was only being done for handlers installed from Scheme).
Otherwise (for example) SIGSTOP followed by SIGCONT on an interpreter
waiting for input caused an EINTR error from read.
* ports.h (struct scm_port_table): make all the char members
unsigned, so they convert to int without becoming negative if large.
* fports.c (scm_fdes_wait_for_input): forgot to check compilation
with threads enabled. rename this procedure to
fport_wait_for_input and take a port instead of a fdes.
use scm_fport_input_waiting_p instead of scm_fdes_waiting_p.
* readline.c (scm_readline): Applied a patch from Greg Harvey to
get readline support working again: use fdopen to get FILE objects.
* gc.c (scm_init_storage): install an atexit proc to flush the
ports.
(cleanup): the new proc. it sets a global variable which can be
checked by the ptob flush procs to avoid trying to throw
exceptions during exit. not very pleasant but it seems more reliable.
* fports.c (local_fflush): check terminating variable and if set
don't throw exception.
* CHECKME: that the atexit proc is installed if unexec used.
* throw.c (scm_handle_by_message): don't flush all ports here.
it still causes bus errors.
* fports.h (SCM_FPORT_CLEAR_BUFFERS): rename to SCM_CLEAR_BUFFERS
and move to ioext.c.
* fports.c (scm_fdes_waiting_p): merged into fport_input_waiting_p.
* ports.c (scm_char_ready_p): check the port buffer and call the
ptob entry if needed.
* ports.h (scm_ptobfuns): input_waiting_p added. change all the
ptob initialisers. use it in char-ready
* ioext.c (scm_do_read_line): moved from ports.c. make it static.
* vports.c (sfflush): modified to write a char (since softports
currently use shortbuf.)
* fports.c (scm_standard_stream_to_port): moved to init.c and
made static.
* init.c (scm_init_standard_ports): make stdout and stderr
unbuffered if connected to a terminal. with stdio they
were line-buffered by default.
* ports.h (scm_ptobfuns): change fflush return to void.
change flush proc definitions.
* strports.c (scm_call_with_output_string): get size from
buffer instead of port stream.
(scm_strprint_obj): likewise.
(st_flush): new proc.
* ports.h (struct scm_port_table): added write_end member,
as an optimisation. set it where write_buf_size is set.
* ports.h (struct scm_port_table): change stream from void *
back to SCM. SCM presumably must be large enough to hold a
pointer (and probably vice versa but who knows.)
(SCM_SSTREAM): deleted. change users back to SCM_STREAM.
(scm_puts): rewritten
* fports.c (local_ffwrite, local_fputs): removed.
* strports.c (stputc, stputs, stwrite): dyked out (FIXME)
* vports.c (sfputc, sfputs, sfwrite) likewise.
* ports.c (write_void_port, puts_void_port): removed.
(putc_void_port, getc_void_port, fgets_void_port): likewise.
* ports.c (scm_lfwrite): rewritten using fport.c version.
* fports.c (local_fputc): deleted.
* ports.c (scm_add_to_port_table): initialise write_needs_seek.
* ports.h (scm_ptobfuns): add seek function pointer.
* fports.c: set it to local_seek, new procedure.
* fports.h (SCM_MAYBE_DRAIN_INPUT): moved to ports.c.
use ptob for seek. take ptob instead of fport arg.
* ports.h (struct scm_port_table): new member write_needs_seek,
replaces reading member in fport struct.
* vports.c (sfgetc): store the getted char into the buffer.
rename to sf_fill_buffer and install it for fill-buffer in ptob.
the Scheme interface is still a procedure that gets a char.
(scm_make_soft_port): set up the port buffer (shortbuf).
* fports.c (local_fgetc, local_fgets): deleted.
* strports.c (stgetc): likewise.
* ports.c: scm_generic_fgets: likewise.
* ports.h (scm_ptobfuns): add fill_buffer.
* ports.c (scm_newptob): assign it.
* strports.c (scm_mkstrport): set up the buffer.
put just the string into the stream, not cons (pos stream).
(stfill_buffer): new proc.
* ports.h: fport buffer moved into port table: to be
used for all port types.
* throw.c (scm_handle_by_message): flush ports at exit.
* socket.c (scm_sock_fd_to_port): use scm_fdes_to_port.
(scm_getsockopt, scm_setsockopt, scm_shutdown, scm_connect,
scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_recv, scm_send, scm_recvfrom,
scm_sendto,
use SCM_FPORT_FDES. use SCM_OPFPORTP not SCM_FPORTP.
* posix.c (scm_getgroups): use SCM_ALLOW/DEFER_INTS.
(scm_ttyname): use SCM_FPORT_FDES.
(scm_tcgetpgrp, scm_tcsetpgrp): likewise.
* ioext.c (scm_isatty_p): use SCM_FPORT_FDES.
(scm_fdes_to_ports): modified.
(scm_fdopen): use scm_fdes_to_port.
* ports.c (scm_init_ports): don't try to flush ports using
atexit(). it's too late, errors will cause SEGV.
* fports.c (scm_fport_buffer_add): new procedure.
* fports.h (SCM_FDES_RANDOM_P): new macro. use it in
scm_fdes_to_port and scm_redirect_port.
* ioext.c (scm_redirect_port): use setvbuf to set buffers in the
new port. reset fp->random.
* fports.c (scm_fdes_to_port), ports.c (scm_void_port),
filesys.c (scm_opendir):
restore defer interrupts while the port is constructed.
* (scm_setvbuf): if mode is _IOFBF and size is not supplied,
derive buffer size from fdes or use a default.
(scm_fdes_to_port): use setvbuf instead of creating the buffers
directly.
vports.c (various places): use SCM_SSTREAM.
strports.c: likewise.
* gdbint.c: likewise.
* ports.h (SCM_SSTREAM): new macro.
* fports.c (scm_input_waiting_p): use scm_return_first, since port
may be removed from the stack by the tail call to scm_fdes_waiting_p.
* fports.h (SCM_CLEAR_BUFFERS): new macro.
* ports.c (scm_force_output): call scm_fflush.
* print.c (scm_newline): don't check errno for EPIPE (it wouldn't
* reach this point.) don't flush port (if scm_cur_outp).
* fports.h (SCM_FPORT_FDES): new macro.
* vports.c (sfflush): don't need to set errno.
* ports.c: install scm_flush_all_ports to be run on exit.
ports.c fports.c ioext.c posix.c socket.c net_db.c filesys.c:
removed all uses of SCM_DEFER/ALLOW ints for now. they were mainly
just protecting errno. some may need to be put back.
* scmsigs.c (take_signal): save and restore errno while this
proc runs.
*fports.c (print_pipe_port, local_pclose, scm_pipob): deleted.
* open-pipe, close-pipe are emulated in (ice-9 popen)
ports.c (scm_ports_prehistory): don't init scm_pipob.
ports.h (scm_tc16_pipe): deleted.
posix.c (scm_open_pipe, scm_close_pipe): deleted.
* ioext.c (scm_primitive_move_to_fdes): use fport.
* fport.c (scm_fport_fill_buffer): flush write buffer if needed.
change arg type from scm_fport to SCM port.
fport.h (SCM_SETFDES): removed.
(SCM_MAYBE_DRAIN_INPUT): new macro.
* ioext.c (scm_dup_to_fdes): use SCM_FSTREAM.
(scm_ftell): always use lseek and account for the buffer.
(scm_fileno): use fport buffer.
(scm_fseek): clear fport buffers. always use lseek.
* posix.c (scm_pipe): use fport buffer.
* unif.c: include fports.h instead of genio.h.
* fports.c (scm_fdes_wait_for_input, scm_fport_fill_buffer): new
procedures.
(local_fgetc): use them.
(local_ffwrite): use buffer.
(local_fgets): use buffer.
(scm_setbuf0): deleted.
(scm_setvbuf): set the buffer.
(scm_setfileno): deleted.
(scm_evict_ports): set fdes directly.
* (scm_freopen): deleted. doesn't seem useful in Guile.
(scm_stdio_to_port): deleted.
fports.h (struct scm_fport): add shortbuf member to avoid separate
code for unbuffered ports.
(SCM_FPORTP, SCM_OPFPORTP, SCM_OPINFPORTP, SCM_OPOUTFPORTP): moved
from ports.h.
* genio.c, genio.h: move contents into ports.c, ports.h. The
division wasn't useful.
* fports.c, fports.h (scm_fport_drain_input): new procedure.
* ports.c (scm_drain_input): call scm_fport_drain_input.
* scm_fdes_waiting_p: new procedure.
* fports.c (scm_fdes_to_port): allocate read and/or write buffers.
(scm_input_waiting_p): check the buffer.
(local_fgetc, local_fflush, local_fputc): likewise.
* fports.h (scm_fport): read/write_buf,_pos,_buf_end,,_buf_size:
new members.
* init.c (scm_init_standard_ports): pass fdes instead of FILE *.
* * ports.c (scm_drain_input): new procedure.
ports.h: prototype.
* fports.c (FPORT_READ_SAFE, FPORT_WRITE_SAFE, FPORT_ALL_OKAY,
pre_read, pre_write): removed.
(local_fputc, local_fputs, local_ffwrite): use write, not stdio.
(scm_standard_stream_to_port): change first arg from FILE * to
int fdes.
(local_fflush): flush fdes, not FILE *.
* fports.h (SCM_NOFTELL): removed.
* genio.c, ports.c: don't include filesys.h.
* genio.c (scm_getc): don't use scm_internal_select if FPORT.
do it in fports.c:local_fgetc.
* genio.c: don't use SCM_SYSCALL when calling ptob procedures.
do it where it's needed in the port smobs.
* filesys.c (scm_input_waiting_p): moved to fports.c, stdio
buffer support removed. take SCM arg, not FILE *.
* filesys.h: prototype moved too.
* fports.c (scm_fdes_to_port): new procedure.
(local_fgetc): use read not fgetc.
(local_fclose): use close, not fclose.
(local_fgets): use read, not fgets
* fports.h: prototype for scm_fdes_to_port.
* fports.h (scm_fport): new struct.
* fports.c (scm_open_file): use open, not fopen.
#include fcntl.h
* ports.h (struct scm_port_table): change stream from SCM to void *.
* ports.c (scm_add_to_port_table): check for memory allocation error.
(scm_prinport): remove MSDOS hair.
(scm_void_port): set stream to 0 instead of SCM_BOOL_F.
(scm_close_port): don't throw errors: do it in fports.c.
1999-06-09 12:19:58 +00:00
|
|
|
|
fd = SCM_FPORT_FDES (port);
|
|
|
|
|
|
if ((pgid = tcgetpgrp (fd)) == -1)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_MAKINUM (pgid);
|
1999-12-12 02:36:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_TCGETPGRP */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_TCSETPGRP
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_tcsetpgrp, "tcsetpgrp", 2, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM port, SCM pgid),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Set the foreground process group ID for the terminal used by the file\n"
|
|
|
|
|
|
"descriptor underlying @var{port} to the integer @var{pgid}.\n"
|
|
|
|
|
|
"The calling process\n"
|
|
|
|
|
|
"must be a member of the same session as @var{pgid} and must have the same\n"
|
|
|
|
|
|
"controlling terminal. The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_tcsetpgrp
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int fd;
|
* filesys.c (scm_close, set_element, get_element, scm_chown,
scm_chmod, scm_stat, scm_truncate_file, scm_fcntl, scm_fsync): Use
SCM_COERCE_OUTPORT to cope with the printstate/port magic.
* ports.c (scm_port_revealed, scm_set_port_revealed_x,
scm_close_port, scm_port_line, scm_set_port_line_x,
scm_port_column, scm_set_port_column_x, scm_port_filename,
scm_set_port_filename_x, scm_port_mode,
scm_close_all_ports_except, scm_set_current_output_port,
scm_set_current_error_port): Likewise
* ioext.c (scm_redirect_port, scm_dup_to_fdes, scm_freopen,
scm_ftell, scm_fileno, scm_isatty_p, scm_primitive_move_to_fdes):
Likewise
* posix.c (scm_ttyname, scm_tcgetpgrp, scm_tcsetpgrp): Likewise
* backtrace.c (display_backtrace_body): Likewise
* fports (scm_setvbuf): Likewise
* socket.c (scm_getsockopt, scm_setsockopt, scm_shutdown,
scm_connect, scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_send, scm_sendto): Likewise
* unif.c (scm_uniform_array_write): Likewise
1997-10-25 21:54:12 +00:00
|
|
|
|
|
|
|
|
|
|
port = SCM_COERCE_OUTPORT (port);
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_OPFPORT (1, port);
|
|
|
|
|
|
SCM_VALIDATE_INUM (2, pgid);
|
* ioext.c (scm_do_read_line): Rewritten to use memchr to find the
newline. A bit faster, and definitely hairier.
(scm_read_line): Count newlines here instead.
* strings.c (scm_take_str): New function.
(scm_take0str): Reimplement in terms of scm_take_str. * strings.h
(scm_take_str): New declaration. * ioext.c (scm_read_line): Use
scm_take_str, to avoid copying the string.
Add some simple-minded support for line buffered ports.
* ports.h (SCM_BUFLINE): New flag for ports.
* init.c (scm_init_standard_ports): Request line-buffering on
the standard output port.
* * ports.c (scm_mode_bits): Recognize 'l' as a request for line
buffering.
(scm_putc, scm_puts, scm_lfwrite): If the port is line-buffered,
and there's a newline to be written, flush the port.
* ports.c: (scm_lseek): clear buffers even if just reading current
position.
* fports.c (local_fclose): call local_fflush unconditionally.
(various): don't use the scm_must... memory procs.
* ports.h (scm_port): make read_pos a pointer to const.
strports.c: take care of rw_active and rw_randow.
fports.c: scm_fport_drain_input: removed. do it all in ports.c.
strports.c (scm_mkstrport): check that pos is reasonable.
ioext.c (scm_ftell, scm_fseek): use lseek.
(SCM_CLEAR_BUFFERS): macro deleted.
ioext.c (redirect_port: use ptob fflush, read_flush.
ports.h (scm_ptobfuns): add ftruncate.
ports.c (scm_newptob): set ftruncate.
adjust ptob tables.
* ports.c (scm_ftruncate): new procedure.
fports.c (local_ftrunate), strports.c (str_ftruncate): new procs.
strports.c (st_seek, st_grow_port): new procs.
fports.h (scm_port): change size types from int to off_t.
ports.c (scm_init_ports): initialise the seek symbols here
instead of in ioext.c.
strports.c (scm_call_with_output_string): start with an empty
string, so seek and ftruncate can be used.
* ports.h (scm_ptobfuns): add a read_flush procedure which is the
equivalent to fflush for the read buffer.
* ports.c (scm_newptob): set read_flush.
ports.c (void_port_ptob): set read_flush.
fports.c (local_read_flush): new proc. add to ptob.
strport.c (st_read_flush): likewise.
vport.c (sf_read_flush): likewise.
fports.h (struct scm_fport): remove random member. there's nothing
left but fdes. leaving it as a struct to allow for future changes.
fports.c: replace usage of scm_fport::random with scm_port::rw_random.
ports.c: (scm_putc, scm_puts, scm_lfwrite): call the read_flush
ptob proc if the read buffer is filled.
* ports.h (scm_port): add a rw_random member and replace
reading and writing members with rw_active member.
SCM_PORT_READ/SCM_PORT_WRITE: new values.
* ports.h (struct scm_port_table): add writing and reading members
to replace write_needs_seek: it isn't good enough for non-fports.
ports.c, ioext.c, fports.c: corresponding changes.
(struct scm_port_table): give it a typedef and rename to scm_port.
ports.c, fports.c, strports.c, vports.c, ioext.c, ports.h:
corresponding changes.
* ports.c (scm_newptob): bugfix: set seek member.
* * (scm_lseek): new procedure, using code from ioext.c:scm_fseek
and generalised to all port types.
* scmsigs.c (scm_init_scmsigs): set the SA_RESTART flag for all
signals (it was only being done for handlers installed from Scheme).
Otherwise (for example) SIGSTOP followed by SIGCONT on an interpreter
waiting for input caused an EINTR error from read.
* ports.h (struct scm_port_table): make all the char members
unsigned, so they convert to int without becoming negative if large.
* fports.c (scm_fdes_wait_for_input): forgot to check compilation
with threads enabled. rename this procedure to
fport_wait_for_input and take a port instead of a fdes.
use scm_fport_input_waiting_p instead of scm_fdes_waiting_p.
* readline.c (scm_readline): Applied a patch from Greg Harvey to
get readline support working again: use fdopen to get FILE objects.
* gc.c (scm_init_storage): install an atexit proc to flush the
ports.
(cleanup): the new proc. it sets a global variable which can be
checked by the ptob flush procs to avoid trying to throw
exceptions during exit. not very pleasant but it seems more reliable.
* fports.c (local_fflush): check terminating variable and if set
don't throw exception.
* CHECKME: that the atexit proc is installed if unexec used.
* throw.c (scm_handle_by_message): don't flush all ports here.
it still causes bus errors.
* fports.h (SCM_FPORT_CLEAR_BUFFERS): rename to SCM_CLEAR_BUFFERS
and move to ioext.c.
* fports.c (scm_fdes_waiting_p): merged into fport_input_waiting_p.
* ports.c (scm_char_ready_p): check the port buffer and call the
ptob entry if needed.
* ports.h (scm_ptobfuns): input_waiting_p added. change all the
ptob initialisers. use it in char-ready
* ioext.c (scm_do_read_line): moved from ports.c. make it static.
* vports.c (sfflush): modified to write a char (since softports
currently use shortbuf.)
* fports.c (scm_standard_stream_to_port): moved to init.c and
made static.
* init.c (scm_init_standard_ports): make stdout and stderr
unbuffered if connected to a terminal. with stdio they
were line-buffered by default.
* ports.h (scm_ptobfuns): change fflush return to void.
change flush proc definitions.
* strports.c (scm_call_with_output_string): get size from
buffer instead of port stream.
(scm_strprint_obj): likewise.
(st_flush): new proc.
* ports.h (struct scm_port_table): added write_end member,
as an optimisation. set it where write_buf_size is set.
* ports.h (struct scm_port_table): change stream from void *
back to SCM. SCM presumably must be large enough to hold a
pointer (and probably vice versa but who knows.)
(SCM_SSTREAM): deleted. change users back to SCM_STREAM.
(scm_puts): rewritten
* fports.c (local_ffwrite, local_fputs): removed.
* strports.c (stputc, stputs, stwrite): dyked out (FIXME)
* vports.c (sfputc, sfputs, sfwrite) likewise.
* ports.c (write_void_port, puts_void_port): removed.
(putc_void_port, getc_void_port, fgets_void_port): likewise.
* ports.c (scm_lfwrite): rewritten using fport.c version.
* fports.c (local_fputc): deleted.
* ports.c (scm_add_to_port_table): initialise write_needs_seek.
* ports.h (scm_ptobfuns): add seek function pointer.
* fports.c: set it to local_seek, new procedure.
* fports.h (SCM_MAYBE_DRAIN_INPUT): moved to ports.c.
use ptob for seek. take ptob instead of fport arg.
* ports.h (struct scm_port_table): new member write_needs_seek,
replaces reading member in fport struct.
* vports.c (sfgetc): store the getted char into the buffer.
rename to sf_fill_buffer and install it for fill-buffer in ptob.
the Scheme interface is still a procedure that gets a char.
(scm_make_soft_port): set up the port buffer (shortbuf).
* fports.c (local_fgetc, local_fgets): deleted.
* strports.c (stgetc): likewise.
* ports.c: scm_generic_fgets: likewise.
* ports.h (scm_ptobfuns): add fill_buffer.
* ports.c (scm_newptob): assign it.
* strports.c (scm_mkstrport): set up the buffer.
put just the string into the stream, not cons (pos stream).
(stfill_buffer): new proc.
* ports.h: fport buffer moved into port table: to be
used for all port types.
* throw.c (scm_handle_by_message): flush ports at exit.
* socket.c (scm_sock_fd_to_port): use scm_fdes_to_port.
(scm_getsockopt, scm_setsockopt, scm_shutdown, scm_connect,
scm_bind, scm_listen, scm_accept, scm_getsockname,
scm_getpeername, scm_recv, scm_send, scm_recvfrom,
scm_sendto,
use SCM_FPORT_FDES. use SCM_OPFPORTP not SCM_FPORTP.
* posix.c (scm_getgroups): use SCM_ALLOW/DEFER_INTS.
(scm_ttyname): use SCM_FPORT_FDES.
(scm_tcgetpgrp, scm_tcsetpgrp): likewise.
* ioext.c (scm_isatty_p): use SCM_FPORT_FDES.
(scm_fdes_to_ports): modified.
(scm_fdopen): use scm_fdes_to_port.
* ports.c (scm_init_ports): don't try to flush ports using
atexit(). it's too late, errors will cause SEGV.
* fports.c (scm_fport_buffer_add): new procedure.
* fports.h (SCM_FDES_RANDOM_P): new macro. use it in
scm_fdes_to_port and scm_redirect_port.
* ioext.c (scm_redirect_port): use setvbuf to set buffers in the
new port. reset fp->random.
* fports.c (scm_fdes_to_port), ports.c (scm_void_port),
filesys.c (scm_opendir):
restore defer interrupts while the port is constructed.
* (scm_setvbuf): if mode is _IOFBF and size is not supplied,
derive buffer size from fdes or use a default.
(scm_fdes_to_port): use setvbuf instead of creating the buffers
directly.
vports.c (various places): use SCM_SSTREAM.
strports.c: likewise.
* gdbint.c: likewise.
* ports.h (SCM_SSTREAM): new macro.
* fports.c (scm_input_waiting_p): use scm_return_first, since port
may be removed from the stack by the tail call to scm_fdes_waiting_p.
* fports.h (SCM_CLEAR_BUFFERS): new macro.
* ports.c (scm_force_output): call scm_fflush.
* print.c (scm_newline): don't check errno for EPIPE (it wouldn't
* reach this point.) don't flush port (if scm_cur_outp).
* fports.h (SCM_FPORT_FDES): new macro.
* vports.c (sfflush): don't need to set errno.
* ports.c: install scm_flush_all_ports to be run on exit.
ports.c fports.c ioext.c posix.c socket.c net_db.c filesys.c:
removed all uses of SCM_DEFER/ALLOW ints for now. they were mainly
just protecting errno. some may need to be put back.
* scmsigs.c (take_signal): save and restore errno while this
proc runs.
*fports.c (print_pipe_port, local_pclose, scm_pipob): deleted.
* open-pipe, close-pipe are emulated in (ice-9 popen)
ports.c (scm_ports_prehistory): don't init scm_pipob.
ports.h (scm_tc16_pipe): deleted.
posix.c (scm_open_pipe, scm_close_pipe): deleted.
* ioext.c (scm_primitive_move_to_fdes): use fport.
* fport.c (scm_fport_fill_buffer): flush write buffer if needed.
change arg type from scm_fport to SCM port.
fport.h (SCM_SETFDES): removed.
(SCM_MAYBE_DRAIN_INPUT): new macro.
* ioext.c (scm_dup_to_fdes): use SCM_FSTREAM.
(scm_ftell): always use lseek and account for the buffer.
(scm_fileno): use fport buffer.
(scm_fseek): clear fport buffers. always use lseek.
* posix.c (scm_pipe): use fport buffer.
* unif.c: include fports.h instead of genio.h.
* fports.c (scm_fdes_wait_for_input, scm_fport_fill_buffer): new
procedures.
(local_fgetc): use them.
(local_ffwrite): use buffer.
(local_fgets): use buffer.
(scm_setbuf0): deleted.
(scm_setvbuf): set the buffer.
(scm_setfileno): deleted.
(scm_evict_ports): set fdes directly.
* (scm_freopen): deleted. doesn't seem useful in Guile.
(scm_stdio_to_port): deleted.
fports.h (struct scm_fport): add shortbuf member to avoid separate
code for unbuffered ports.
(SCM_FPORTP, SCM_OPFPORTP, SCM_OPINFPORTP, SCM_OPOUTFPORTP): moved
from ports.h.
* genio.c, genio.h: move contents into ports.c, ports.h. The
division wasn't useful.
* fports.c, fports.h (scm_fport_drain_input): new procedure.
* ports.c (scm_drain_input): call scm_fport_drain_input.
* scm_fdes_waiting_p: new procedure.
* fports.c (scm_fdes_to_port): allocate read and/or write buffers.
(scm_input_waiting_p): check the buffer.
(local_fgetc, local_fflush, local_fputc): likewise.
* fports.h (scm_fport): read/write_buf,_pos,_buf_end,,_buf_size:
new members.
* init.c (scm_init_standard_ports): pass fdes instead of FILE *.
* * ports.c (scm_drain_input): new procedure.
ports.h: prototype.
* fports.c (FPORT_READ_SAFE, FPORT_WRITE_SAFE, FPORT_ALL_OKAY,
pre_read, pre_write): removed.
(local_fputc, local_fputs, local_ffwrite): use write, not stdio.
(scm_standard_stream_to_port): change first arg from FILE * to
int fdes.
(local_fflush): flush fdes, not FILE *.
* fports.h (SCM_NOFTELL): removed.
* genio.c, ports.c: don't include filesys.h.
* genio.c (scm_getc): don't use scm_internal_select if FPORT.
do it in fports.c:local_fgetc.
* genio.c: don't use SCM_SYSCALL when calling ptob procedures.
do it where it's needed in the port smobs.
* filesys.c (scm_input_waiting_p): moved to fports.c, stdio
buffer support removed. take SCM arg, not FILE *.
* filesys.h: prototype moved too.
* fports.c (scm_fdes_to_port): new procedure.
(local_fgetc): use read not fgetc.
(local_fclose): use close, not fclose.
(local_fgets): use read, not fgets
* fports.h: prototype for scm_fdes_to_port.
* fports.h (scm_fport): new struct.
* fports.c (scm_open_file): use open, not fopen.
#include fcntl.h
* ports.h (struct scm_port_table): change stream from SCM to void *.
* ports.c (scm_add_to_port_table): check for memory allocation error.
(scm_prinport): remove MSDOS hair.
(scm_void_port): set stream to 0 instead of SCM_BOOL_F.
(scm_close_port): don't throw errors: do it in fports.c.
1999-06-09 12:19:58 +00:00
|
|
|
|
fd = SCM_FPORT_FDES (port);
|
|
|
|
|
|
if (tcsetpgrp (fd, SCM_INUM (pgid)) == -1)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1999-12-12 02:36:16 +00:00
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_TCSETPGRP */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2002-06-30 19:27:18 +00:00
|
|
|
|
/* return a newly allocated array of char pointers to each of the strings
|
|
|
|
|
|
in args, with a terminating NULL pointer. */
|
|
|
|
|
|
/* Note: a similar function is defined in dynl.c, but we don't necessarily
|
|
|
|
|
|
want to export it. */
|
|
|
|
|
|
static char **allocate_string_pointers (SCM args)
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-06-30 19:27:18 +00:00
|
|
|
|
char **result;
|
|
|
|
|
|
int n_args = scm_ilength (args);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
int i;
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
|
2002-06-30 19:27:18 +00:00
|
|
|
|
SCM_ASSERT (n_args >= 0, args, SCM_ARGn, "allocate_string_pointers");
|
|
|
|
|
|
result = (char **) scm_malloc ((n_args + 1) * sizeof (char *));
|
|
|
|
|
|
result[n_args] = NULL;
|
|
|
|
|
|
for (i = 0; i < n_args; i++)
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-06-30 19:27:18 +00:00
|
|
|
|
SCM car = SCM_CAR (args);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
|
2002-06-30 19:27:18 +00:00
|
|
|
|
if (!SCM_STRINGP (car))
|
|
|
|
|
|
{
|
|
|
|
|
|
free (result);
|
|
|
|
|
|
scm_wrong_type_arg ("allocate_string_pointers", SCM_ARGn, car);
|
|
|
|
|
|
}
|
|
|
|
|
|
result[i] = SCM_STRING_CHARS (SCM_CAR (args));
|
|
|
|
|
|
args = SCM_CDR (args);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
2002-06-30 19:27:18 +00:00
|
|
|
|
return result;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_execl, "execl", 1, 0, 1,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM filename, SCM args),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Executes the file named by @var{path} as a new process image.\n"
|
|
|
|
|
|
"The remaining arguments are supplied to the process; from a C program\n"
|
2002-03-15 10:37:40 +00:00
|
|
|
|
"they are accessible as the @code{argv} argument to @code{main}.\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Conventionally the first @var{arg} is the same as @var{path}.\n"
|
2001-11-16 15:04:17 +00:00
|
|
|
|
"All arguments must be strings.\n\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"If @var{arg} is missing, @var{path} is executed with a null\n"
|
|
|
|
|
|
"argument list, which may have system-dependent side-effects.\n\n"
|
|
|
|
|
|
"This procedure is currently implemented using the @code{execv} system\n"
|
|
|
|
|
|
"call, but we call it @code{execl} because of its Scheme calling interface.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_execl
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
char **execargv;
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, filename);
|
2002-06-30 19:27:18 +00:00
|
|
|
|
execargv = allocate_string_pointers (args);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
execv (SCM_STRING_CHARS (filename), execargv);
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
/* not reached. */
|
|
|
|
|
|
return SCM_BOOL_F;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_execlp, "execlp", 1, 0, 1,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM filename, SCM args),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Similar to @code{execl}, however if\n"
|
|
|
|
|
|
"@var{filename} does not contain a slash\n"
|
|
|
|
|
|
"then the file to execute will be located by searching the\n"
|
|
|
|
|
|
"directories listed in the @code{PATH} environment variable.\n\n"
|
2000-04-25 22:08:26 +00:00
|
|
|
|
"This procedure is currently implemented using the @code{execvp} system\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"call, but we call it @code{execlp} because of its Scheme calling interface.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_execlp
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
char **execargv;
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, filename);
|
2002-06-30 19:27:18 +00:00
|
|
|
|
execargv = allocate_string_pointers (args);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
execvp (SCM_STRING_CHARS (filename), execargv);
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
/* not reached. */
|
|
|
|
|
|
return SCM_BOOL_F;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
static char **
|
* chars.c (scm_lowers, scm_uppers, scm_charnames, scm_charnums),
eval.c (s_expression, s_test, s_body, s_bindings, s_variable,
s_clauses, s_formals): Variables now const.
* eval.c (promsmob): Now const.
* macros.c (macrosmob): Now const.
* smob.c (scm_newsmob): Smobfuns argument now points to const.
(freecell, flob, bigob): Now const.
* dynl.c (scm_make_argv_from_stringlist, scm_coerce_rostring),
error.c (scm_error, scm_syserror, scm_syserror_msg,
scm_num_overflow, scm_out_of_range, scm_wrong_type_arg,
scm_memory_error, scm_misc_error, scm_wta), macros.c
(scm_make_synt), feature.c (scm_add_feature), filesys.c
(scm_input_waiting_p), gc.c (scm_gc_start, scm_igc,
scm_must_malloc, scm_must_realloc), gsubr.c (scm_make_gsubr),
numbers.c (scm_num2dbl, scm_two_doubles, scm_num2long,
scm_num2long_long, scm_num2ulong),
options.c (scm_options), posix.c (scm_convert_exec_args,
environ_list_to_c), procs.c (scm_make_subr_opt, scm_make_subr),
ramap.c (scm_ramapc), read.c (scm_flush_ws), socket.c
(scm_sock_fd_to_port, scm_fill_sockaddr, scm_addr_vector), stime.c
(setzone, restorezone, bdtime2c), strop.c (scm_i_index),
strports.c (scm_mkstrport), symbols.c (scm_intern_obarray_soft,
scm_intern_obarray, scm_intern, scm_intern0,
scm_sysintern0_no_module_lookup, scm_sysintern, scm_sysintern0,
scm_symbol_value0), unif.c (scm_aind, scm_shap2ra): Argument
indicating calling subr, error message text, reason for error,
symbol name or feature name are now pointer to const.
* snarf.h (SCM_PROC, SCM_PROC1): String variables are now const.
* procs.c (scm_init_iprocs): iproc argument now points to const.
* pairs.c (cxrs): Now const.
* chars.h, error.h, feature.h, filesys.h, gc.h, gsubr.h, macros.h,
numbers.h, options.h, procs.h, ramap.h, read.h, smob.h,
strports.h, symbols.h, unif.h: Update variable declarations and
function prototypes for above changes.
* dynl.c, dynl-dld.c, dynl-dl.c, dynl-shl.c (sysdep_dynl_link,
sysdep_dynl_unlink, sysdep_dynl_func): Arguments FNAME, SUBR, and
SYMB now point to const.
1999-02-06 12:31:04 +00:00
|
|
|
|
environ_list_to_c (SCM envlist, int arg, const char *proc)
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
{
|
|
|
|
|
|
int num_strings;
|
|
|
|
|
|
char **result;
|
2000-10-30 11:42:26 +00:00
|
|
|
|
int i;
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
|
|
|
|
|
|
num_strings = scm_ilength (envlist);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_ASSERT (num_strings >= 0, envlist, arg, proc);
|
2002-08-16 22:01:10 +00:00
|
|
|
|
result = (char **) scm_malloc ((num_strings + 1) * sizeof (char *));
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
if (result == NULL)
|
|
|
|
|
|
scm_memory_error (proc);
|
2002-01-22 23:31:39 +00:00
|
|
|
|
for (i = 0; !SCM_NULL_OR_NIL_P (envlist); ++i, envlist = SCM_CDR (envlist))
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
{
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM str = SCM_CAR (envlist);
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
int len;
|
|
|
|
|
|
char *src;
|
|
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_ASSERT (SCM_STRINGP (str), envlist, arg, proc);
|
|
|
|
|
|
len = SCM_STRING_LENGTH (str);
|
2000-11-22 11:20:03 +00:00
|
|
|
|
src = SCM_STRING_CHARS (str);
|
2002-08-16 22:01:10 +00:00
|
|
|
|
result[i] = scm_malloc (len + 1);
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
if (result[i] == NULL)
|
|
|
|
|
|
scm_memory_error (proc);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
memcpy (result[i], src, len);
|
|
|
|
|
|
result[i][len] = 0;
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
result[i] = 0;
|
|
|
|
|
|
return result;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_execle, "execle", 2, 0, 1,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM filename, SCM env, SCM args),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Similar to @code{execl}, but the environment of the new process is\n"
|
|
|
|
|
|
"specified by @var{env}, which must be a list of strings as returned by the\n"
|
|
|
|
|
|
"@code{environ} procedure.\n\n"
|
|
|
|
|
|
"This procedure is currently implemented using the @code{execve} system\n"
|
|
|
|
|
|
"call, but we call it @code{execle} because of its Scheme calling interface.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_execle
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
{
|
|
|
|
|
|
char **execargv;
|
|
|
|
|
|
char **exec_env;
|
|
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, filename);
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
|
2002-06-30 19:27:18 +00:00
|
|
|
|
execargv = allocate_string_pointers (args);
|
1999-12-12 02:36:16 +00:00
|
|
|
|
exec_env = environ_list_to_c (env, SCM_ARG2, FUNC_NAME);
|
2000-10-30 11:42:26 +00:00
|
|
|
|
execve (SCM_STRING_CHARS (filename), execargv, exec_env);
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
/* not reached. */
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#ifdef HAVE_FORK
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_fork, "primitive-fork", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Creates a new \"child\" process by duplicating the current \"parent\" process.\n"
|
|
|
|
|
|
"In the child the return value is 0. In the parent the return value is\n"
|
|
|
|
|
|
"the integer process ID of the child.\n\n"
|
|
|
|
|
|
"This procedure has been renamed from @code{fork} to avoid a naming conflict\n"
|
|
|
|
|
|
"with the scsh fork.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_fork
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
On NextStep, <utime.h> doesn't define struct utime, unless we
#define _POSIX_SOURCE before #including it.
* aclocal.m4 (GUILE_STRUCT_UTIMBUF): New test.
* acconfig.h: New comment text for above CPP symbol.
* configure.in: Call it.
* posix.c: #define _POSIX_SOURCE if it seems necessary.
* configure.in (AC_CHECK_HEADERS): Include sys/utime.h and utime.h
in the list.
* posix.c: Check HAVE_SYS_UTIME_H and HAVE_UTIME_H, instead of
testing for __EMX__.
* posix.c: #include <libc.h>, if it exists.
* posix.c: Cast the return result to GETGROUPS_T, not gid_t; we
don't even know if the latter exists.
* posix.c (s_sys_setpgid, s_sys_setsid, s_sys_ctermid,
s_sys_tcgetpgrp, s_sys_tcsetpgrp): Renamed from s_setpgid,
s_setsid, s_ctermid, s_tcgetpgrp, s_tcsetpgrp, for consistency.
* posix.c (R_OK, W_OK, X_OK, F_OK): #define these if the system's
header files don't.
(scm_init_posix): Use them when initializing the Scheme constants
of the same name.
1996-09-03 04:43:15 +00:00
|
|
|
|
int pid;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
pid = fork ();
|
|
|
|
|
|
if (pid == -1)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_MAKINUM (0L+pid);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
2001-06-26 17:53:09 +00:00
|
|
|
|
#endif /* HAVE_FORK */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-11-02 00:16:46 +00:00
|
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
|
# include "win32-uname.h"
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if defined (HAVE_UNAME) || defined (__MINGW32__)
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_uname, "uname", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an object with some information about the computer\n"
|
|
|
|
|
|
"system the program is running on.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_uname
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
struct utsname buf;
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM result = scm_c_make_vector (5, SCM_UNSPECIFIED);
|
* scmsigs.h, async.h: updated.
* _scm.h: if HAVE_RESTARTS is defined then don't use a SYSCALL
loop.
* posix.c (scm_uname): interpret only negative values as an error.
Solaris normally returns a positive value.
* script.c (scm_compile_shell_switches): if we are not going into
an interactive repl, set scm_mask_ints to zero so that asyncs can
run.
* simpos.c (scm_system): don't ignore/unignore signals around
the "system" call.
* posix.c (scm_open_pipe): don't ignore/unignore signals around
the "popen" call.
* init.c (scm_boot_guile_1): don't call scm_init_signals, it's
done in boot-9.scm instead.
* scmsigs.c, async.c: Major rewriting of signal handling code.
(scm_sigaction): new procedure.
(scm_sleep): don't wrap sleep in SCM_SYSCALL, it would mess up the
timing.
(scm_raise): return unspecified, throw error on failure.
* boot-9.scm: signal-handler, alarm-thunk: removed.
don't define ticks-interrupt etc.
top-repl: install signal handlers for SIGINT, SIGFPE, SIGSEGV, SIGBUS
during call to scm-style-repl.
* acconfig.h: mention HAVE_RESTARTS.
* configure.in: check for sigaction and restartable system calls.
1997-05-31 19:02:38 +00:00
|
|
|
|
if (uname (&buf) < 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 0, scm_makfrom0str (buf.sysname));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 1, scm_makfrom0str (buf.nodename));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 2, scm_makfrom0str (buf.release));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 3, scm_makfrom0str (buf.version));
|
|
|
|
|
|
SCM_VECTOR_SET(result, 4, scm_makfrom0str (buf.machine));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
/*
|
1996-08-02 23:26:33 +00:00
|
|
|
|
a linux special?
|
2002-07-21 17:46:23 +00:00
|
|
|
|
SCM_VECTOR_SET(result, 5, scm_makfrom0str (buf.domainname));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
*/
|
2002-07-21 17:46:23 +00:00
|
|
|
|
return result;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_UNAME */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_environ, "environ", 0, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM env),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"If @var{env} is omitted, return the current environment (in the\n"
|
|
|
|
|
|
"Unix sense) as a list of strings. Otherwise set the current\n"
|
|
|
|
|
|
"environment, which is also the default environment for child\n"
|
|
|
|
|
|
"processes, to the supplied list of strings. Each member of\n"
|
|
|
|
|
|
"@var{env} should be of the form @code{NAME=VALUE} and values of\n"
|
|
|
|
|
|
"@code{NAME} should not be duplicated. If @var{env} is supplied\n"
|
|
|
|
|
|
"then the return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_environ
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
if (SCM_UNBNDP (env))
|
|
|
|
|
|
return scm_makfromstrs (-1, environ);
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
char **new_environ;
|
* stime.h: prototype for scm_times.
* stime.c (scm_times): new procedure.
* ioext.c (scm_fseek): if the first argument is a file descriptor
call lseek.
(scm_ftell): if the first argument is a file descriptor call lseek
(sic).
* filesys.h: prototypes for scm_open_fdes, scm_fsync.
* filesys.c (scm_chmod): if the first argument is a file descriptor,
call fchmod.
(scm_chown): if the first argument is a port or file descriptor,
call fchown.
(scm_truncate_file): new procedure.
Add DEFER/ALLOW INTS to a few other procedures.
(scm_fsync): new procedure.
(scm_open_fdes): new procedure.
(scm_open): use scm_open_fdes. If mode isn't specified, 666 will
now be used.
(scm_fcntl): the first argument can now be a file descriptor. The
third argument is now optional.
* posix.c (scm_execl, scm_execlp): make the filename argument
compulsory, since omitting it causes SEGV.
(scm_sync): return unspecified instead of #f.
(scm_execle): new procedure.
(environ_list_to_c): new procedure.
(scm_environ): use environ_list_to_c. disable interrupts.
(scm_convert_exec_args): take pos and subr arguments and
improve error checking.
* boot-9.scm: define tms accessors: clock, utime, stime, cutime,
cstime.
1997-08-16 18:48:44 +00:00
|
|
|
|
|
1999-12-12 02:36:16 +00:00
|
|
|
|
new_environ = environ_list_to_c (env, SCM_ARG1, FUNC_NAME);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
/* Free the old environment, except when called for the first
|
|
|
|
|
|
* time.
|
|
|
|
|
|
*/
|
|
|
|
|
|
{
|
|
|
|
|
|
char **ep;
|
|
|
|
|
|
static int first = 1;
|
|
|
|
|
|
if (!first)
|
|
|
|
|
|
{
|
|
|
|
|
|
for (ep = environ; *ep != NULL; ep++)
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
free (*ep);
|
|
|
|
|
|
free ((char *) environ);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
first = 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
environ = new_environ;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
1996-11-02 20:53:53 +00:00
|
|
|
|
#ifdef L_tmpnam
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_tmpnam, "tmpnam", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return a name in the file system that does not match any\n"
|
|
|
|
|
|
"existing file. However there is no guarantee that another\n"
|
|
|
|
|
|
"process will not create the file after @code{tmpnam} is called.\n"
|
|
|
|
|
|
"Care should be taken if opening the file, e.g., use the\n"
|
|
|
|
|
|
"@code{O_EXCL} open flag or use @code{mkstemp!} instead.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_tmpnam
|
1996-11-02 20:53:53 +00:00
|
|
|
|
{
|
|
|
|
|
|
char name[L_tmpnam];
|
2001-03-18 20:29:58 +00:00
|
|
|
|
char *rv;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_SYSCALL (rv = tmpnam (name));
|
|
|
|
|
|
if (rv == NULL)
|
|
|
|
|
|
/* not SCM_SYSERROR since errno probably not set. */
|
|
|
|
|
|
SCM_MISC_ERROR ("tmpnam failed", SCM_EOL);
|
1996-11-02 20:53:53 +00:00
|
|
|
|
return scm_makfrom0str (name);
|
|
|
|
|
|
}
|
2000-01-11 21:47:57 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#endif
|
* __scm.h, alist.c, alist.h, append.c, append.h, appinit.c,
arbiters.c, arbiters.h, async.c, async.h, boolean.c, boolean.h,
chars.c, chars.h, continuations.c, continuations.h, debug.c,
debug.h, dynwind.c, dynwind.h, eq.c, eq.h, error.c, eval.c,
eval.h, extchrs.c, extchrs.h, fdsocket.c, fdsocket.h, filesys.c,
filesys.h, fports.c, fports.h, gc.c, gdb_interface.h, gdbint.c,
gdbint.h, genio.c, genio.h, gscm.c, gscm.h, gsubr.c, gsubr.h,
hash.c, hash.h, hashtab.c, hashtab.h, init.c, ioext.c, ioext.h,
kw.c, kw.h, libguile.h, mallocs.c, mallocs.h, markers.c,
markers.h, mbstrings.c, mbstrings.h, numbers.c, numbers.h,
objprop.c, objprop.h, options.c, options.h, pairs.c, pairs.h,
ports.c, ports.h, posix.c, posix.h, print.c, print.h, procprop.c,
procprop.h, procs.c, procs.h, ramap.c, ramap.h, read.c, read.h,
root.c, scmsigs.c, scmsigs.h, sequences.c, sequences.h, simpos.c,
simpos.h, smob.c, socket.c, socket.h, srcprop.c, srcprop.h,
stackchk.c, stackchk.h, stime.c, stime.h, strings.c, strings.h,
strop.c, strop.h, strorder.c, strorder.h, strports.c, strports.h,
struct.c, struct.h, symbols.c, symbols.h, tag.c, tag.h, unif.c,
unif.h, variable.c, variable.h, vectors.c, vectors.h, version.c,
version.h, vports.c, vports.h, weaks.c, weaks.h: Use SCM_P to
declare functions with prototypes. (Patch thanks to Marius
Vollmer.)
1996-10-14 01:33:50 +00:00
|
|
|
|
|
2001-11-02 00:16:46 +00:00
|
|
|
|
#ifndef HAVE_MKSTEMP
|
|
|
|
|
|
extern int mkstemp (char *);
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
2001-03-18 20:29:58 +00:00
|
|
|
|
SCM_DEFINE (scm_mkstemp, "mkstemp!", 1, 0, 0,
|
|
|
|
|
|
(SCM tmpl),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Create a new unique file in the file system and returns a new\n"
|
|
|
|
|
|
"buffered port open for reading and writing to the file.\n"
|
|
|
|
|
|
"@var{tmpl} is a string specifying where the file should be\n"
|
|
|
|
|
|
"created: it must end with @code{XXXXXX} and will be changed in\n"
|
|
|
|
|
|
"place to return the name of the temporary file.")
|
2001-03-18 20:29:58 +00:00
|
|
|
|
#define FUNC_NAME s_scm_mkstemp
|
|
|
|
|
|
{
|
|
|
|
|
|
char *c_tmpl;
|
|
|
|
|
|
int rv;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_STRING_COPY (1, tmpl, c_tmpl);
|
|
|
|
|
|
SCM_SYSCALL (rv = mkstemp (c_tmpl));
|
|
|
|
|
|
if (rv == -1)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return scm_fdes_to_port (rv, "w+", tmpl);
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_utime, "utime", 1, 2, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM pathname, SCM actime, SCM modtime),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"@code{utime} sets the access and modification times for the\n"
|
|
|
|
|
|
"file named by @var{path}. If @var{actime} or @var{modtime} is\n"
|
|
|
|
|
|
"not supplied, then the current time is used. @var{actime} and\n"
|
|
|
|
|
|
"@var{modtime} must be integer time values as returned by the\n"
|
|
|
|
|
|
"@code{current-time} procedure.\n"
|
|
|
|
|
|
"@lisp\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"(utime \"foo\" (- (current-time) 3600))\n"
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"@end lisp\n"
|
|
|
|
|
|
"will set the access time to one hour in the past and the\n"
|
|
|
|
|
|
"modification time to the current time.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_utime
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int rv;
|
|
|
|
|
|
struct utimbuf utm_tmp;
|
|
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, pathname);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (SCM_UNBNDP (actime))
|
|
|
|
|
|
SCM_SYSCALL (time (&utm_tmp.actime));
|
|
|
|
|
|
else
|
2001-04-10 07:57:05 +00:00
|
|
|
|
utm_tmp.actime = SCM_NUM2ULONG (2, actime);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
if (SCM_UNBNDP (modtime))
|
|
|
|
|
|
SCM_SYSCALL (time (&utm_tmp.modtime));
|
|
|
|
|
|
else
|
2001-04-10 07:57:05 +00:00
|
|
|
|
utm_tmp.modtime = SCM_NUM2ULONG (3, modtime);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_SYSCALL (rv = utime (SCM_STRING_CHARS (pathname), &utm_tmp));
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (rv != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_access, "access?", 2, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM path, SCM how),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return @code{#t} if @var{path} corresponds to an existing file\n"
|
|
|
|
|
|
"and the current process has the type of access specified by\n"
|
|
|
|
|
|
"@var{how}, otherwise @code{#f}. @var{how} should be specified\n"
|
|
|
|
|
|
"using the values of the variables listed below. Multiple\n"
|
|
|
|
|
|
"values can be combined using a bitwise or, in which case\n"
|
|
|
|
|
|
"@code{#t} will only be returned if all accesses are granted.\n"
|
|
|
|
|
|
"\n"
|
|
|
|
|
|
"Permissions are checked using the real id of the current\n"
|
|
|
|
|
|
"process, not the effective id, although it's the effective id\n"
|
|
|
|
|
|
"which determines whether the access would actually be granted.\n"
|
|
|
|
|
|
"\n"
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"@defvar R_OK\n"
|
|
|
|
|
|
"test for read permission.\n"
|
|
|
|
|
|
"@end defvar\n"
|
|
|
|
|
|
"@defvar W_OK\n"
|
|
|
|
|
|
"test for write permission.\n"
|
|
|
|
|
|
"@end defvar\n"
|
|
|
|
|
|
"@defvar X_OK\n"
|
|
|
|
|
|
"test for execute permission.\n"
|
|
|
|
|
|
"@end defvar\n"
|
|
|
|
|
|
"@defvar F_OK\n"
|
|
|
|
|
|
"test for existence of the file.\n"
|
|
|
|
|
|
"@end defvar")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_access
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int rv;
|
|
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, path);
|
|
|
|
|
|
SCM_VALIDATE_INUM (2, how);
|
|
|
|
|
|
rv = access (SCM_STRING_CHARS (path), SCM_INUM (how));
|
1999-12-12 19:24:29 +00:00
|
|
|
|
return SCM_NEGATE_BOOL(rv);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_getpid, "getpid", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"Return an integer representing the current process ID.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_getpid
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
return SCM_MAKINUM ((unsigned long) getpid ());
|
|
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_putenv, "putenv", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM str),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Modifies the environment of the current process, which is\n"
|
|
|
|
|
|
"also the default environment inherited by child processes.\n\n"
|
|
|
|
|
|
"If @var{string} is of the form @code{NAME=VALUE} then it will be written\n"
|
|
|
|
|
|
"directly into the environment, replacing any existing environment string\n"
|
|
|
|
|
|
"with\n"
|
|
|
|
|
|
"name matching @code{NAME}. If @var{string} does not contain an equal\n"
|
|
|
|
|
|
"sign, then any existing string with name matching @var{string} will\n"
|
|
|
|
|
|
"be removed.\n\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_putenv
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2003-06-11 23:24:08 +00:00
|
|
|
|
int rv;
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
char *ptr;
|
1996-10-28 09:44:07 +00:00
|
|
|
|
|
2000-10-09 16:27:24 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, str);
|
2002-05-06 22:33:52 +00:00
|
|
|
|
|
|
|
|
|
|
if (strchr (SCM_STRING_CHARS (str), '=') == NULL)
|
|
|
|
|
|
{
|
2003-05-30 09:39:34 +00:00
|
|
|
|
#ifdef HAVE_UNSETENV
|
2002-05-06 22:33:52 +00:00
|
|
|
|
/* No '=' in argument means we should remove the variable from
|
2003-06-11 23:43:03 +00:00
|
|
|
|
the environment. Not all putenvs understand this (for instance
|
|
|
|
|
|
FreeBSD 4.8 doesn't). To be safe, we do it explicitely using
|
|
|
|
|
|
unsetenv. */
|
2002-05-06 22:33:52 +00:00
|
|
|
|
unsetenv (SCM_STRING_CHARS (str));
|
2003-05-30 09:39:34 +00:00
|
|
|
|
#else
|
|
|
|
|
|
/* On e.g. Win32 hosts putenv() called with 'name=' removes the
|
|
|
|
|
|
environment variable 'name'. */
|
2003-06-11 23:24:08 +00:00
|
|
|
|
int e;
|
2003-05-30 09:39:34 +00:00
|
|
|
|
ptr = scm_malloc (SCM_STRING_LENGTH (str) + 2);
|
2003-06-14 05:36:02 +00:00
|
|
|
|
if (ptr == NULL)
|
|
|
|
|
|
SCM_MEMORY_ERROR;
|
2003-05-30 09:39:34 +00:00
|
|
|
|
strncpy (ptr, SCM_STRING_CHARS (str), SCM_STRING_LENGTH (str));
|
|
|
|
|
|
ptr[SCM_STRING_LENGTH (str)] = '=';
|
|
|
|
|
|
ptr[SCM_STRING_LENGTH (str) + 1] = 0;
|
|
|
|
|
|
rv = putenv (ptr);
|
2003-06-11 23:15:02 +00:00
|
|
|
|
e = errno; free (ptr); errno = e;
|
2003-05-30 09:39:34 +00:00
|
|
|
|
if (rv < 0)
|
|
|
|
|
|
SCM_SYSERROR;
|
2003-06-14 05:36:02 +00:00
|
|
|
|
#endif /* !HAVE_UNSETENV */
|
2002-05-06 22:33:52 +00:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
/* must make a new copy to be left in the environment, safe from gc. */
|
2002-08-16 22:01:10 +00:00
|
|
|
|
ptr = scm_malloc (SCM_STRING_LENGTH (str) + 1);
|
2002-05-06 22:33:52 +00:00
|
|
|
|
if (ptr == NULL)
|
|
|
|
|
|
SCM_MEMORY_ERROR;
|
|
|
|
|
|
strncpy (ptr, SCM_STRING_CHARS (str), SCM_STRING_LENGTH (str));
|
2003-06-14 05:36:02 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
|
/* If str is "FOO=", ie. attempting to set an empty string, then
|
|
|
|
|
|
we need to see if it's been successful. On MINGW, "FOO="
|
|
|
|
|
|
means remove FOO from the environment. As a workaround, we
|
|
|
|
|
|
set "FOO= ", ie. a space, and then modify the string returned
|
|
|
|
|
|
by getenv. It's not enough just to modify the string we set,
|
|
|
|
|
|
because MINGW putenv copies it. */
|
|
|
|
|
|
if (ptr[SCM_STRING_LENGTH (str) - 1] == '=')
|
|
|
|
|
|
{
|
|
|
|
|
|
char *alt;
|
|
|
|
|
|
SCM name = scm_substring (str, SCM_MAKINUM (0),
|
|
|
|
|
|
SCM_MAKINUM (SCM_STRING_LENGTH (str) - 1));
|
|
|
|
|
|
if (getenv (SCM_STRING_CHARS (name)) == NULL)
|
|
|
|
|
|
{
|
|
|
|
|
|
alt = scm_malloc (SCM_STRING_LENGTH (str) + 2);
|
|
|
|
|
|
if (alt == NULL)
|
|
|
|
|
|
{
|
|
|
|
|
|
free (ptr);
|
|
|
|
|
|
SCM_MEMORY_ERROR;
|
|
|
|
|
|
}
|
|
|
|
|
|
memcpy (alt, SCM_STRING_CHARS (str), SCM_STRING_LENGTH (str));
|
|
|
|
|
|
alt[SCM_STRING_LENGTH (str)] = ' ';
|
|
|
|
|
|
alt[SCM_STRING_LENGTH (str) + 1] = '\0';
|
|
|
|
|
|
rv = putenv (alt);
|
|
|
|
|
|
if (rv < 0)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
free (ptr); /* don't need the old string we gave to putenv */
|
|
|
|
|
|
}
|
|
|
|
|
|
alt = getenv (SCM_STRING_CHARS (name));
|
|
|
|
|
|
alt[0] = '\0';
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* __MINGW32__ */
|
|
|
|
|
|
|
2002-05-06 22:33:52 +00:00
|
|
|
|
ptr[SCM_STRING_LENGTH (str)] = 0;
|
|
|
|
|
|
rv = putenv (ptr);
|
|
|
|
|
|
if (rv < 0)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
}
|
1996-10-28 09:44:07 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_SETLOCALE
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_setlocale, "setlocale", 1, 1, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM category, SCM locale),
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"If @var{locale} is omitted, return the current value of the\n"
|
|
|
|
|
|
"specified locale category as a system-dependent string.\n"
|
|
|
|
|
|
"@var{category} should be specified using the values\n"
|
|
|
|
|
|
"@code{LC_COLLATE}, @code{LC_ALL} etc.\n"
|
|
|
|
|
|
"\n"
|
|
|
|
|
|
"Otherwise the specified locale category is set to the string\n"
|
|
|
|
|
|
"@var{locale} and the new value is returned as a\n"
|
|
|
|
|
|
"system-dependent string. If @var{locale} is an empty string,\n"
|
2002-03-15 10:37:40 +00:00
|
|
|
|
"the locale will be set using environment variables.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_setlocale
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
char *clocale;
|
|
|
|
|
|
char *rv;
|
|
|
|
|
|
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, category);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
if (SCM_UNBNDP (locale))
|
|
|
|
|
|
{
|
|
|
|
|
|
clocale = NULL;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (2, locale);
|
|
|
|
|
|
clocale = SCM_STRING_CHARS (locale);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
rv = setlocale (SCM_INUM (category), clocale);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (rv == NULL)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return scm_makfrom0str (rv);
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_SETLOCALE */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_MKNOD
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_mknod, "mknod", 4, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM path, SCM type, SCM perms, SCM dev),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Creates a new special file, such as a file corresponding to a device.\n"
|
|
|
|
|
|
"@var{path} specifies the name of the file. @var{type} should\n"
|
|
|
|
|
|
"be one of the following symbols:\n"
|
|
|
|
|
|
"regular, directory, symlink, block-special, char-special,\n"
|
|
|
|
|
|
"fifo, or socket. @var{perms} (an integer) specifies the file permissions.\n"
|
|
|
|
|
|
"@var{dev} (an integer) specifies which device the special file refers\n"
|
|
|
|
|
|
"to. Its exact interpretation depends on the kind of special file\n"
|
|
|
|
|
|
"being created.\n\n"
|
|
|
|
|
|
"E.g.,\n"
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"@lisp\n"
|
2000-09-02 23:20:40 +00:00
|
|
|
|
"(mknod \"/dev/fd0\" 'block-special #o660 (+ (* 2 256) 2))\n"
|
2001-04-03 13:19:05 +00:00
|
|
|
|
"@end lisp\n\n"
|
2000-01-18 14:13:31 +00:00
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_mknod
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
int val;
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
char *p;
|
1998-10-03 14:12:59 +00:00
|
|
|
|
int ctype = 0;
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_VALIDATE_STRING (1, path);
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_SYMBOL (2, type);
|
|
|
|
|
|
SCM_VALIDATE_INUM (3, perms);
|
|
|
|
|
|
SCM_VALIDATE_INUM (4, dev);
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
|
2000-09-22 17:17:55 +00:00
|
|
|
|
p = SCM_SYMBOL_CHARS (type);
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
if (strcmp (p, "regular") == 0)
|
|
|
|
|
|
ctype = S_IFREG;
|
|
|
|
|
|
else if (strcmp (p, "directory") == 0)
|
|
|
|
|
|
ctype = S_IFDIR;
|
|
|
|
|
|
else if (strcmp (p, "symlink") == 0)
|
|
|
|
|
|
ctype = S_IFLNK;
|
|
|
|
|
|
else if (strcmp (p, "block-special") == 0)
|
|
|
|
|
|
ctype = S_IFBLK;
|
|
|
|
|
|
else if (strcmp (p, "char-special") == 0)
|
|
|
|
|
|
ctype = S_IFCHR;
|
|
|
|
|
|
else if (strcmp (p, "fifo") == 0)
|
|
|
|
|
|
ctype = S_IFIFO;
|
2000-09-30 15:51:49 +00:00
|
|
|
|
#ifdef S_IFSOCK
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
else if (strcmp (p, "socket") == 0)
|
|
|
|
|
|
ctype = S_IFSOCK;
|
2000-09-30 15:51:49 +00:00
|
|
|
|
#endif
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
else
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_OUT_OF_RANGE (2, type);
|
* posix.c (scm_putenv): don't check HAVE_PUTENV.
* Makefile.am (EXTRA_libguile_la_SOURCES): add putenv.c.
* configure.in: move putenv from AC_CHECK_FUNCS to AC_REPLACE_FUNCS.
* putenv.c: new file, from sh-utils 1.12.
* posix.c (scm_environ): use malloc in place of scm_must_malloc
since allocation isn't for Scheme objects.
(scm_putenv): copy strings before placing in the environment.
* stime.c (scm_current_time): throw an error if time returns -1,
instead of returning #f.
(scm_get_internal_real_time, scm_get_internal_real_time): use
scm_long2num for return value instead of SCM_MAKINUM.
* stime.h: prototypes updated.
* stime.c (scm_time_in_msec): apparently unused, deleted.
* configure.in: check for gettimeofday.
* stime.c (scm_time_plus_ticks): new procedure, an scsh interface
which may be more usefully portable than a gettimeofday interface.
* stime.c (filltime): recovered static procedure.
(scm_localtime, scm_gmtime, scm_mktime, scm_tzset): recovered from
an earlier Guile.
* posix.h: add prototype for scm_close_pipe, remove prototypes for
scm_open_input_pipe, scm_open_output_pipe, change scm_mknod prototype.
* * posix.c (scm_mknod): split the mode argument into type and perms
arguments, like the extra fields returned by stat.
* fports.c (scm_pipob): set the close, free and print procedures.
(scm_close_pipe): new procedure.
* posix.c (scm_open_input_pipe, scm_open_output_pipe): deleted,
define them in boot-9.scm
1997-04-05 21:50:31 +00:00
|
|
|
|
|
2000-10-30 11:42:26 +00:00
|
|
|
|
SCM_SYSCALL (val = mknod (SCM_STRING_CHARS (path), ctype | SCM_INUM (perms),
|
|
|
|
|
|
SCM_INUM (dev)));
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (val != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_MKNOD */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_NICE
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_nice, "nice", 1, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(SCM incr),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Increment the priority of the current process by @var{incr}. A higher\n"
|
|
|
|
|
|
"priority value means that the process runs less often.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_nice
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
2002-07-20 14:08:34 +00:00
|
|
|
|
SCM_VALIDATE_INUM (1, incr);
|
1996-08-02 23:26:33 +00:00
|
|
|
|
if (nice(SCM_INUM(incr)) != 0)
|
1999-12-12 02:36:16 +00:00
|
|
|
|
SCM_SYSERROR;
|
1996-08-02 23:26:33 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_NICE */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#ifdef HAVE_SYNC
|
2000-01-05 19:05:23 +00:00
|
|
|
|
SCM_DEFINE (scm_sync, "sync", 0, 0, 0,
|
1999-12-12 02:36:16 +00:00
|
|
|
|
(),
|
* alist.c, chars.c, debug.c, dynl.c, dynwind.c, error.c, eval.c,
evalext.c, filesys.c, gc.c, hash.c, hashtab.c, ioext.c,
keywords.c, list.c, load.c, macros.c, net_db.c, numbers.c,
objprop.c, ports.c, posix.c, print.c, procprop.c, procs.c,
ramap.c, regex-posix.c, root.c, scmsigs.c, simpos.c, socket.c,
stacks.c, stime.c, strings.c, strop.c, strports.c, struct.c,
symbols.c, throw.c, unif.c, vectors.c, version.c, vports.c,
weaks.c: Converted docstrings to ANSI C format.
2000-01-18 11:24:03 +00:00
|
|
|
|
"Flush the operating system disk buffers.\n"
|
|
|
|
|
|
"The return value is unspecified.")
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#define FUNC_NAME s_scm_sync
|
1996-07-25 22:56:11 +00:00
|
|
|
|
{
|
|
|
|
|
|
sync();
|
2000-01-09 16:09:15 +00:00
|
|
|
|
return SCM_UNSPECIFIED;
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
1999-12-12 02:36:16 +00:00
|
|
|
|
#undef FUNC_NAME
|
* eval.c: define scm_unbound_variable_key ('unbound-variable).
scm_lookupcar1: throw an error with key 'unbound-variable instead
of 'misc-error when an unbound variable is encountered.
* filesys.c (scm_mkdir, scm_rmdir, scm_getcwd, scm_select,
scm_symlink, scm_readlink, scm_lstat),
posix.c (scm_setpgid, scm_setsid, scm_ctermid, scm_tcgetpgrp,
scm_tcsetpgrp, scm_uname, scm_setlocale, scm_mknod, scm_nice,
scm_sync),
simpos.c (scm_system),
stime.c (scm_times, scm_strptime):
move the HAVE_XXX feature tests out of the procedure bodies.
don't use SCM_SYSMISSING.
scm_validate.h (SCM_SYSMISSING): removed.
error.h, error.c (scm_sysmissing): comment that this is deprecated.
see ChangeLog entry for 1999-12-28.
2000-01-09 13:41:53 +00:00
|
|
|
|
#endif /* HAVE_SYNC */
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#if HAVE_LIBCRYPT && HAVE_CRYPT_H
|
|
|
|
|
|
SCM_DEFINE (scm_crypt, "crypt", 2, 0, 0,
|
|
|
|
|
|
(SCM key, SCM salt),
|
|
|
|
|
|
"Encrypt @var{key} using @var{salt} as the salt value to the\n"
|
2001-11-11 15:01:52 +00:00
|
|
|
|
"crypt(3) library call.")
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#define FUNC_NAME s_scm_crypt
|
|
|
|
|
|
{
|
|
|
|
|
|
char * p;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_STRING (1, key);
|
|
|
|
|
|
SCM_VALIDATE_STRING (2, salt);
|
|
|
|
|
|
|
|
|
|
|
|
p = crypt (SCM_STRING_CHARS (key), SCM_STRING_CHARS (salt));
|
|
|
|
|
|
return scm_makfrom0str (p);
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_LIBCRYPT && HAVE_CRYPT_H */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_CHROOT
|
|
|
|
|
|
SCM_DEFINE (scm_chroot, "chroot", 1, 0, 0,
|
|
|
|
|
|
(SCM path),
|
|
|
|
|
|
"Change the root directory to that specified in @var{path}.\n"
|
|
|
|
|
|
"This directory will be used for path names beginning with\n"
|
|
|
|
|
|
"@file{/}. The root directory is inherited by all children\n"
|
|
|
|
|
|
"of the current process. Only the superuser may change the\n"
|
|
|
|
|
|
"root directory.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_chroot
|
|
|
|
|
|
{
|
|
|
|
|
|
SCM_VALIDATE_STRING (1, path);
|
|
|
|
|
|
|
|
|
|
|
|
if (chroot (SCM_STRING_CHARS (path)) == -1)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_CHROOT */
|
|
|
|
|
|
|
2001-07-03 15:27:56 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
|
/* Wrapper function to supplying `getlogin()' under Windows. */
|
|
|
|
|
|
static char * getlogin (void)
|
|
|
|
|
|
{
|
|
|
|
|
|
static char user[256];
|
|
|
|
|
|
static unsigned long len = 256;
|
|
|
|
|
|
|
|
|
|
|
|
if (!GetUserName (user, &len))
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
return user;
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* __MINGW32__ */
|
|
|
|
|
|
|
|
|
|
|
|
|
2001-11-02 00:16:46 +00:00
|
|
|
|
#if defined (HAVE_GETLOGIN) || defined (__MINGW32__)
|
2001-03-09 10:03:47 +00:00
|
|
|
|
SCM_DEFINE (scm_getlogin, "getlogin", 0, 0, 0,
|
|
|
|
|
|
(void),
|
|
|
|
|
|
"Return a string containing the name of the user logged in on\n"
|
|
|
|
|
|
"the controlling terminal of the process, or @code{#f} if this\n"
|
|
|
|
|
|
"information cannot be obtained.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_getlogin
|
|
|
|
|
|
{
|
|
|
|
|
|
char * p;
|
|
|
|
|
|
|
|
|
|
|
|
p = getlogin ();
|
|
|
|
|
|
if (!p || !*p)
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
return scm_makfrom0str (p);
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_GETLOGIN */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_CUSERID
|
|
|
|
|
|
SCM_DEFINE (scm_cuserid, "cuserid", 0, 0, 0,
|
|
|
|
|
|
(void),
|
|
|
|
|
|
"Return a string containing a user name associated with the\n"
|
|
|
|
|
|
"effective user id of the process. Return @code{#f} if this\n"
|
|
|
|
|
|
"information cannot be obtained.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_cuserid
|
|
|
|
|
|
{
|
|
|
|
|
|
char * p;
|
|
|
|
|
|
|
|
|
|
|
|
p = cuserid (NULL);
|
|
|
|
|
|
if (!p || !*p)
|
|
|
|
|
|
return SCM_BOOL_F;
|
|
|
|
|
|
return scm_makfrom0str (p);
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_CUSERID */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_GETPRIORITY
|
|
|
|
|
|
SCM_DEFINE (scm_getpriority, "getpriority", 2, 0, 0,
|
|
|
|
|
|
(SCM which, SCM who),
|
|
|
|
|
|
"Return the scheduling priority of the process, process group\n"
|
|
|
|
|
|
"or user, as indicated by @var{which} and @var{who}. @var{which}\n"
|
|
|
|
|
|
"is one of the variables @code{PRIO_PROCESS}, @code{PRIO_PGRP}\n"
|
|
|
|
|
|
"or @code{PRIO_USER}, and @var{who} is interpreted relative to\n"
|
|
|
|
|
|
"@var{which} (a process identifier for @code{PRIO_PROCESS},\n"
|
|
|
|
|
|
"process group identifier for @code{PRIO_PGRP}, and a user\n"
|
|
|
|
|
|
"identifier for @code{PRIO_USER}. A zero value of @var{who}\n"
|
|
|
|
|
|
"denotes the current process, process group, or user. Return\n"
|
|
|
|
|
|
"the highest priority (lowest numerical value) of any of the\n"
|
|
|
|
|
|
"specified processes.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_getpriority
|
|
|
|
|
|
{
|
|
|
|
|
|
int cwhich, cwho, ret;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (1, which, cwhich);
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (2, who, cwho);
|
|
|
|
|
|
|
|
|
|
|
|
/* We have to clear errno and examine it later, because -1 is a
|
|
|
|
|
|
legal return value for getpriority(). */
|
|
|
|
|
|
errno = 0;
|
|
|
|
|
|
ret = getpriority (cwhich, cwho);
|
|
|
|
|
|
if (errno != 0)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_MAKINUM (ret);
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_GETPRIORITY */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_SETPRIORITY
|
|
|
|
|
|
SCM_DEFINE (scm_setpriority, "setpriority", 3, 0, 0,
|
|
|
|
|
|
(SCM which, SCM who, SCM prio),
|
|
|
|
|
|
"Set the scheduling priority of the process, process group\n"
|
|
|
|
|
|
"or user, as indicated by @var{which} and @var{who}. @var{which}\n"
|
|
|
|
|
|
"is one of the variables @code{PRIO_PROCESS}, @code{PRIO_PGRP}\n"
|
|
|
|
|
|
"or @code{PRIO_USER}, and @var{who} is interpreted relative to\n"
|
|
|
|
|
|
"@var{which} (a process identifier for @code{PRIO_PROCESS},\n"
|
|
|
|
|
|
"process group identifier for @code{PRIO_PGRP}, and a user\n"
|
|
|
|
|
|
"identifier for @code{PRIO_USER}. A zero value of @var{who}\n"
|
|
|
|
|
|
"denotes the current process, process group, or user.\n"
|
|
|
|
|
|
"@var{prio} is a value in the range -20 and 20, the default\n"
|
|
|
|
|
|
"priority is 0; lower priorities cause more favorable\n"
|
|
|
|
|
|
"scheduling. Sets the priority of all of the specified\n"
|
|
|
|
|
|
"processes. Only the super-user may lower priorities.\n"
|
|
|
|
|
|
"The return value is not specified.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_setpriority
|
|
|
|
|
|
{
|
|
|
|
|
|
int cwhich, cwho, cprio;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (1, which, cwhich);
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (2, who, cwho);
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (3, prio, cprio);
|
|
|
|
|
|
|
|
|
|
|
|
if (setpriority (cwhich, cwho, cprio) == -1)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_SETPRIORITY */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_GETPASS
|
|
|
|
|
|
SCM_DEFINE (scm_getpass, "getpass", 1, 0, 0,
|
|
|
|
|
|
(SCM prompt),
|
|
|
|
|
|
"Display @var{prompt} to the standard error output and read\n"
|
|
|
|
|
|
"a password from @file{/dev/tty}. If this file is not\n"
|
|
|
|
|
|
"accessible, it reads from standard input. The password may be\n"
|
|
|
|
|
|
"up to 127 characters in length. Additional characters and the\n"
|
|
|
|
|
|
"terminating newline character are discarded. While reading\n"
|
|
|
|
|
|
"the password, echoing and the generation of signals by special\n"
|
|
|
|
|
|
"characters is disabled.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_getpass
|
|
|
|
|
|
{
|
|
|
|
|
|
char * p;
|
|
|
|
|
|
SCM passwd;
|
|
|
|
|
|
|
|
|
|
|
|
SCM_VALIDATE_STRING (1, prompt);
|
|
|
|
|
|
|
|
|
|
|
|
p = getpass(SCM_STRING_CHARS (prompt));
|
|
|
|
|
|
passwd = scm_makfrom0str (p);
|
|
|
|
|
|
|
|
|
|
|
|
/* Clear out the password in the static buffer. */
|
|
|
|
|
|
memset (p, 0, strlen (p));
|
|
|
|
|
|
|
|
|
|
|
|
return passwd;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_GETPASS */
|
|
|
|
|
|
|
2001-11-04 15:52:30 +00:00
|
|
|
|
/* Wrapper function for flock() support under M$-Windows. */
|
|
|
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
|
# include <io.h>
|
|
|
|
|
|
# include <sys/locking.h>
|
|
|
|
|
|
# include <errno.h>
|
|
|
|
|
|
# ifndef _LK_UNLCK
|
|
|
|
|
|
/* Current MinGW package fails to define this. *sigh* */
|
|
|
|
|
|
# define _LK_UNLCK 0
|
|
|
|
|
|
# endif
|
|
|
|
|
|
# define LOCK_EX 1
|
|
|
|
|
|
# define LOCK_UN 2
|
|
|
|
|
|
# define LOCK_SH 4
|
|
|
|
|
|
# define LOCK_NB 8
|
|
|
|
|
|
|
|
|
|
|
|
static int flock (int fd, int operation)
|
|
|
|
|
|
{
|
|
|
|
|
|
long pos, len;
|
|
|
|
|
|
int ret, err;
|
|
|
|
|
|
|
|
|
|
|
|
/* Disable invalid arguments. */
|
|
|
|
|
|
if (((operation & (LOCK_EX | LOCK_SH)) == (LOCK_EX | LOCK_SH)) ||
|
|
|
|
|
|
((operation & (LOCK_EX | LOCK_UN)) == (LOCK_EX | LOCK_UN)) ||
|
|
|
|
|
|
((operation & (LOCK_SH | LOCK_UN)) == (LOCK_SH | LOCK_UN)))
|
|
|
|
|
|
{
|
|
|
|
|
|
errno = EINVAL;
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Determine mode of operation and discard unsupported ones. */
|
|
|
|
|
|
if (operation == (LOCK_NB | LOCK_EX))
|
|
|
|
|
|
operation = _LK_NBLCK;
|
|
|
|
|
|
else if (operation & LOCK_UN)
|
|
|
|
|
|
operation = _LK_UNLCK;
|
|
|
|
|
|
else if (operation == LOCK_EX)
|
|
|
|
|
|
operation = _LK_LOCK;
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
errno = EINVAL;
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Save current file pointer and seek to beginning. */
|
|
|
|
|
|
if ((pos = lseek (fd, 0, SEEK_CUR)) == -1 || (len = filelength (fd)) == -1)
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
lseek (fd, 0L, SEEK_SET);
|
|
|
|
|
|
|
|
|
|
|
|
/* Deadlock if necessary. */
|
|
|
|
|
|
do
|
|
|
|
|
|
{
|
|
|
|
|
|
ret = _locking (fd, operation, len);
|
|
|
|
|
|
}
|
|
|
|
|
|
while (ret == -1 && errno == EDEADLOCK);
|
|
|
|
|
|
|
|
|
|
|
|
/* Produce meaningful error message. */
|
|
|
|
|
|
if (errno == EACCES && operation == _LK_NBLCK)
|
|
|
|
|
|
err = EDEADLOCK;
|
|
|
|
|
|
else
|
|
|
|
|
|
err = errno;
|
|
|
|
|
|
|
|
|
|
|
|
/* Return to saved file position pointer. */
|
|
|
|
|
|
lseek (fd, pos, SEEK_SET);
|
|
|
|
|
|
errno = err;
|
|
|
|
|
|
return ret;
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* __MINGW32__ */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_FLOCK || defined (__MINGW32__)
|
2001-03-09 10:03:47 +00:00
|
|
|
|
SCM_DEFINE (scm_flock, "flock", 2, 0, 0,
|
|
|
|
|
|
(SCM file, SCM operation),
|
|
|
|
|
|
"Apply or remove an advisory lock on an open file.\n"
|
|
|
|
|
|
"@var{operation} specifies the action to be done:\n"
|
|
|
|
|
|
"@table @code\n"
|
|
|
|
|
|
"@item LOCK_SH\n"
|
|
|
|
|
|
"Shared lock. More than one process may hold a shared lock\n"
|
|
|
|
|
|
"for a given file at a given time.\n"
|
|
|
|
|
|
"@item LOCK_EX\n"
|
|
|
|
|
|
"Exclusive lock. Only one process may hold an exclusive lock\n"
|
|
|
|
|
|
"for a given file at a given time.\n"
|
|
|
|
|
|
"@item LOCK_UN\n"
|
|
|
|
|
|
"Unlock the file.\n"
|
|
|
|
|
|
"@item LOCK_NB\n"
|
|
|
|
|
|
"Don't block when locking. May be specified by bitwise OR'ing\n"
|
|
|
|
|
|
"it to one of the other operations.\n"
|
|
|
|
|
|
"@end table\n"
|
|
|
|
|
|
"The return value is not specified. @var{file} may be an open\n"
|
2002-03-15 10:37:40 +00:00
|
|
|
|
"file descriptor or an open file descriptor port.")
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#define FUNC_NAME s_scm_flock
|
|
|
|
|
|
{
|
|
|
|
|
|
int coperation, fdes;
|
|
|
|
|
|
|
|
|
|
|
|
if (SCM_INUMP (file))
|
|
|
|
|
|
fdes = SCM_INUM (file);
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
SCM_VALIDATE_OPFPORT (2, file);
|
|
|
|
|
|
|
|
|
|
|
|
fdes = SCM_FPORT_FDES (file);
|
|
|
|
|
|
}
|
|
|
|
|
|
SCM_VALIDATE_INUM_COPY (2, operation, coperation);
|
|
|
|
|
|
if (flock (fdes, coperation) == -1)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_FLOCK */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_SETHOSTNAME
|
|
|
|
|
|
SCM_DEFINE (scm_sethostname, "sethostname", 1, 0, 0,
|
|
|
|
|
|
(SCM name),
|
|
|
|
|
|
"Set the host name of the current processor to @var{name}. May\n"
|
|
|
|
|
|
"only be used by the superuser. The return value is not\n"
|
|
|
|
|
|
"specified.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_sethostname
|
|
|
|
|
|
{
|
|
|
|
|
|
SCM_VALIDATE_STRING (1, name);
|
|
|
|
|
|
|
|
|
|
|
|
if (sethostname (SCM_STRING_CHARS (name), SCM_STRING_LENGTH (name)) == -1)
|
|
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
return SCM_UNSPECIFIED;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_SETHOSTNAME */
|
|
|
|
|
|
|
|
|
|
|
|
#if HAVE_GETHOSTNAME
|
|
|
|
|
|
SCM_DEFINE (scm_gethostname, "gethostname", 0, 0, 0,
|
|
|
|
|
|
(void),
|
|
|
|
|
|
"Return the host name of the current processor.")
|
|
|
|
|
|
#define FUNC_NAME s_scm_gethostname
|
|
|
|
|
|
{
|
2001-03-09 12:09:17 +00:00
|
|
|
|
/* 256 is for Solaris, under Linux ENAMETOOLONG is returned if not
|
|
|
|
|
|
large enough. */
|
|
|
|
|
|
int len = 256, res;
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
char *p = scm_malloc (len);
|
2001-03-09 10:03:47 +00:00
|
|
|
|
SCM name;
|
|
|
|
|
|
|
|
|
|
|
|
res = gethostname (p, len);
|
|
|
|
|
|
while (res == -1 && errno == ENAMETOOLONG)
|
|
|
|
|
|
{
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
p = scm_realloc (p, len * 2);
|
2001-03-09 10:03:47 +00:00
|
|
|
|
len *= 2;
|
|
|
|
|
|
res = gethostname (p, len);
|
|
|
|
|
|
}
|
|
|
|
|
|
if (res == -1)
|
|
|
|
|
|
{
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
free (p);
|
2001-03-09 10:03:47 +00:00
|
|
|
|
SCM_SYSERROR;
|
|
|
|
|
|
}
|
|
|
|
|
|
name = scm_makfrom0str (p);
|
* gc.h, gc.c (scm_gc_sweep): Issue deprecation warning when
non-zero is returned from a port or smob free function.
(scm_malloc, scm_realloc, scm_strndup, scm_strdup,
scm_gc_register_collectable_memory,
scm_gc_unregister_collectable_memory, scm_gc_malloc,
scm_gc_realloc, scm_gc_free, scm_gc_strndup, scm_gc_strdup): New.
* backtrace.c, continuations.c, convert.i.c, coop-threads.c,
debug-malloc.c, dynl.c, environments.c, environments.h,
extensions.c, filesys.c, fports.c, gc.c, gc.h, gh_data.c, goops.c,
guardians.c, hooks.c, init.c, keywords.c, load.c, numbers.c,
ports.c, posix.c, procs.c, rdelim.c, regex-posix.c, root.c,
smob.c, stime.c, strings.c, struct.c, struct.h, symbols.c, unif.c,
vectors.c, weaks.c: Use scm_gc_malloc/scm_malloc and
scm_gc_free/free instead of scm_must_malloc and scm_must_free, as
appropriate. Return zero from smob and port free functions.
* debug-malloc.c (scm_malloc_reregister): Handle "old == NULL".
* fports.c (scm_setvbuf): Reset read buffer to saved values when
it is pointing to the putback buffer.
2002-02-11 18:06:50 +00:00
|
|
|
|
free (p);
|
2001-03-09 10:03:47 +00:00
|
|
|
|
return name;
|
|
|
|
|
|
}
|
|
|
|
|
|
#undef FUNC_NAME
|
|
|
|
|
|
#endif /* HAVE_GETHOSTNAME */
|
|
|
|
|
|
|
1996-07-25 22:56:11 +00:00
|
|
|
|
void
|
|
|
|
|
|
scm_init_posix ()
|
|
|
|
|
|
{
|
|
|
|
|
|
scm_add_feature ("posix");
|
|
|
|
|
|
#ifdef HAVE_GETEUID
|
|
|
|
|
|
scm_add_feature ("EIDs");
|
|
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef WAIT_ANY
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("WAIT_ANY", SCM_MAKINUM (WAIT_ANY));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef WAIT_MYPGRP
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("WAIT_MYPGRP", SCM_MAKINUM (WAIT_MYPGRP));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef WNOHANG
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("WNOHANG", SCM_MAKINUM (WNOHANG));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef WUNTRACED
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("WUNTRACED", SCM_MAKINUM (WUNTRACED));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/* access() symbols. */
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("R_OK", SCM_MAKINUM (R_OK));
|
|
|
|
|
|
scm_c_define ("W_OK", SCM_MAKINUM (W_OK));
|
|
|
|
|
|
scm_c_define ("X_OK", SCM_MAKINUM (X_OK));
|
|
|
|
|
|
scm_c_define ("F_OK", SCM_MAKINUM (F_OK));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
|
|
|
|
|
|
#ifdef LC_COLLATE
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_COLLATE", SCM_MAKINUM (LC_COLLATE));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_CTYPE
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_CTYPE", SCM_MAKINUM (LC_CTYPE));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_MONETARY
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_MONETARY", SCM_MAKINUM (LC_MONETARY));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_NUMERIC
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_NUMERIC", SCM_MAKINUM (LC_NUMERIC));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_TIME
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_TIME", SCM_MAKINUM (LC_TIME));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_MESSAGES
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_MESSAGES", SCM_MAKINUM (LC_MESSAGES));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LC_ALL
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LC_ALL", SCM_MAKINUM (LC_ALL));
|
1996-07-25 22:56:11 +00:00
|
|
|
|
#endif
|
* strings.h: don't use SCM_P. don't include <string.h>.
* error.c, gh_data.c, ports.c, script.c, strop.c: include <string.h>.
* strings.c (scm_string_ref): make the 2nd argument compulsory.
previously it defaulted to zero for no good reason that I can see.
use a local variable for SCM_INUM (k). replace
SCM_VALIDATE_INUM_DEF with SCM_VALIDATE_INUM_COPY.
(scm_makfromstr): cosmetic changes.
(scm_string): Accept only chars in the list, not strings, for
conformance to R5RS (particularly for list->string, which is
supposed to be the inverse of string->list.) remove
SCM_DEFER_INTS/SCM_ALLOW_INTS, which is unnecessary since
scm_makstr handles the cell allocation. when reporting wrong-type
arg, don't report the position as 1.
* posix.c (scm_init_posix): intern PIPE_BUF if it's defined.
* boot-9.scm (find-and-link-dynamic-module): pass strings, not symbols,
to string-append.
2000-01-31 18:29:56 +00:00
|
|
|
|
#ifdef PIPE_BUF
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("PIPE_BUF", scm_long2num (PIPE_BUF));
|
* strings.h: don't use SCM_P. don't include <string.h>.
* error.c, gh_data.c, ports.c, script.c, strop.c: include <string.h>.
* strings.c (scm_string_ref): make the 2nd argument compulsory.
previously it defaulted to zero for no good reason that I can see.
use a local variable for SCM_INUM (k). replace
SCM_VALIDATE_INUM_DEF with SCM_VALIDATE_INUM_COPY.
(scm_makfromstr): cosmetic changes.
(scm_string): Accept only chars in the list, not strings, for
conformance to R5RS (particularly for list->string, which is
supposed to be the inverse of string->list.) remove
SCM_DEFER_INTS/SCM_ALLOW_INTS, which is unnecessary since
scm_makstr handles the cell allocation. when reporting wrong-type
arg, don't report the position as 1.
* posix.c (scm_init_posix): intern PIPE_BUF if it's defined.
* boot-9.scm (find-and-link-dynamic-module): pass strings, not symbols,
to string-append.
2000-01-31 18:29:56 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#ifdef PRIO_PROCESS
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("PRIO_PROCESS", SCM_MAKINUM (PRIO_PROCESS));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef PRIO_PGRP
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("PRIO_PGRP", SCM_MAKINUM (PRIO_PGRP));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef PRIO_USER
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("PRIO_USER", SCM_MAKINUM (PRIO_USER));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef LOCK_SH
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LOCK_SH", SCM_MAKINUM (LOCK_SH));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LOCK_EX
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LOCK_EX", SCM_MAKINUM (LOCK_EX));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LOCK_UN
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LOCK_UN", SCM_MAKINUM (LOCK_UN));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
#ifdef LOCK_NB
|
2001-05-15 14:57:22 +00:00
|
|
|
|
scm_c_define ("LOCK_NB", SCM_MAKINUM (LOCK_NB));
|
2001-03-09 10:03:47 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
2000-04-21 14:16:44 +00:00
|
|
|
|
#include "libguile/cpp_sig_symbols.c"
|
|
|
|
|
|
#include "libguile/posix.x"
|
1996-07-25 22:56:11 +00:00
|
|
|
|
}
|
2000-03-19 19:01:16 +00:00
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
Local Variables:
|
|
|
|
|
|
c-file-style: "gnu"
|
|
|
|
|
|
End:
|
|
|
|
|
|
*/
|