lzio.c 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. ** $Id: lzio.c,v 1.31.1.1 2007/12/27 13:02:25 roberto Exp $
  3. ** a generic input stream interface
  4. ** See Copyright Notice in lua.h
  5. */
  6. #include <string.h>
  7. #define lzio_c
  8. #define LUA_CORE
  9. #include "lua.h"
  10. #include "llimits.h"
  11. #include "lmem.h"
  12. #include "lstate.h"
  13. #include "lzio.h"
  14. int luaZ_fill(ZIO *z)
  15. {
  16. size_t size;
  17. lua_State *L = z->L;
  18. const char *buff;
  19. lua_unlock(L);
  20. buff = z->reader(L, z->data, &size);
  21. lua_lock(L);
  22. if (buff == NULL || size == 0) return EOZ;
  23. z->n = size - 1;
  24. z->p = buff;
  25. return char2int(*(z->p++));
  26. }
  27. int luaZ_lookahead(ZIO *z)
  28. {
  29. if (z->n == 0)
  30. {
  31. if (luaZ_fill(z) == EOZ)
  32. return EOZ;
  33. else
  34. {
  35. z->n++; /* luaZ_fill removed first byte; put back it */
  36. z->p--;
  37. }
  38. }
  39. return char2int(*z->p);
  40. }
  41. void luaZ_init(lua_State *L, ZIO *z, lua_Reader reader, void *data)
  42. {
  43. z->L = L;
  44. z->reader = reader;
  45. z->data = data;
  46. z->n = z->i = 0;
  47. z->p = NULL;
  48. }
  49. /* --------------------------------------------------------------- read --- */
  50. size_t luaZ_read(ZIO *z, void *b, size_t n)
  51. {
  52. while (n)
  53. {
  54. size_t m;
  55. if (luaZ_lookahead(z) == EOZ)
  56. return n; /* return number of missing bytes */
  57. m = (n <= z->n) ? n : z->n; /* min. between n and z->n */
  58. if (b)
  59. memcpy(b, z->p, m);
  60. z->n -= m;
  61. z->i += m;
  62. z->p += m;
  63. if (b)
  64. b = (char *)b + m;
  65. n -= m;
  66. }
  67. return 0;
  68. }
  69. /* ------------------------------------------------------------------------ */
  70. char *luaZ_openspace(lua_State *L, Mbuffer *buff, size_t n)
  71. {
  72. if (n > buff->buffsize)
  73. {
  74. if (n < LUA_MINBUFFER) n = LUA_MINBUFFER;
  75. luaZ_resizebuffer(L, buff, n);
  76. }
  77. return buff->buffer;
  78. }