annotate src/lstream.h @ 617:af57a77cbc92

[xemacs-hg @ 2001-06-18 07:09:50 by ben] --------------------------------------------------------------- DOCUMENTATION FIXES: --------------------------------------------------------------- eval.c: Correct documentation. elhash.c: Doc correction. --------------------------------------------------------------- LISP OBJECT CLEANUP: --------------------------------------------------------------- bytecode.h, buffer.h, casetab.h, chartab.h, console-msw.h, console.h, database.c, device.h, eldap.h, elhash.h, events.h, extents.h, faces.h, file-coding.h, frame.h, glyphs.h, gui-x.h, gui.h, keymap.h, lisp-disunion.h, lisp-union.h, lisp.h, lrecord.h, lstream.h, mule-charset.h, objects.h, opaque.h, postgresql.h, process.h, rangetab.h, specifier.h, toolbar.h, tooltalk.h, ui-gtk.h: Add wrap_* to all objects (it was already there for a few of them) -- an expression to encapsulate a pointer into a Lisp object, rather than the inconvenient XSET*. "wrap" was chosen because "make" as in make_int(), make_char() is not appropriate. (It implies allocation. The issue does not exist for ints and chars because they are not allocated.) Full error checking has been added to these expressions. When used without error checking, non-union build, use of these expressions will incur no loss of efficiency. (In fact, XSET* is now defined in terms of wrap_* in a non-union build.) In a union build, you will also get no loss of efficiency provided that you have a decent optimizing compiler, and a compiler that either understands inlines or automatically inlines those particular functions. (And since people don't normally do their production builds on union, it doesn't matter.) Update the sample Lisp object definition in lrecord.h accordingly. dumper.c: Fix places in dumper that referenced wrap_object to reference its new name, wrap_pointer_1. buffer.c, bufslots.h, conslots.h, console.c, console.h, devslots.h, device.c, device.h, frame.c, frame.h, frameslots.h, window.c, window.h, winslots.h: -- Extract out the Lisp objects of `struct device' into devslots.h, just like for the other structures. -- Extract out the remaining (not copied into the window config) Lisp objects in `struct window' into winslots.h; use different macros (WINDOW_SLOT vs. WINDOW_SAVED_SLOT) to differentiate them. -- Eliminate the `dead' flag of `struct frame', since it duplicates information already available in `framemeths', and fix FRAME_LIVE_P accordingly. (Devices and consoles already work this way.) -- In *slots.h, switch to system where MARKED_SLOT is automatically undef'd at the end of the file. (Follows what winslots.h already does.) -- Update the comments at the beginning of *slots.h to be accurate. -- When making any of the above objects dead, zero it out entirely and reset all Lisp object slots to Qnil. (We were already doing this somewhat, but not consistently.) This (1) Eliminates the possibility of extra objects hanging around that ought to be GC'd, (2) Causes an immediate crash if anyone tries to access a structure in one of these objects, (3) Ensures consistent behavior wrt dead objects. dialog-msw.c: Use internal_object_printer, since this object should not escape. --------------------------------------------------------------- FIXING A CRASH THAT I HIT ONCE (AND A RELATED BAD BEHAVIOR): --------------------------------------------------------------- eval.c: Fix up some comments about the FSF implementation. Fix two nasty bugs: (1) condition_case_unwind frees the conses sitting in the catch->tag slot too quickly, resulting in a crash that I hit. (2) catches need to be unwound one at a time when calling unwind-protect code, rather than all at once at the end; otherwise, incorrect behavior can result. (A comment shows exactly how.) backtrace.h: Improve comment about FSF differences in the handler stack. --------------------------------------------------------------- FIXING A CRASH THAT I REPEATEDLY HIT WHEN USING THE MOUSE WHEEL UNDER MSWINDOWS: --------------------------------------------------------------- Basic idea: My crash is due either to a dead, non-marked, GC-collected frame inside of a window mirror, or a prematurely freed window mirror. We need to mark the Lisp objects inside of window mirrors. Tracking the lifespan of window mirrors and scrollbar instances is extremely hard, and there may well be lurking bugs where such objects are freed too soon. The only safe way to fix these problems (and it fixes both problems at once) is to make both of these structures Lisp objects. lrecord.h, emacs.c, inline.c, scrollbar-gtk.c, scrollbar-msw.c, scrollbar-x.c, scrollbar.c, scrollbar.h, symsinit.h: Make scrollbar instances actual Lisp objects. Mark the window mirrors in them. inline.c needs to know about scrollbar.h now. Record the new type in lrecord.h. Fix up scrollbar-*.c appropriately. Create a hash table in scrollbar-msw.c so that the scrollbar instances stored in scrollbar HWND's are properly GC-protected. Create complex_vars_of_scrollbar_mswindows() to create the hash table at startup, and call it from emacs.c. Don't store the scrollbar instance as a property of the GTK scrollbar, as it's not used and if we did this, we'd have to separately GC-protect it in a hash table, like in MS Windows. lrecord.h, frame.h, frame.c, frameslots.h, redisplay.c, window.c, window.h: Move mark_window_mirror from redisplay.c to window.c. Make window mirrors actual Lisp objects. Tell lrecord.h about them. Change the window mirror member of struct frame from a pointer to a Lisp object, and add XWINDOW_MIRROR in appropriate places. Mark the scrollbar instances in the window mirror. redisplay.c, redisplay.h, alloc.c: Delete mark_redisplay. Don't call mark_redisplay. We now mark frame-specific structures in mark_frame. NOTE: I also deleted an extremely questionable call to update_frame_window_mirrors(). It was extremely questionable before, and now totally impossible, since it will create Lisp objects during redisplay. frame.c: Mark the scrollbar instances, which are now Lisp objects. Call mark_gutter() here, not in mark_redisplay(). gutter.c: Update comments about correct marking. --------------------------------------------------------------- ISSUES BROUGHT UP BY MARTIN: --------------------------------------------------------------- buffer.h: Put back these macros the way Steve T and I think they ought to be. I already explained in a previous changelog entry why I think these macros should be the way I'd defined them. Once again: We fix these macros so they don't care about the type of their lvalues. The non-C-string equivalents of these already function in the same way, and it's correct because it should be OK to pass in a CBufbyte *, a BufByte *, a Char_Binary *, an UChar_Binary *, etc. The whole reason for these different types is to work around errors caused by signed-vs-unsigned non-matching types. Any possible error that might be caught in a DFC macro would also be caught wherever the argument is used elsewhere. So creating multiple macro versions would add no useful error-checking and just further complicate an already complicated area. As for Martin's "ANSI aliasing" bug, XEmacs is not ANSI-aliasing clean and probably never will be. Unless the board agrees to change XEmacs in this way (and we really don't want to go down that road), this is not a bug. sound.h: Undo Martin's type change. signal.c: Fix problem identified by Martin with Linux and g++ due to non-standard declaration of setitimer(). systime.h: Update the docs for "qxe_" to point out why making the encapsulation explicit is always the right way to go. (setitimer() itself serves as an example.) For 21.4: update-elc-2.el: Correct misplaced parentheses, making lisp/mule not get recompiled.
author ben
date Mon, 18 Jun 2001 07:10:32 +0000
parents 183866b06e0b
children b39c14581166
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 /* Generic stream implementation -- header file.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2 Copyright (C) 1995 Free Software Foundation, Inc.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
3 Copyright (C) 1996 Ben Wing.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
4
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
5 This file is part of XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
6
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7 XEmacs is free software; you can redistribute it and/or modify it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
9 Free Software Foundation; either version 2, or (at your option) any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
10 later version.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
11
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
15 for more details.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
16
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
18 along with XEmacs; see the file COPYING. If not, write to
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
20 Boston, MA 02111-1307, USA. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22 /* Synched up with: Not in FSF. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
23
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
24 /* Written by Ben Wing. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
25
440
8de8e3f6228a Import from CVS: tag r21-2-28
cvs
parents: 428
diff changeset
26 #ifndef INCLUDED_lstream_h_
8de8e3f6228a Import from CVS: tag r21-2-28
cvs
parents: 428
diff changeset
27 #define INCLUDED_lstream_h_
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30 /* definition of Lstream object */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
31 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 DECLARE_LRECORD (lstream, struct lstream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34 #define XLSTREAM(x) XRECORD (x, lstream, struct lstream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 #define XSETLSTREAM(x, p) XSETRECORD (x, p, lstream)
617
af57a77cbc92 [xemacs-hg @ 2001-06-18 07:09:50 by ben]
ben
parents: 563
diff changeset
36 #define wrap_lstream(p) wrap_record (p, lstream)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
37 #define LSTREAMP(x) RECORDP (x, lstream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
38 /* #define CHECK_LSTREAM(x) CHECK_RECORD (x, lstream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39 Lstream pointers should never escape to the Lisp level, so
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40 functions should not be doing this. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
41
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
42 #ifndef EOF
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
43 #define EOF (-1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
44 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
45
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
46 /* Typedef specifying a count of bytes in a data block to be written
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
47 out or read in, using Lstream_read(), Lstream_write(), and related
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
48 functions. This MUST BE SIGNED, since it also is used in functions
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
49 that return the number of bytes actually read to or written from in
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
50 an operation, and these functions can return -1 to signal error.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
51
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
52 Note that the standard Unix read() and write() functions define the
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
53 count going in as a size_t, which is UNSIGNED, and the count going
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
54 out as an ssize_t, which is SIGNED. This is a horrible design
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
55 flaw. Not only is it highly likely to lead to logic errors when a
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
56 -1 gets interpreted as a large positive number, but operations are
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
57 bound to fail in all sorts of horrible ways when a number in the
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
58 upper-half of the size_t range is passed in -- this number is
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
59 unrepresentable as an ssize_t, so code that checks to see how many
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
60 bytes are actually written (which is mandatory if you are dealing
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
61 with certain types of devices) will get completely screwed up.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
62 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
63
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
64 typedef EMACS_INT Lstream_data_count;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
65
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 typedef enum lstream_buffering
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
68 /* No buffering. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 LSTREAM_UNBUFFERED,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70 /* Buffer until a '\n' character is reached. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 LSTREAM_LINE_BUFFERED,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72 /* Buffer in standard-size (i.e. 512-byte) blocks. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
73 LSTREAM_BLOCK_BUFFERED,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
74 /* Buffer in blocks of a specified size. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 LSTREAM_BLOCKN_BUFFERED,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 /* Buffer until the stream is closed (only applies to write-only
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 streams). Only one call to the stream writer will be made,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 and that is when the stream is closed. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 LSTREAM_UNLIMITED
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 } Lstream_buffering;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82 /* Methods defining how this stream works. Some may be undefined. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 /* We do not implement the seek/tell paradigm. I tried to do that,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 but getting the semantics right in the presence of buffering is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
86 extremely tricky and very error-prone and basically not worth it.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
87 This is especially the case with complicated streams like
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 decoding streams -- the seek pointer in this case can't be a single
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89 integer but has to be a whole complicated structure that records
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90 all of the stream's state at the time.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 Rewind semantics are generally easy to implement, so we do provide
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93 a rewind method. Even rewind() may not be available on a stream,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 however -- e.g. on process output. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 typedef struct lstream_implementation
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
97 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
98 const char *name;
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
99 Lstream_data_count size; /* Number of additional bytes to be
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
100 allocated with this stream. Access this
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
101 data using Lstream_data(). */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102 /* Read some data from the stream's end and store it into DATA, which
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 can hold SIZE bytes. Return the number of bytes read. A return
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104 value of 0 means no bytes can be read at this time. This may
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105 be because of an EOF, or because there is a granularity greater
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 than one byte that the stream imposes on the returned data, and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 SIZE is less than this granularity. (This will happen frequently
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 for streams that need to return whole characters, because
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 Lstream_read() calls the reader function repeatedly until it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110 has the number of bytes it wants or until 0 is returned.)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111 The lstream functions do not treat a 0 return as EOF or do
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 anything special; however, the calling function will interpret
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 any 0 it gets back as EOF. This will normally not happen unless
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114 the caller calls Lstream_read() with a very small size.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 This function can be NULL if the stream is output-only. */
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
117 /* The omniscient mly, blinded by the irresistible thrall of Common
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118 Lisp, thinks that it is bogus that the types and implementations
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
119 of input and output streams are the same. */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
120 Lstream_data_count (*reader) (Lstream *stream, unsigned char *data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
121 Lstream_data_count size);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 /* Send some data to the stream's end. Data to be sent is in DATA
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123 and is SIZE bytes. Return the number of bytes sent. This
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 function can send and return fewer bytes than is passed in; in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 that case, the function will just be called again until there is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126 no data left or 0 is returned. A return value of 0 means that no
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127 more data can be currently stored, but there is no error; the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128 data will be squirrelled away until the writer can accept
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 data. (This is useful, e.g., of you're dealing with a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 non-blocking file descriptor and are getting EWOULDBLOCK errors.)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131 This function can be NULL if the stream is input-only. */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
132 Lstream_data_count (*writer) (Lstream *stream, const unsigned char *data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
133 Lstream_data_count size);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134 /* Return non-zero if the last write operation on the stream resulted
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
135 in an attempt to block (EWOULDBLOCK). If this method does not
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
136 exists, the implementation returns 0 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
137 int (*was_blocked_p) (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
138 /* Rewind the stream. If this is NULL, the stream is not seekable. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
139 int (*rewinder) (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
140 /* Indicate whether this stream is seekable -- i.e. it can be rewound.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
141 This method is ignored if the stream does not have a rewind
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
142 method. If this method is not present, the result is determined
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
143 by whether a rewind method is present. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
144 int (*seekable_p) (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
145 /* Perform any additional operations necessary to flush the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
146 data in this stream. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
147 int (*flusher) (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
148 /* Perform any additional operations necessary to close this
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
149 stream down. May be NULL. This function is called when
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
150 Lstream_close() is called or when the stream is garbage-
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
151 collected. When this function is called, all pending data
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
152 in the stream will already have been written out. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
153 int (*closer) (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
154 /* Mark this object for garbage collection. Same semantics as
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
155 a standard Lisp_Object marker. This function can be NULL. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
156 Lisp_Object (*marker) (Lisp_Object lstream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157 } Lstream_implementation;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 #define DEFINE_LSTREAM_IMPLEMENTATION(name,c_name,size) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
160 Lstream_implementation c_name[1] = \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161 { { (name), (size) } }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
162
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163 #define LSTREAM_FL_IS_OPEN 1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164 #define LSTREAM_FL_READ 2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
165 #define LSTREAM_FL_WRITE 4
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166 #define LSTREAM_FL_NO_PARTIAL_CHARS 8
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 #define LSTREAM_FL_CLOSE_AT_DISKSAVE 16
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
168
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169 struct lstream
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
170 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
171 struct lcrecord_header header;
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
172 const Lstream_implementation *imp; /* methods for this stream */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 Lstream_buffering buffering; /* type of buffering in use */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
174 Lstream_data_count buffering_size; /* number of bytes buffered */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
175
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
176 unsigned char *in_buffer; /* holds characters read from stream end */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
177 Lstream_data_count in_buffer_size; /* allocated size of buffer */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
178 Lstream_data_count in_buffer_current; /* number of characters in buffer */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
179 Lstream_data_count in_buffer_ind; /* pointer to next character to
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
180 take from buffer */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
181
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
182 unsigned char *out_buffer; /* holds characters to write to stream end */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
183 Lstream_data_count out_buffer_size; /* allocated size of buffer */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
184 Lstream_data_count out_buffer_ind; /* pointer to next buffer spot to
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
185 write a character */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
186
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
187 /* The unget buffer is more or less a stack -- things get pushed
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
188 onto the end and read back from the end. Lstream_read()
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
189 basically reads backwards from the end to get stuff; Lstream_unread()
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
190 similarly has to push the data on backwards. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
191 unsigned char *unget_buffer; /* holds characters pushed back onto input */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
192 Lstream_data_count unget_buffer_size; /* allocated size of buffer */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
193 Lstream_data_count unget_buffer_ind; /* pointer to next buffer spot
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
194 to write a character */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
195
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
196 Lstream_data_count byte_count;
456
e7ef97881643 Import from CVS: tag r21-2-43
cvs
parents: 444
diff changeset
197 int flags;
e7ef97881643 Import from CVS: tag r21-2-43
cvs
parents: 444
diff changeset
198 max_align_t data[1];
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
199 };
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
200
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
201 #define LSTREAM_TYPE_P(lstr, type) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
202 ((lstr)->imp == lstream_##type)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
203
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
204 #ifdef ERROR_CHECK_TYPECHECK
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
205 INLINE_HEADER struct lstream *
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
206 error_check_lstream_type (struct lstream *stream,
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
207 const Lstream_implementation *imp);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
208 INLINE_HEADER struct lstream *
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
209 error_check_lstream_type (struct lstream *stream,
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
210 const Lstream_implementation *imp)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
211 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
212 assert (stream->imp == imp);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
213 return stream;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
214 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
215 # define LSTREAM_TYPE_DATA(lstr, type) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
216 ((struct type##_stream *) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
217 Lstream_data (error_check_lstream_type(lstr, lstream_##type)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
218 #else
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
219 # define LSTREAM_TYPE_DATA(lstr, type) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
220 ((struct type##_stream *) Lstream_data (lstr))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
221 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
222
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
223 /* Declare that lstream-type TYPE has method M; used in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
224 initialization routines */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
225 #define LSTREAM_HAS_METHOD(type, m) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
226 (lstream_##type->m = type##_##m)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
227
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
228
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
229 Lstream *Lstream_new (const Lstream_implementation *imp,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
230 const char *mode);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
231 void Lstream_reopen (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
232 void Lstream_set_buffering (Lstream *lstr, Lstream_buffering buffering,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
233 int buffering_size);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
234 int Lstream_flush (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
235 int Lstream_flush_out (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
236 int Lstream_fputc (Lstream *lstr, int c);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
237 int Lstream_fgetc (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
238 void Lstream_fungetc (Lstream *lstr, int c);
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
239 Lstream_data_count Lstream_read (Lstream *lstr, void *data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
240 Lstream_data_count size);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
241 Lstream_data_count Lstream_write (Lstream *lstr, const void *data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
242 Lstream_data_count size);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
243 int Lstream_was_blocked_p (Lstream *lstr);
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
244 void Lstream_unread (Lstream *lstr, const void *data, Lstream_data_count size);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
245 int Lstream_rewind (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
246 int Lstream_seekable_p (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
247 int Lstream_close (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
248 void Lstream_delete (Lstream *lstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
249 void Lstream_set_character_mode (Lstream *str);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
250
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
251 /* Call the function equivalent if the out buffer is full. Otherwise,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
252 add to the end of the out buffer and, if line buffering is called for
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
253 and the character marks the end of a line, write out the buffer. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
254
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
255 #define Lstream_putc(stream, c) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
256 ((stream)->out_buffer_ind >= (stream)->out_buffer_size ? \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
257 Lstream_fputc (stream, c) : \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
258 ((stream)->out_buffer[(stream)->out_buffer_ind++] = \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
259 (unsigned char) (c), \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
260 (stream)->byte_count++, \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
261 (stream)->buffering == LSTREAM_LINE_BUFFERED && \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
262 (stream)->out_buffer[(stream)->out_buffer_ind - 1] == '\n' ? \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263 Lstream_flush_out (stream) : 0))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
264
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265 /* Retrieve from unget buffer if there are any characters there;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266 else retrieve from in buffer if there's anything there;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
267 else call the function equivalent */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 #define Lstream_getc(stream) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269 ((stream)->unget_buffer_ind > 0 ? \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
270 ((stream)->byte_count++, \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
271 (stream)->unget_buffer[--(stream)->unget_buffer_ind]) : \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
272 (stream)->in_buffer_ind < (stream)->in_buffer_current ? \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
273 ((stream)->byte_count++, \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
274 (stream)->in_buffer[(stream)->in_buffer_ind++]) : \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
275 Lstream_fgetc (stream))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
276
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
277 /* Add to the end if it won't overflow buffer; otherwise call the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
278 function equivalent */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
279 #define Lstream_ungetc(stream, c) \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
280 ((stream)->unget_buffer_ind >= (stream)->unget_buffer_size ? \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
281 Lstream_fungetc (stream, c) : \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
282 (void) ((stream)->byte_count--, \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
283 ((stream)->unget_buffer[(stream)->unget_buffer_ind++] = \
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
284 (unsigned char) (c))))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
285
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
286 #define Lstream_data(stream) ((void *) ((stream)->data))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
287 #define Lstream_byte_count(stream) ((stream)->byte_count)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
288
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
289
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
290 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
291 /* working with an Lstream as a stream of Emchars */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
292 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
293
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
294 #ifdef MULE
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
295
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
296 #ifndef BYTE_ASCII_P
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
297 #include "mule-charset.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
298 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
299
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
300 INLINE_HEADER Emchar Lstream_get_emchar (Lstream *stream);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
301 INLINE_HEADER Emchar
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
302 Lstream_get_emchar (Lstream *stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
303 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
304 int c = Lstream_getc (stream);
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
305 return (c < 0x80 /* c == EOF || BYTE_ASCII_P (c) */
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
306 ? (Emchar) c
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
307 : Lstream_get_emchar_1 (stream, c));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
308 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
309
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
310 INLINE_HEADER int Lstream_put_emchar (Lstream *stream, Emchar ch);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
311 INLINE_HEADER int
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
312 Lstream_put_emchar (Lstream *stream, Emchar ch)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
313 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
314 return CHAR_ASCII_P (ch) ?
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
315 Lstream_putc (stream, ch) :
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
316 Lstream_fput_emchar (stream, ch);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
317 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
318
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
319 INLINE_HEADER void Lstream_unget_emchar (Lstream *stream, Emchar ch);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
320 INLINE_HEADER void
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
321 Lstream_unget_emchar (Lstream *stream, Emchar ch)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
322 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
323 if (CHAR_ASCII_P (ch))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
324 Lstream_ungetc (stream, ch);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
325 else
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
326 Lstream_funget_emchar (stream, ch);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
327 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
328 #else /* not MULE */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
329
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
330 # define Lstream_get_emchar(stream) Lstream_getc (stream)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
331 # define Lstream_put_emchar(stream, ch) Lstream_putc (stream, ch)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
332 # define Lstream_unget_emchar(stream, ch) Lstream_ungetc (stream, ch)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
333
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
334 #endif /* not MULE */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
335
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
336
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
337 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
338 /* Lstream implementations */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
339 /************************************************************************/
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
340
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
341 /* Flags we can pass to the filedesc and stdio streams. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
342
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
343 /* If set, close the descriptor or FILE * when the stream is closed. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
344 #define LSTR_CLOSING 1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
345
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
346 /* If set, allow quitting out of the actual I/O. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
347 #define LSTR_ALLOW_QUIT 2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
348
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
349 /* If set and filedesc_stream_set_pty_flushing() has been called
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
350 on the stream, do not send more than pty_max_bytes on a single
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
351 line without flushing the data out using the eof_char. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
352 #define LSTR_PTY_FLUSHING 4
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
353
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
354 /* If set, an EWOULDBLOCK error is not treated as an error but
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
355 simply causes the write function to return 0 as the number
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
356 of bytes written out. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
357 #define LSTR_BLOCKED_OK 8
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
358
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
359 Lisp_Object make_stdio_input_stream (FILE *stream, int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
360 Lisp_Object make_stdio_output_stream (FILE *stream, int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
361 Lisp_Object make_filedesc_input_stream (int filedesc, int offset, int count,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
362 int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
363 Lisp_Object make_filedesc_output_stream (int filedesc, int offset, int count,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
364 int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
365 void filedesc_stream_set_pty_flushing (Lstream *stream,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
366 int pty_max_bytes,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
367 Bufbyte eof_char);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
368 int filedesc_stream_fd (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
369 Lisp_Object make_lisp_string_input_stream (Lisp_Object string,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
370 Bytecount offset,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
371 Bytecount len);
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
372 Lisp_Object make_fixed_buffer_input_stream (const void *buf,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
373 Lstream_data_count size);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
374 Lisp_Object make_fixed_buffer_output_stream (void *buf,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents: 456
diff changeset
375 Lstream_data_count size);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
376 const unsigned char *fixed_buffer_input_stream_ptr (Lstream *stream);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
377 unsigned char *fixed_buffer_output_stream_ptr (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
378 Lisp_Object make_resizing_buffer_output_stream (void);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
379 unsigned char *resizing_buffer_stream_ptr (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
380 Lisp_Object make_dynarr_output_stream (unsigned_char_dynarr *dyn);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
381 #define LSTR_SELECTIVE 1
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
382 #define LSTR_IGNORE_ACCESSIBLE 2
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
383 Lisp_Object make_lisp_buffer_input_stream (struct buffer *buf, Bufpos start,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
384 Bufpos end, int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
385 Lisp_Object make_lisp_buffer_output_stream (struct buffer *buf, Bufpos pos,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
386 int flags);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
387 Bufpos lisp_buffer_stream_startpos (Lstream *stream);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
388
440
8de8e3f6228a Import from CVS: tag r21-2-28
cvs
parents: 428
diff changeset
389 #endif /* INCLUDED_lstream_h_ */