CHDK_DE Vorschauversion  Trunk Rev. 5272
 Alle Datenstrukturen Dateien Funktionen Variablen Typdefinitionen Aufzählungen Aufzählungswerte Makrodefinitionen
lzio.h-Dateireferenz
#include "lua.h"
#include "lmem.h"
+ Include-Abhängigkeitsdiagramm für lzio.h:
+ Dieser Graph zeigt, welche Datei direkt oder indirekt diese Datei enthält:

gehe zum Quellcode dieser Datei

Datenstrukturen

struct  Mbuffer
 
struct  Zio
 

Makrodefinitionen

#define EOZ   (-1) /* end of stream */
 
#define char2int(c)   cast(int, cast(unsigned char, (c)))
 
#define zgetc(z)   (((z)->n--)>0 ? char2int(*(z)->p++) : luaZ_fill(z))
 
#define luaZ_initbuffer(L, buff)   ((buff)->buffer = NULL, (buff)->buffsize = 0)
 
#define luaZ_buffer(buff)   ((buff)->buffer)
 
#define luaZ_sizebuffer(buff)   ((buff)->buffsize)
 
#define luaZ_bufflen(buff)   ((buff)->n)
 
#define luaZ_resetbuffer(buff)   ((buff)->n = 0)
 
#define luaZ_resizebuffer(L, buff, size)
 
#define luaZ_freebuffer(L, buff)   luaZ_resizebuffer(L, buff, 0)
 

Typdefinitionen

typedef struct Zio ZIO
 
typedef struct Mbuffer Mbuffer
 

Funktionen

LUAI_FUNC char * luaZ_openspace (lua_State *L, Mbuffer *buff, size_t n)
 
LUAI_FUNC void luaZ_init (lua_State *L, ZIO *z, lua_Reader reader, void *data)
 
LUAI_FUNC size_t luaZ_read (ZIO *z, void *b, size_t n)
 
LUAI_FUNC int luaZ_lookahead (ZIO *z)
 
LUAI_FUNC int luaZ_fill (ZIO *z)
 

Makro-Dokumentation

#define char2int (   c)    cast(int, cast(unsigned char, (c)))

Definiert in Zeile 20 der Datei lzio.h.

#define EOZ   (-1) /* end of stream */

Definiert in Zeile 16 der Datei lzio.h.

#define luaZ_buffer (   buff)    ((buff)->buffer)

Definiert in Zeile 32 der Datei lzio.h.

#define luaZ_bufflen (   buff)    ((buff)->n)

Definiert in Zeile 34 der Datei lzio.h.

#define luaZ_freebuffer (   L,
  buff 
)    luaZ_resizebuffer(L, buff, 0)

Definiert in Zeile 43 der Datei lzio.h.

#define luaZ_initbuffer (   L,
  buff 
)    ((buff)->buffer = NULL, (buff)->buffsize = 0)

Definiert in Zeile 30 der Datei lzio.h.

#define luaZ_resetbuffer (   buff)    ((buff)->n = 0)

Definiert in Zeile 36 der Datei lzio.h.

#define luaZ_resizebuffer (   L,
  buff,
  size 
)
Wert:
(luaM_reallocvector(L, (buff)->buffer, (buff)->buffsize, size, char), \
(buff)->buffsize = size)

Definiert in Zeile 39 der Datei lzio.h.

#define luaZ_sizebuffer (   buff)    ((buff)->buffsize)

Definiert in Zeile 33 der Datei lzio.h.

#define zgetc (   z)    (((z)->n--)>0 ? char2int(*(z)->p++) : luaZ_fill(z))

Definiert in Zeile 22 der Datei lzio.h.

Dokumentation der benutzerdefinierten Typen

typedef struct Mbuffer Mbuffer
typedef struct Zio ZIO

Definiert in Zeile 18 der Datei lzio.h.

Dokumentation der Funktionen

LUAI_FUNC int luaZ_fill ( ZIO z)

Definiert in Zeile 21 der Datei lzio.c.

21  {
22  size_t size;
23  lua_State *L = z->L;
24  const char *buff;
25  lua_unlock(L);
26  buff = z->reader(L, z->data, &size);
27  lua_lock(L);
28  if (buff == NULL || size == 0) return EOZ;
29  z->n = size - 1;
30  z->p = buff;
31  return char2int(*(z->p++));
32 }
LUAI_FUNC void luaZ_init ( lua_State L,
ZIO z,
lua_Reader  reader,
void *  data 
)

Definiert in Zeile 48 der Datei lzio.c.

48  {
49  z->L = L;
50  z->reader = reader;
51  z->data = data;
52  z->n = 0;
53  z->p = NULL;
54 }
LUAI_FUNC int luaZ_lookahead ( ZIO z)

Definiert in Zeile 35 der Datei lzio.c.

35  {
36  if (z->n == 0) {
37  if (luaZ_fill(z) == EOZ)
38  return EOZ;
39  else {
40  z->n++; /* luaZ_fill removed first byte; put back it */
41  z->p--;
42  }
43  }
44  return char2int(*z->p);
45 }
LUAI_FUNC char* luaZ_openspace ( lua_State L,
Mbuffer buff,
size_t  n 
)

Definiert in Zeile 74 der Datei lzio.c.

74  {
75  if (n > buff->buffsize) {
76  if (n < LUA_MINBUFFER) n = LUA_MINBUFFER;
77  luaZ_resizebuffer(L, buff, n);
78  }
79  return buff->buffer;
80 }
LUAI_FUNC size_t luaZ_read ( ZIO z,
void *  b,
size_t  n 
)

Definiert in Zeile 58 der Datei lzio.c.

58  {
59  while (n) {
60  size_t m;
61  if (luaZ_lookahead(z) == EOZ)
62  return n; /* return number of missing bytes */
63  m = (n <= z->n) ? n : z->n; /* min. between n and z->n */
64  memcpy(b, z->p, m);
65  z->n -= m;
66  z->p += m;
67  b = (char *)b + m;
68  n -= m;
69  }
70  return 0;
71 }