File: xsgetn.yo

package info (click to toggle)
c%2B%2B-annotations 13.02.02-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 13,576 kB
  • sloc: cpp: 25,297; makefile: 1,523; ansic: 165; sh: 126; perl: 90; fortran: 27
file content (21 lines) | stat: -rw-r--r-- 1,048 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
A stream's tt(read) member calls tt(xsgetn) to read tt(nChars) characters from
the device. The tt(nChar) characters might not be available in the current
buffer. In those cases tt(underflow) is called to refresh the
buffer. Initially some bytes may already be available. At each cycle the
number of available characters are copied to the next location of its tt(buf)
parameter, calling tt(underflow) if there are no available characters
anymore. So tt(xsgetn), while there are (still) characters to be read from the
device, must
    itemization(
    it() determine whether the current buffer contains available characters;
    it() if not, it must call tt(underflow);
    it() the number of available characters are copied to the next position of
        the tt(buf) parameter;
    it() the number of bytes to read is reduced by the number of available
        bytes; 
    it() the tt(buf) pointer and the counters are updated using the
        number of read bytes. 
    )

Here is a skeleton of tt(xsgetn):
    verbinclude(-a examples/xsgetn.cc)