diff options
Diffstat (limited to '')
-rw-r--r-- | src/stable/myriad.cpp | 143 | ||||
-rw-r--r-- | src/stable/myriad.h | 24 | ||||
-rw-r--r-- | src/stable/myriadstream.cpp | 72 | ||||
-rw-r--r-- | src/stable/myriadstream.h | 4 |
4 files changed, 216 insertions, 27 deletions
diff --git a/src/stable/myriad.cpp b/src/stable/myriad.cpp index 5278ac5..f3ff09a 100644 --- a/src/stable/myriad.cpp +++ b/src/stable/myriad.cpp | |||
@@ -81,6 +81,14 @@ bool Bu::Myriad::setSize( Bu::Myriad::StreamId /*iStream*/, | |||
81 | return false; | 81 | return false; |
82 | } | 82 | } |
83 | 83 | ||
84 | Bu::String Bu::Myriad::getLocation() const | ||
85 | { | ||
86 | Bu::MutexLocker l( mAccess ); | ||
87 | Bu::MutexLocker l2( mBacking ); | ||
88 | return Bu::String("myriad(%1,%2):%3") | ||
89 | .arg( 1 ).arg( iBlockSize ).arg( rBacking.getLocation() ); | ||
90 | } | ||
91 | |||
84 | bool Bu::Myriad::loadMyriad() | 92 | bool Bu::Myriad::loadMyriad() |
85 | { | 93 | { |
86 | Bu::println("Load myriad!"); | 94 | Bu::println("Load myriad!"); |
@@ -264,6 +272,32 @@ int32_t Bu::Myriad::allocateBlock() | |||
264 | } | 272 | } |
265 | } | 273 | } |
266 | 274 | ||
275 | void Bu::Myriad::releaseBlock( int32_t iBlockId, bool bBlank ) | ||
276 | { | ||
277 | Bu::MutexLocker l( mAccess ); | ||
278 | lFreeBlocks.append( iBlockId ); | ||
279 | if( bBlank ) | ||
280 | { | ||
281 | blankBlock( iBlockId ); | ||
282 | } | ||
283 | } | ||
284 | |||
285 | void Bu::Myriad::blankBlock( int32_t iBlockId ) | ||
286 | { | ||
287 | Bu::MutexLocker l( mBacking ); | ||
288 | rBacking.setPos( iBlockId*iBlockSize ); | ||
289 | int32_t iChunk = std::min( iBlockSize, 4096 ); | ||
290 | uint8_t *pChunk = new uint8_t[iChunk]; | ||
291 | memset( pChunk, 0, iChunk ); | ||
292 | int iLeft = iBlockSize; | ||
293 | while( iLeft > 0 ) | ||
294 | { | ||
295 | int32_t iWrite = rBacking.write( pChunk, std::min( iChunk, iLeft ) ); | ||
296 | iLeft -= iWrite; | ||
297 | } | ||
298 | delete[] pChunk; | ||
299 | } | ||
300 | |||
267 | void Bu::Myriad::openStream( StreamId id ) | 301 | void Bu::Myriad::openStream( StreamId id ) |
268 | { | 302 | { |
269 | Bu::MutexLocker l( mAccess ); | 303 | Bu::MutexLocker l( mAccess ); |
@@ -276,20 +310,36 @@ void Bu::Myriad::closeStream( StreamId id ) | |||
276 | hStream.get( id )->close(); | 310 | hStream.get( id )->close(); |
277 | } | 311 | } |
278 | 312 | ||
279 | int32_t Bu::Myriad::blockRead( int32_t iStart, void *pTarget, int32_t iSize ) | 313 | int32_t Bu::Myriad::blockRead( int32_t iBlock, int32_t iStart, |
314 | void *pTarget, int32_t iSize ) | ||
280 | { | 315 | { |
281 | int32_t iUpperSize = iBlockSize - (iStart%iBlockSize); | 316 | int32_t iUpperSize = iBlockSize - (iStart%iBlockSize); |
282 | Bu::println("Max size within block: %1 vs %2 (start=%3, blocksize=%4)") | 317 | Bu::println("Max read within block: %1 vs %2 (start=%3, blocksize=%4)") |
283 | .arg( iUpperSize ).arg( iSize ) | 318 | .arg( iUpperSize ).arg( iSize ) |
284 | .arg( iStart ).arg( iBlockSize ); | 319 | .arg( iStart ).arg( iBlockSize ); |
285 | 320 | ||
286 | int32_t iAmnt = std::min( iSize, iUpperSize ); | 321 | int32_t iAmnt = std::min( iSize, iUpperSize ); |
287 | Bu::MutexLocker l( mBacking ); | 322 | Bu::MutexLocker l( mBacking ); |
288 | rBacking.setPos( iStart ); | 323 | rBacking.setPos( iBlockSize*iBlock + iStart ); |
289 | 324 | ||
290 | return rBacking.read( pTarget, iAmnt ); | 325 | return rBacking.read( pTarget, iAmnt ); |
291 | } | 326 | } |
292 | 327 | ||
328 | int32_t Bu::Myriad::blockWrite( int32_t iBlock, int32_t iStart, | ||
329 | const void *pTarget, int32_t iSize ) | ||
330 | { | ||
331 | int32_t iUpperSize = iBlockSize - (iStart%iBlockSize); | ||
332 | Bu::println("Max write within block: %1 vs %2 (start=%3, blocksize=%4)") | ||
333 | .arg( iUpperSize ).arg( iSize ) | ||
334 | .arg( iStart ).arg( iBlockSize ); | ||
335 | |||
336 | int32_t iAmnt = std::min( iSize, iUpperSize ); | ||
337 | Bu::MutexLocker l( mBacking ); | ||
338 | rBacking.setPos( iBlock*iBlockSize + iStart ); | ||
339 | |||
340 | return rBacking.write( pTarget, iAmnt ); | ||
341 | } | ||
342 | |||
293 | ///////// | 343 | ///////// |
294 | // Bu::Myriad::Stream | 344 | // Bu::Myriad::Stream |
295 | // | 345 | // |
@@ -308,22 +358,71 @@ Bu::Myriad::Stream::~Stream() | |||
308 | { | 358 | { |
309 | } | 359 | } |
310 | 360 | ||
361 | int32_t Bu::Myriad::Stream::getSize() const | ||
362 | { | ||
363 | Bu::MutexLocker l( mAccess ); | ||
364 | return iSize; | ||
365 | } | ||
366 | |||
367 | int32_t Bu::Myriad::Stream::getBlockSize() const | ||
368 | { | ||
369 | Bu::MutexLocker l( mAccess ); | ||
370 | return rParent.iBlockSize; | ||
371 | } | ||
372 | |||
373 | Bu::Myriad::StreamId Bu::Myriad::Stream::getStreamId() const | ||
374 | { | ||
375 | return iStream; | ||
376 | } | ||
377 | |||
378 | int32_t Bu::Myriad::Stream::getOpenCount() const | ||
379 | { | ||
380 | Bu::MutexLocker l( mAccess ); | ||
381 | return iOpenCount; | ||
382 | } | ||
383 | |||
384 | void Bu::Myriad::Stream::setSize( int32_t iNewSize ) | ||
385 | { | ||
386 | // Two possible modes, shrink or grow. | ||
387 | Bu::MutexLocker l( mAccess ); | ||
388 | if( iNewSize < iSize ) | ||
389 | { | ||
390 | // Shrink it | ||
391 | int iNewBlocks = Bu::blkDiv( iNewSize, rParent.iBlockSize ); | ||
392 | while( aBlocks.getSize() > iNewBlocks ) | ||
393 | { | ||
394 | rParent.releaseBlock( aBlocks.last(), false ); | ||
395 | aBlocks.eraseLast(); | ||
396 | } | ||
397 | iSize = iNewSize; | ||
398 | } | ||
399 | else if( iNewSize > iSize ) | ||
400 | { | ||
401 | // Grow it | ||
402 | int iNewBlocks = Bu::blkDiv( iNewSize, rParent.iBlockSize ); | ||
403 | while( aBlocks.getSize() < iNewBlocks ) | ||
404 | { | ||
405 | aBlocks.append( rParent.allocateBlock() ); | ||
406 | } | ||
407 | iSize = iNewSize; | ||
408 | } | ||
409 | } | ||
410 | |||
311 | int32_t Bu::Myriad::Stream::read( int32_t iStart, void *pTarget, | 411 | int32_t Bu::Myriad::Stream::read( int32_t iStart, void *pTarget, |
312 | int32_t iSize ) | 412 | int32_t iSize ) |
313 | { | 413 | { |
314 | int32_t iPos = iStart; | ||
315 | int32_t iRead = 0; | 414 | int32_t iRead = 0; |
316 | Bu::MutexLocker l( mAccess ); | 415 | Bu::MutexLocker l( mAccess ); |
317 | while( iStart > 0 ) | 416 | while( iSize > 0 ) |
318 | { | 417 | { |
319 | int32_t iBlock = aBlocks[iStart/rParent.iBlockSize]; | 418 | int32_t iBlock = aBlocks[iStart/rParent.iBlockSize]; |
320 | int32_t iOffset = iPos % rParent.iBlockSize; | ||
321 | int32_t iChunkRead = rParent.blockRead( | 419 | int32_t iChunkRead = rParent.blockRead( |
322 | iBlock*rParent.iBlockSize+iOffset, pTarget, iSize | 420 | iBlock, iStart%rParent.iBlockSize, pTarget, iSize |
323 | ); | 421 | ); |
324 | if( iChunkRead == 0 ) | 422 | if( iChunkRead == 0 ) |
325 | break; | 423 | break; |
326 | iRead += iChunkRead; | 424 | iRead += iChunkRead; |
425 | iStart += iChunkRead; | ||
327 | reinterpret_cast<ptrdiff_t &>(pTarget) += iChunkRead; | 426 | reinterpret_cast<ptrdiff_t &>(pTarget) += iChunkRead; |
328 | iSize -= iChunkRead; | 427 | iSize -= iChunkRead; |
329 | } | 428 | } |
@@ -331,6 +430,36 @@ int32_t Bu::Myriad::Stream::read( int32_t iStart, void *pTarget, | |||
331 | return iRead; | 430 | return iRead; |
332 | } | 431 | } |
333 | 432 | ||
433 | int32_t Bu::Myriad::Stream::write( int32_t iStart, const void *pTarget, | ||
434 | int32_t iSize ) | ||
435 | { | ||
436 | int32_t iWrite = 0; | ||
437 | Bu::MutexLocker l( mAccess ); | ||
438 | while( iSize > 0 ) | ||
439 | { | ||
440 | int32_t iBlockIdx = iStart/rParent.iBlockSize; | ||
441 | int32_t iBlock = aBlocks[iBlockIdx]; | ||
442 | int32_t iChunkWrite = rParent.blockWrite( | ||
443 | iBlock, iStart%rParent.iBlockSize, pTarget, iSize | ||
444 | ); | ||
445 | if( iChunkWrite == 0 ) | ||
446 | break; | ||
447 | iWrite += iChunkWrite; | ||
448 | iStart += iChunkWrite; | ||
449 | reinterpret_cast<ptrdiff_t &>(pTarget) += iChunkWrite; | ||
450 | iSize -= iChunkWrite; | ||
451 | } | ||
452 | |||
453 | return iWrite; | ||
454 | } | ||
455 | |||
456 | Bu::String Bu::Myriad::Stream::getLocation() const | ||
457 | { | ||
458 | Bu::MutexLocker l( mAccess ); | ||
459 | return Bu::String("%1:stream %2")\ | ||
460 | .arg( rParent.getLocation() ).arg( iStream ); | ||
461 | } | ||
462 | |||
334 | void Bu::Myriad::Stream::open() | 463 | void Bu::Myriad::Stream::open() |
335 | { | 464 | { |
336 | Bu::MutexLocker l( mAccess ); | 465 | Bu::MutexLocker l( mAccess ); |
diff --git a/src/stable/myriad.h b/src/stable/myriad.h index 07b4a1d..6d99ee4 100644 --- a/src/stable/myriad.h +++ b/src/stable/myriad.h | |||
@@ -75,11 +75,14 @@ namespace Bu | |||
75 | MyriadStream open( StreamId iStream, Mode eMode ); | 75 | MyriadStream open( StreamId iStream, Mode eMode ); |
76 | bool erase( StreamId iStream ); | 76 | bool erase( StreamId iStream ); |
77 | bool setSize( StreamId iStream, int32_t iNewSize ); | 77 | bool setSize( StreamId iStream, int32_t iNewSize ); |
78 | Bu::String getLocation() const; | ||
78 | 79 | ||
79 | private: | 80 | private: |
80 | bool loadMyriad(); | 81 | bool loadMyriad(); |
81 | void createMyriad( int32_t iBlockSize, int32_t iPreallocateBlocks ); | 82 | void createMyriad( int32_t iBlockSize, int32_t iPreallocateBlocks ); |
82 | int32_t allocateBlock(); | 83 | int32_t allocateBlock(); |
84 | void releaseBlock( int32_t iBlockId, bool bBlank=true ); | ||
85 | void blankBlock( int32_t iBlockId ); | ||
83 | 86 | ||
84 | void openStream( StreamId id ); | 87 | void openStream( StreamId id ); |
85 | void closeStream( StreamId id ); | 88 | void closeStream( StreamId id ); |
@@ -87,7 +90,16 @@ namespace Bu | |||
87 | * Block restricted read, it will not read past the end of the block | 90 | * Block restricted read, it will not read past the end of the block |
88 | * that iStart places it in. | 91 | * that iStart places it in. |
89 | */ | 92 | */ |
90 | int32_t blockRead( int32_t iStart, void *pTarget, int32_t iSize ); | 93 | int32_t blockRead( int32_t iBlock, int32_t iStart, |
94 | void *pTarget, int32_t iSize ); | ||
95 | |||
96 | /** | ||
97 | * Block restricted write, it will not write past the end of the block | ||
98 | * that iStart places it in. If this returns a non-zero number it's an | ||
99 | * indication that you need to allocate a new block. | ||
100 | */ | ||
101 | int32_t blockWrite( int32_t iBlock, int32_t iStart, | ||
102 | const void *pTarget, int32_t iSize ); | ||
91 | 103 | ||
92 | public: | 104 | public: |
93 | /** | 105 | /** |
@@ -103,7 +115,15 @@ namespace Bu | |||
103 | virtual ~Stream(); | 115 | virtual ~Stream(); |
104 | 116 | ||
105 | public: | 117 | public: |
118 | int32_t getSize() const; | ||
119 | int32_t getBlockSize() const; | ||
120 | StreamId getStreamId() const; | ||
121 | int32_t getOpenCount() const; | ||
122 | |||
123 | void setSize( int32_t iNewSize ); | ||
106 | int32_t read( int32_t iStart, void *pTarget, int32_t iSize ); | 124 | int32_t read( int32_t iStart, void *pTarget, int32_t iSize ); |
125 | int32_t write( int32_t iStart, const void *pTarget, int32_t iSize ); | ||
126 | Bu::String getLocation() const; | ||
107 | 127 | ||
108 | /** | 128 | /** |
109 | * Doesn't actually open, just increments the open counter. | 129 | * Doesn't actually open, just increments the open counter. |
@@ -134,7 +154,7 @@ namespace Bu | |||
134 | typedef Bu::Hash<StreamId, Stream *> StreamHash; | 154 | typedef Bu::Hash<StreamId, Stream *> StreamHash; |
135 | 155 | ||
136 | typedef Bu::List<int32_t> IndexList; | 156 | typedef Bu::List<int32_t> IndexList; |
137 | Bu::Mutex mAccess; | 157 | mutable Bu::Mutex mAccess; |
138 | mutable Bu::Mutex mBacking; | 158 | mutable Bu::Mutex mBacking; |
139 | Bu::Stream &rBacking; | 159 | Bu::Stream &rBacking; |
140 | int32_t iBlockSize; | 160 | int32_t iBlockSize; |
diff --git a/src/stable/myriadstream.cpp b/src/stable/myriadstream.cpp index cbbd4fe..9ea2e17 100644 --- a/src/stable/myriadstream.cpp +++ b/src/stable/myriadstream.cpp | |||
@@ -6,7 +6,8 @@ Bu::MyriadStream::MyriadStream( Bu::Myriad &rMyriad, | |||
6 | Bu::Myriad::Stream *pStream, Bu::Myriad::Mode eMode ) : | 6 | Bu::Myriad::Stream *pStream, Bu::Myriad::Mode eMode ) : |
7 | rMyriad( rMyriad ), | 7 | rMyriad( rMyriad ), |
8 | pStream( pStream ), | 8 | pStream( pStream ), |
9 | eMode( eMode ) | 9 | eMode( eMode ), |
10 | iPos( 0 ) | ||
10 | { | 11 | { |
11 | if( (eMode&Bu::Myriad::ReadWrite) == 0 ) | 12 | if( (eMode&Bu::Myriad::ReadWrite) == 0 ) |
12 | { | 13 | { |
@@ -15,6 +16,20 @@ Bu::MyriadStream::MyriadStream( Bu::Myriad &rMyriad, | |||
15 | } | 16 | } |
16 | Bu::MutexLocker l( mAccess ); | 17 | Bu::MutexLocker l( mAccess ); |
17 | pStream->open(); | 18 | pStream->open(); |
19 | |||
20 | if( (eMode&Bu::Myriad::Write) != 0 ) | ||
21 | { | ||
22 | // Writing mode, what other options do we deal with? | ||
23 | if( (eMode&Bu::Myriad::Truncate) != 0 ) | ||
24 | { | ||
25 | // Truncate, set size to zero before starting. | ||
26 | pStream->setSize( 0 ); | ||
27 | } | ||
28 | else if( (eMode&Bu::Myriad::Append) != 0 ) | ||
29 | { | ||
30 | iPos = pStream->getSize(); | ||
31 | } | ||
32 | } | ||
18 | } | 33 | } |
19 | 34 | ||
20 | Bu::MyriadStream::~MyriadStream() | 35 | Bu::MyriadStream::~MyriadStream() |
@@ -34,93 +49,120 @@ void Bu::MyriadStream::close() | |||
34 | 49 | ||
35 | Bu::size Bu::MyriadStream::read( void *pBuf, size iBytes ) | 50 | Bu::size Bu::MyriadStream::read( void *pBuf, size iBytes ) |
36 | { | 51 | { |
37 | } | 52 | Bu::MutexLocker l( mAccess ); |
38 | 53 | int32_t iRead = pStream->read( iPos, pBuf, iBytes ); | |
39 | Bu::String Bu::MyriadStream::readLine() | 54 | iPos += iRead; |
40 | { | 55 | return iRead; |
41 | } | ||
42 | |||
43 | Bu::String Bu::MyriadStream::readAll() | ||
44 | { | ||
45 | } | 56 | } |
46 | 57 | ||
47 | Bu::size Bu::MyriadStream::write( const void *pBuf, size iBytes ) | 58 | Bu::size Bu::MyriadStream::write( const void *pBuf, size iBytes ) |
48 | { | 59 | { |
49 | } | 60 | Bu::MutexLocker l( mAccess ); |
50 | 61 | int32_t iWrite = pStream->write( iPos, pBuf, iBytes ); | |
51 | Bu::size Bu::MyriadStream::write( const Bu::String &sBuf ) | 62 | iPos += iWrite; |
52 | { | 63 | return iWrite; |
53 | } | 64 | } |
54 | 65 | ||
55 | Bu::size Bu::MyriadStream::tell() | 66 | Bu::size Bu::MyriadStream::tell() |
56 | { | 67 | { |
68 | Bu::MutexLocker l( mAccess ); | ||
69 | return iPos; | ||
57 | } | 70 | } |
58 | 71 | ||
59 | void Bu::MyriadStream::seek( size offset ) | 72 | void Bu::MyriadStream::seek( size offset ) |
60 | { | 73 | { |
74 | Bu::MutexLocker l( mAccess ); | ||
75 | iPos += offset; | ||
61 | } | 76 | } |
62 | 77 | ||
63 | void Bu::MyriadStream::setPos( size pos ) | 78 | void Bu::MyriadStream::setPos( size pos ) |
64 | { | 79 | { |
80 | Bu::MutexLocker l( mAccess ); | ||
81 | iPos = pos; | ||
65 | } | 82 | } |
66 | 83 | ||
67 | void Bu::MyriadStream::setPosEnd( size pos ) | 84 | void Bu::MyriadStream::setPosEnd( size pos ) |
68 | { | 85 | { |
86 | Bu::MutexLocker l( mAccess ); | ||
87 | iPos = pStream->getSize()-pos; | ||
69 | } | 88 | } |
70 | 89 | ||
71 | bool Bu::MyriadStream::isEos() | 90 | bool Bu::MyriadStream::isEos() |
72 | { | 91 | { |
92 | Bu::MutexLocker l( mAccess ); | ||
93 | return iPos == pStream->getSize(); | ||
73 | } | 94 | } |
74 | 95 | ||
75 | bool Bu::MyriadStream::isOpen() | 96 | bool Bu::MyriadStream::isOpen() |
76 | { | 97 | { |
98 | return true; | ||
77 | } | 99 | } |
78 | 100 | ||
79 | void Bu::MyriadStream::flush() | 101 | void Bu::MyriadStream::flush() |
80 | { | 102 | { |
103 | // Does this make sense? | ||
81 | } | 104 | } |
82 | 105 | ||
83 | bool Bu::MyriadStream::canRead() | 106 | bool Bu::MyriadStream::canRead() |
84 | { | 107 | { |
108 | return true; | ||
85 | } | 109 | } |
86 | 110 | ||
87 | bool Bu::MyriadStream::canWrite() | 111 | bool Bu::MyriadStream::canWrite() |
88 | { | 112 | { |
113 | return true; | ||
89 | } | 114 | } |
90 | 115 | ||
91 | bool Bu::MyriadStream::isReadable() | 116 | bool Bu::MyriadStream::isReadable() |
92 | { | 117 | { |
118 | Bu::MutexLocker l( mAccess ); | ||
119 | return (eMode&Bu::Myriad::Read) != 0; | ||
93 | } | 120 | } |
94 | 121 | ||
95 | bool Bu::MyriadStream::isWritable() | 122 | bool Bu::MyriadStream::isWritable() |
96 | { | 123 | { |
124 | Bu::MutexLocker l( mAccess ); | ||
125 | return (eMode&Bu::Myriad::Write) != 0; | ||
97 | } | 126 | } |
98 | 127 | ||
99 | bool Bu::MyriadStream::isSeekable() | 128 | bool Bu::MyriadStream::isSeekable() |
100 | { | 129 | { |
130 | return true; | ||
101 | } | 131 | } |
102 | 132 | ||
103 | bool Bu::MyriadStream::isBlocking() | 133 | bool Bu::MyriadStream::isBlocking() |
104 | { | 134 | { |
135 | return true; | ||
105 | } | 136 | } |
106 | 137 | ||
107 | void Bu::MyriadStream::setBlocking( bool bBlocking ) | 138 | void Bu::MyriadStream::setBlocking( bool /*bBlocking*/ ) |
108 | { | 139 | { |
140 | // Dunno what this would even mean here. | ||
109 | } | 141 | } |
110 | 142 | ||
111 | void Bu::MyriadStream::setSize( size iSize ) | 143 | void Bu::MyriadStream::setSize( size iSize ) |
112 | { | 144 | { |
145 | Bu::MutexLocker l( mAccess ); | ||
146 | pStream->setSize( iSize ); | ||
147 | if( iPos > iSize ) | ||
148 | iPos = iSize; | ||
113 | } | 149 | } |
114 | 150 | ||
115 | Bu::size Bu::MyriadStream::getSize() const | 151 | Bu::size Bu::MyriadStream::getSize() const |
116 | { | 152 | { |
153 | Bu::MutexLocker l( mAccess ); | ||
154 | return pStream->getSize(); | ||
117 | } | 155 | } |
118 | 156 | ||
119 | Bu::size Bu::MyriadStream::getBlockSize() const | 157 | Bu::size Bu::MyriadStream::getBlockSize() const |
120 | { | 158 | { |
159 | Bu::MutexLocker l( mAccess ); | ||
160 | return pStream->getBlockSize(); | ||
121 | } | 161 | } |
122 | 162 | ||
123 | Bu::String getLocation() const | 163 | Bu::String Bu::MyriadStream::getLocation() const |
124 | { | 164 | { |
165 | Bu::MutexLocker l( mAccess ); | ||
166 | return pStream->getLocation(); | ||
125 | } | 167 | } |
126 | 168 | ||
diff --git a/src/stable/myriadstream.h b/src/stable/myriadstream.h index 87192a9..c01cf34 100644 --- a/src/stable/myriadstream.h +++ b/src/stable/myriadstream.h | |||
@@ -18,10 +18,7 @@ namespace Bu | |||
18 | public: | 18 | public: |
19 | virtual void close(); | 19 | virtual void close(); |
20 | virtual size read( void *pBuf, size iBytes ); | 20 | virtual size read( void *pBuf, size iBytes ); |
21 | virtual Bu::String readLine(); | ||
22 | virtual Bu::String readAll(); | ||
23 | virtual size write( const void *pBuf, size iBytes ); | 21 | virtual size write( const void *pBuf, size iBytes ); |
24 | virtual size write( const Bu::String &sBuf ); | ||
25 | virtual size tell(); | 22 | virtual size tell(); |
26 | virtual void seek( size offset ); | 23 | virtual void seek( size offset ); |
27 | virtual void setPos( size pos ); | 24 | virtual void setPos( size pos ); |
@@ -46,6 +43,7 @@ namespace Bu | |||
46 | Bu::Myriad &rMyriad; | 43 | Bu::Myriad &rMyriad; |
47 | Bu::Myriad::Stream *pStream; | 44 | Bu::Myriad::Stream *pStream; |
48 | Bu::Myriad::Mode eMode; | 45 | Bu::Myriad::Mode eMode; |
46 | int32_t iPos; | ||
49 | }; | 47 | }; |
50 | }; | 48 | }; |
51 | 49 | ||