mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-12 14:50:19 +02:00
Inline scm_getc',
scm_putc' and `scm_puts'.
This commit is contained in:
parent
c3455f571a
commit
f5c2af4be0
5 changed files with 89 additions and 68 deletions
1
NEWS
1
NEWS
|
@ -49,6 +49,7 @@ http://git.sv.gnu.org/gitweb/?p=guile.git . See `README' for details.
|
||||||
* New features (see the manual for details)
|
* New features (see the manual for details)
|
||||||
|
|
||||||
** New `postfix' read option, for SRFI-88 keyword syntax
|
** New `postfix' read option, for SRFI-88 keyword syntax
|
||||||
|
** Some I/O primitives have been inlined, which improves I/O performance
|
||||||
|
|
||||||
* Bugs fixed
|
* Bugs fixed
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,8 @@
|
||||||
|
2008-04-16 Ludovic Courtès <ludo@gnu.org>
|
||||||
|
|
||||||
|
* ports.c (scm_getc, scm_putc, scm_puts): Moved...
|
||||||
|
* inline.h: ... here. Noticeably improves `read' performance.
|
||||||
|
|
||||||
2008-04-15 Ludovic Courtès <ludo@gnu.org>
|
2008-04-15 Ludovic Courtès <ludo@gnu.org>
|
||||||
Julian Graham <joolean@gmail.com>
|
Julian Graham <joolean@gmail.com>
|
||||||
|
|
||||||
|
|
|
@ -25,17 +25,17 @@
|
||||||
"inline.c".
|
"inline.c".
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libguile/__scm.h"
|
|
||||||
|
|
||||||
#if (SCM_DEBUG_CELL_ACCESSES == 1)
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#endif
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "libguile/__scm.h"
|
||||||
|
|
||||||
#include "libguile/pairs.h"
|
#include "libguile/pairs.h"
|
||||||
#include "libguile/gc.h"
|
#include "libguile/gc.h"
|
||||||
#include "libguile/threads.h"
|
#include "libguile/threads.h"
|
||||||
#include "libguile/unif.h"
|
#include "libguile/unif.h"
|
||||||
#include "libguile/pairs.h"
|
#include "libguile/ports.h"
|
||||||
|
#include "libguile/error.h"
|
||||||
|
|
||||||
|
|
||||||
#ifndef SCM_INLINE_C_INCLUDING_INLINE_H
|
#ifndef SCM_INLINE_C_INCLUDING_INLINE_H
|
||||||
|
@ -85,6 +85,10 @@ SCM_API void scm_array_handle_set (scm_t_array_handle *h, ssize_t pos, SCM val);
|
||||||
|
|
||||||
SCM_API int scm_is_pair (SCM x);
|
SCM_API int scm_is_pair (SCM x);
|
||||||
|
|
||||||
|
SCM_API int scm_getc (SCM port);
|
||||||
|
SCM_API void scm_putc (char c, SCM port);
|
||||||
|
SCM_API void scm_puts (const char *str_data, SCM port);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
@ -285,5 +289,77 @@ scm_is_pair (SCM x)
|
||||||
return SCM_I_CONSP (x);
|
return SCM_I_CONSP (x);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Port I/O. */
|
||||||
|
|
||||||
|
#ifndef SCM_INLINE_C_INCLUDING_INLINE_H
|
||||||
|
SCM_C_EXTERN_INLINE
|
||||||
|
#endif
|
||||||
|
int
|
||||||
|
scm_getc (SCM port)
|
||||||
|
{
|
||||||
|
int c;
|
||||||
|
scm_t_port *pt = SCM_PTAB_ENTRY (port);
|
||||||
|
|
||||||
|
if (pt->rw_active == SCM_PORT_WRITE)
|
||||||
|
/* may be marginally faster than calling scm_flush. */
|
||||||
|
scm_ptobs[SCM_PTOBNUM (port)].flush (port);
|
||||||
|
|
||||||
|
if (pt->rw_random)
|
||||||
|
pt->rw_active = SCM_PORT_READ;
|
||||||
|
|
||||||
|
if (pt->read_pos >= pt->read_end)
|
||||||
|
{
|
||||||
|
if (scm_fill_input (port) == EOF)
|
||||||
|
return EOF;
|
||||||
|
}
|
||||||
|
|
||||||
|
c = *(pt->read_pos++);
|
||||||
|
|
||||||
|
switch (c)
|
||||||
|
{
|
||||||
|
case '\a':
|
||||||
|
break;
|
||||||
|
case '\b':
|
||||||
|
SCM_DECCOL (port);
|
||||||
|
break;
|
||||||
|
case '\n':
|
||||||
|
SCM_INCLINE (port);
|
||||||
|
break;
|
||||||
|
case '\r':
|
||||||
|
SCM_ZEROCOL (port);
|
||||||
|
break;
|
||||||
|
case '\t':
|
||||||
|
SCM_TABCOL (port);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
SCM_INCCOL (port);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef SCM_INLINE_C_INCLUDING_INLINE_H
|
||||||
|
SCM_C_EXTERN_INLINE
|
||||||
|
#endif
|
||||||
|
void
|
||||||
|
scm_putc (char c, SCM port)
|
||||||
|
{
|
||||||
|
SCM_ASSERT_TYPE (SCM_OPOUTPORTP (port), port, 0, NULL, "output port");
|
||||||
|
scm_lfwrite (&c, 1, port);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef SCM_INLINE_C_INCLUDING_INLINE_H
|
||||||
|
SCM_C_EXTERN_INLINE
|
||||||
|
#endif
|
||||||
|
void
|
||||||
|
scm_puts (const char *s, SCM port)
|
||||||
|
{
|
||||||
|
SCM_ASSERT_TYPE (SCM_OPOUTPORTP (port), port, 0, NULL, "output port");
|
||||||
|
scm_lfwrite (s, strlen (s), port);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001, 2003, 2004, 2006, 2007 Free Software Foundation, Inc.
|
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001, 2003, 2004, 2006, 2007, 2008 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
@ -960,64 +960,6 @@ scm_fill_input (SCM port)
|
||||||
return scm_ptobs[SCM_PTOBNUM (port)].fill_input (port);
|
return scm_ptobs[SCM_PTOBNUM (port)].fill_input (port);
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
|
||||||
scm_getc (SCM port)
|
|
||||||
{
|
|
||||||
int c;
|
|
||||||
scm_t_port *pt = SCM_PTAB_ENTRY (port);
|
|
||||||
|
|
||||||
if (pt->rw_active == SCM_PORT_WRITE)
|
|
||||||
/* may be marginally faster than calling scm_flush. */
|
|
||||||
scm_ptobs[SCM_PTOBNUM (port)].flush (port);
|
|
||||||
|
|
||||||
if (pt->rw_random)
|
|
||||||
pt->rw_active = SCM_PORT_READ;
|
|
||||||
|
|
||||||
if (pt->read_pos >= pt->read_end)
|
|
||||||
{
|
|
||||||
if (scm_fill_input (port) == EOF)
|
|
||||||
return EOF;
|
|
||||||
}
|
|
||||||
|
|
||||||
c = *(pt->read_pos++);
|
|
||||||
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '\a':
|
|
||||||
break;
|
|
||||||
case '\b':
|
|
||||||
SCM_DECCOL (port);
|
|
||||||
break;
|
|
||||||
case '\n':
|
|
||||||
SCM_INCLINE (port);
|
|
||||||
break;
|
|
||||||
case '\r':
|
|
||||||
SCM_ZEROCOL (port);
|
|
||||||
break;
|
|
||||||
case '\t':
|
|
||||||
SCM_TABCOL (port);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
SCM_INCCOL (port);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return c;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
scm_putc (char c, SCM port)
|
|
||||||
{
|
|
||||||
SCM_ASSERT_TYPE (SCM_OPOUTPORTP (port), port, 0, NULL, "output port");
|
|
||||||
scm_lfwrite (&c, 1, port);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
scm_puts (const char *s, SCM port)
|
|
||||||
{
|
|
||||||
SCM_ASSERT_TYPE (SCM_OPOUTPORTP (port), port, 0, NULL, "output port");
|
|
||||||
scm_lfwrite (s, strlen (s), port);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* scm_lfwrite
|
/* scm_lfwrite
|
||||||
*
|
*
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#ifndef SCM_PORTS_H
|
#ifndef SCM_PORTS_H
|
||||||
#define SCM_PORTS_H
|
#define SCM_PORTS_H
|
||||||
|
|
||||||
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001, 2003, 2004, 2006 Free Software Foundation, Inc.
|
/* Copyright (C) 1995,1996,1997,1998,1999,2000,2001, 2003, 2004, 2006, 2008 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Lesser General Public
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
@ -264,15 +264,12 @@ SCM_API SCM scm_eof_object_p (SCM x);
|
||||||
SCM_API SCM scm_force_output (SCM port);
|
SCM_API SCM scm_force_output (SCM port);
|
||||||
SCM_API SCM scm_flush_all_ports (void);
|
SCM_API SCM scm_flush_all_ports (void);
|
||||||
SCM_API SCM scm_read_char (SCM port);
|
SCM_API SCM scm_read_char (SCM port);
|
||||||
SCM_API void scm_putc (char c, SCM port);
|
|
||||||
SCM_API void scm_puts (const char *str_data, SCM port);
|
|
||||||
SCM_API size_t scm_c_read (SCM port, void *buffer, size_t size);
|
SCM_API size_t scm_c_read (SCM port, void *buffer, size_t size);
|
||||||
SCM_API void scm_c_write (SCM port, const void *buffer, size_t size);
|
SCM_API void scm_c_write (SCM port, const void *buffer, size_t size);
|
||||||
SCM_API void scm_lfwrite (const char *ptr, size_t size, SCM port);
|
SCM_API void scm_lfwrite (const char *ptr, size_t size, SCM port);
|
||||||
SCM_API void scm_flush (SCM port);
|
SCM_API void scm_flush (SCM port);
|
||||||
SCM_API void scm_end_input (SCM port);
|
SCM_API void scm_end_input (SCM port);
|
||||||
SCM_API int scm_fill_input (SCM port);
|
SCM_API int scm_fill_input (SCM port);
|
||||||
SCM_API int scm_getc (SCM port);
|
|
||||||
SCM_API void scm_ungetc (int c, SCM port);
|
SCM_API void scm_ungetc (int c, SCM port);
|
||||||
SCM_API void scm_ungets (const char *s, int n, SCM port);
|
SCM_API void scm_ungets (const char *s, int n, SCM port);
|
||||||
SCM_API SCM scm_peek_char (SCM port);
|
SCM_API SCM scm_peek_char (SCM port);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue