jstream.cpp 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. /*##############################################################################
  2. HPCC SYSTEMS software Copyright (C) 2012 HPCC Systems®.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. ############################################################################## */
  13. #include "platform.h"
  14. #include "jstream.ipp"
  15. #include "jstring.hpp"
  16. #include "jexcept.hpp"
  17. #include "jlog.hpp"
  18. #include <assert.h>
  19. #include <stdio.h>
  20. #ifdef _WIN32
  21. #include <io.h>
  22. #endif
  23. CByteInputStream::CByteInputStream()
  24. {
  25. eofseen = false;
  26. pushedback = false;
  27. ungot = 0;
  28. }
  29. bool CByteInputStream::eof()
  30. {
  31. try
  32. {
  33. unget(readByte());
  34. }
  35. catch (IException *c)
  36. {
  37. c->Release();
  38. return true;
  39. }
  40. return eofseen;
  41. }
  42. int CByteInputStream::readByte()
  43. {
  44. if (pushedback)
  45. {
  46. pushedback = false;
  47. return ungot;
  48. }
  49. if (eofseen)
  50. return -1;
  51. int ret = readNext();
  52. if (ret==-1)
  53. eofseen = true;
  54. return ret;
  55. }
  56. int CByteInputStream::readBytes(void *vbuf, int size)
  57. {
  58. int read = 0;
  59. if (eofseen)
  60. return 0;
  61. char *buf = (char *) vbuf;
  62. while (read < size)
  63. {
  64. char c = readByte();
  65. if (eofseen)
  66. return read;
  67. buf[read] = c;
  68. read++;
  69. }
  70. return read;
  71. }
  72. void CByteInputStream::unget(int c)
  73. {
  74. assertex(!pushedback);
  75. pushedback = true;
  76. ungot = c;
  77. }
  78. //================================================================================
  79. CStringBufferInputStream::CStringBufferInputStream(const char *s) : pos(0), str(s)
  80. {
  81. }
  82. int CStringBufferInputStream::readNext()
  83. {
  84. if (pos < str.length())
  85. return str.charAt(pos++);
  86. else
  87. return -1;
  88. }
  89. extern jlib_decl IByteInputStream *createInputStream(const char *string)
  90. {
  91. return new CStringBufferInputStream(string);
  92. }
  93. //================================================================================
  94. CUserStringBufferInputStream::CUserStringBufferInputStream(StringBuffer &s) : pos(0), str(s)
  95. {
  96. }
  97. int CUserStringBufferInputStream::readNext()
  98. {
  99. if (pos < str.length())
  100. return str.charAt(pos++);
  101. else
  102. return -1;
  103. }
  104. extern jlib_decl IByteInputStream *createInputStream(StringBuffer &from)
  105. {
  106. return new CUserStringBufferInputStream(from);
  107. }
  108. //================================================================================
  109. void CStringBufferOutputStream::writeByte(byte b)
  110. {
  111. out.append((char)b);
  112. }
  113. void CStringBufferOutputStream::writeBytes(const void * data, int len)
  114. {
  115. out.append(len, (const char *)data);
  116. }
  117. extern jlib_decl IByteOutputStream *createOutputStream(StringBuffer &to)
  118. {
  119. return new CStringBufferOutputStream(to);
  120. }
  121. //================================================================================
  122. CSocketInputStream::CSocketInputStream(ISocket *s)
  123. {
  124. sock = s;
  125. s->Link();
  126. remaining = 0;
  127. next = 0;
  128. }
  129. CSocketInputStream::~CSocketInputStream()
  130. {
  131. sock->Release();
  132. }
  133. void CSocketInputStream::refill()
  134. {
  135. if (!eofseen)
  136. {
  137. next = 0;
  138. sock->read(buffer, 1, sizeof(buffer), remaining);
  139. if (remaining <= 0)
  140. {
  141. remaining = 0;
  142. eofseen = true;
  143. }
  144. }
  145. }
  146. int CSocketInputStream::readNext()
  147. {
  148. if (!remaining)
  149. refill();
  150. if (eofseen)
  151. return -1;
  152. else
  153. {
  154. int ret = buffer[next];
  155. assertex(ret != -1);
  156. next++;
  157. remaining--;
  158. return ret;
  159. }
  160. }
  161. //===========================================================================
  162. CSocketOutputStream::CSocketOutputStream(ISocket *s)
  163. {
  164. sock = s;
  165. s->Link();
  166. }
  167. CSocketOutputStream::~CSocketOutputStream()
  168. {
  169. this->sock->Release();
  170. }
  171. void CSocketOutputStream::writeByte(byte b)
  172. {
  173. this->sock->write((const char *) &b, 1);
  174. }
  175. void CSocketOutputStream::writeBytes(const void *b, int len)
  176. {
  177. if (len)
  178. this->sock->write((const char *) b, len);
  179. }
  180. //===========================================================================
  181. CFileOutputStream::CFileOutputStream(int _handle)
  182. {
  183. handle = _handle;
  184. }
  185. void CFileOutputStream::writeByte(byte b)
  186. {
  187. if (_write(handle, &b, 1) != 1)
  188. throw MakeStringException(-1, "Error while writing byte 0x%x\n", (unsigned)b);
  189. }
  190. void CFileOutputStream::writeBytes(const void *b, int len)
  191. {
  192. ssize_t written = _write(handle, b, len);
  193. if (written < 0)
  194. throw MakeStringException(-1, "Error while writing %d bytes\n", len);
  195. if (written != len)
  196. throw MakeStringException(-1, "Truncated (%d) while writing %d bytes\n", (int)written, len);
  197. }
  198. extern jlib_decl IByteOutputStream *createOutputStream(int handle)
  199. {
  200. return new CFileOutputStream(handle);
  201. }
  202. //===========================================================================
  203. CFileInputStream::CFileInputStream(int _handle)
  204. {
  205. handle = _handle;
  206. remaining = 0;
  207. }
  208. void CFileInputStream::refill()
  209. {
  210. if (!eofseen)
  211. {
  212. next = 0;
  213. remaining = _read(handle, buffer, sizeof(buffer));
  214. if(remaining == 0)
  215. eofseen = true;
  216. else if (remaining < 0)
  217. {
  218. remaining = 0;
  219. perror("error reading:");
  220. eofseen = true;
  221. }
  222. }
  223. }
  224. int CFileInputStream::readNext()
  225. {
  226. if (!remaining)
  227. refill();
  228. if (eofseen)
  229. return -1;
  230. else
  231. {
  232. int ret = buffer[next];
  233. assertex(ret != -1);
  234. next++;
  235. remaining--;
  236. return ret;
  237. }
  238. }
  239. IByteInputStream *createInputStream(int handle)
  240. {
  241. return new CFileInputStream(handle);
  242. }