1998-11-02 15:43:17 +01:00
|
|
|
Sfio is a portable library for managing I/O streams. It provides
|
|
|
|
similar functionality to the ANSI C Standard I/O functions known
|
|
|
|
collectively as Stdio. However, it has a distinct interface and is
|
2003-05-06 19:40:18 +02:00
|
|
|
generally faster and more robust than most Stdio implementations.
|
1998-11-02 15:43:17 +01:00
|
|
|
Sfio also introduces a number of new features and concepts beyond
|
2003-05-06 19:40:18 +02:00
|
|
|
Stdio stream I/O processing:
|
1998-11-02 15:43:17 +01:00
|
|
|
|
2003-05-06 19:40:18 +02:00
|
|
|
+ Automatic locking to avoid concurrent stream accesses,
|
1998-11-02 15:43:17 +01:00
|
|
|
+ I/O disciplines to pre/post-process read/write data from/to streams,
|
2003-05-06 19:40:18 +02:00
|
|
|
+ Stream stacking for recursive processing of nested streams,
|
1998-11-02 15:43:17 +01:00
|
|
|
+ Stream pooling for automatic stream synchronization when I/O
|
|
|
|
operations are performed on different streams,
|
|
|
|
+ Buffer reservation for safe access to the internal buffers of streams,
|
2003-05-06 19:40:18 +02:00
|
|
|
+ Robust handling of variable-sized records, and
|
|
|
|
+ Extensible printf/scanf-like formatting I/O operations.
|
1998-11-02 15:43:17 +01:00
|
|
|
|
|
|
|
For backward compatibility, Sfio provides two Stdio emulation
|
|
|
|
packages. An application with source code can include the header file
|
|
|
|
stdio.h provided by Sfio instead of the native one to translate Stdio
|
|
|
|
calls to Sfio calls. An application already compiled with the native
|
|
|
|
header file stdio.h can make use of Sfio functionality by linking with
|
|
|
|
the library libstdio.a which emulates Stdio functions. In fact, it is
|
|
|
|
safe to mix and match modules that are compiled with either
|
2003-05-06 19:40:18 +02:00
|
|
|
Sfio-provided or native stdio.h.
|
1998-11-02 15:43:17 +01:00
|
|
|
|
|
|
|
The current distribution of Sfio is Sfio1998. This version of the
|
|
|
|
library is portable to all known UNIX platforms including various
|
|
|
|
flavors of IRIX, SUNOS, Solaris, Ultrix, MVS/OpenEdition, Linux and
|
|
|
|
BSDI. The library handles 64-bit streams on platforms that support
|
|
|
|
64-bit files. The formatting family of functions (e.g., sfprintf()
|
|
|
|
and sfscanf()) have been extended so that applications can redefine
|
2003-05-06 19:40:18 +02:00
|
|
|
the meanings of predefined patterns as well as define new patterns.
|
|
|
|
The manual page has more details on recent changes.
|
1998-11-02 15:43:17 +01:00
|
|
|
|
2003-05-06 19:40:18 +02:00
|
|
|
Below are papers related to Sfio:
|
1998-11-02 15:43:17 +01:00
|
|
|
|
|
|
|
David G. Korn and Kiem-Phong Vo, ``Sfio: Safe/Fast String/File IO'',
|
2003-05-06 19:40:18 +02:00
|
|
|
Proceedings of the Summer '91 Usenix Conference, pp. 235-256, 1991.
|
1998-11-02 15:43:17 +01:00
|
|
|
|
|
|
|
Glenn S. Fowler, David G. Korn and Kiem-Phong Vo,
|
|
|
|
``Feature-Based Portability'', Proceedings of the Usenix VHLL
|
|
|
|
Conference, pp. 197-207, 1994.
|
|
|
|
|
|
|
|
Kiem-Phong Vo, ``An Architecture for Reusable Libraries'',
|
2003-05-06 19:40:18 +02:00
|
|
|
Proc. of the IEEE Fifth Int. Conf. on Software Reuse, 1998.
|