diff options
author | Mike Buland <eichlan@xagasoft.com> | 2010-05-24 15:10:19 +0000 |
---|---|---|
committer | Mike Buland <eichlan@xagasoft.com> | 2010-05-24 15:10:19 +0000 |
commit | ecc191f590f76584a14c9c51727412b0b7b3086e (patch) | |
tree | b27ee434ed541ba3a386ff6a3238f66b9451ef22 | |
parent | 71191e311d949b1b7bdd74fc36a14306f492c181 (diff) | |
download | libbu++-ecc191f590f76584a14c9c51727412b0b7b3086e.tar.gz libbu++-ecc191f590f76584a14c9c51727412b0b7b3086e.tar.bz2 libbu++-ecc191f590f76584a14c9c51727412b0b7b3086e.tar.xz libbu++-ecc191f590f76584a14c9c51727412b0b7b3086e.zip |
Changed the Bu::Stream API, setSize is now standard. There may be a few more
things that should be added. A few of them still need to be implemented. I
know that truncate for Bu::File is possible on windows, I've used it before, but
hell if I can find it. Myriad also needs the setSize function completed.
Diffstat (limited to '')
-rw-r--r-- | src/file.cpp | 14 | ||||
-rw-r--r-- | src/file.h | 12 | ||||
-rw-r--r-- | src/filter.cpp | 4 | ||||
-rw-r--r-- | src/filter.h | 6 | ||||
-rw-r--r-- | src/membuf.cpp | 9 | ||||
-rw-r--r-- | src/membuf.h | 1 | ||||
-rw-r--r-- | src/myriad.cpp | 6 | ||||
-rw-r--r-- | src/myriad.h | 2 | ||||
-rw-r--r-- | src/myriadstream.cpp | 7 | ||||
-rw-r--r-- | src/myriadstream.h | 1 | ||||
-rw-r--r-- | src/process.cpp | 4 | ||||
-rw-r--r-- | src/process.h | 2 | ||||
-rw-r--r-- | src/queuebuf.cpp | 4 | ||||
-rw-r--r-- | src/queuebuf.h | 1 | ||||
-rw-r--r-- | src/socket.cpp | 4 | ||||
-rw-r--r-- | src/socket.h | 2 | ||||
-rw-r--r-- | src/stdstream.cpp | 4 | ||||
-rw-r--r-- | src/stdstream.h | 1 | ||||
-rw-r--r-- | src/stream.h | 8 | ||||
-rw-r--r-- | src/unit/myriad.unit | 2 | ||||
-rw-r--r-- | src/unitsuite.cpp | 14 | ||||
-rw-r--r-- | src/unitsuite.h | 5 |
22 files changed, 101 insertions, 12 deletions
diff --git a/src/file.cpp b/src/file.cpp index f1f63e4..a0c3fd8 100644 --- a/src/file.cpp +++ b/src/file.cpp | |||
@@ -187,19 +187,27 @@ void Bu::File::setBlocking( bool bBlocking ) | |||
187 | #endif | 187 | #endif |
188 | } | 188 | } |
189 | 189 | ||
190 | #ifndef WIN32 | ||
191 | Bu::File Bu::File::tempFile( Bu::FString &sName ) | 190 | Bu::File Bu::File::tempFile( Bu::FString &sName ) |
192 | { | 191 | { |
192 | #ifndef WIN32 | ||
193 | int afh_d = mkstemp( sName.getStr() ); | 193 | int afh_d = mkstemp( sName.getStr() ); |
194 | 194 | ||
195 | return Bu::File( afh_d ); | 195 | return Bu::File( afh_d ); |
196 | #else | ||
197 | return Bu::File( sName, Bu::File::Write|Bu::File::Create ); | ||
198 | #endif | ||
196 | } | 199 | } |
197 | 200 | ||
198 | void Bu::File::truncate( long nSize ) | 201 | void Bu::File::setSize( long iSize ) |
199 | { | 202 | { |
200 | ftruncate( fd, nSize ); | 203 | #ifndef WIN32 |
204 | ftruncate( fd, iSize ); | ||
205 | #else | ||
206 | #warning Bu::File::setSize not implemented on this platform | ||
207 | #endif | ||
201 | } | 208 | } |
202 | 209 | ||
210 | #ifndef WIN32 | ||
203 | void Bu::File::chmod( mode_t t ) | 211 | void Bu::File::chmod( mode_t t ) |
204 | { | 212 | { |
205 | fchmod( fd, t ); | 213 | fchmod( fd, t ); |
@@ -69,6 +69,9 @@ namespace Bu | |||
69 | WriteNew = 0x0E ///< Create a file (or truncate) for writing. | 69 | WriteNew = 0x0E ///< Create a file (or truncate) for writing. |
70 | /// Same as Write|Create|Truncate | 70 | /// Same as Write|Create|Truncate |
71 | }; | 71 | }; |
72 | |||
73 | virtual void setSize( long iSize ); | ||
74 | |||
72 | /** | 75 | /** |
73 | * Create a temp file and return its handle. The file is opened | 76 | * Create a temp file and return its handle. The file is opened |
74 | * Read/Write. | 77 | * Read/Write. |
@@ -77,16 +80,9 @@ namespace Bu | |||
77 | * characters. | 80 | * characters. |
78 | *@returns (Bu::File) A file object representing your temp file. | 81 | *@returns (Bu::File) A file object representing your temp file. |
79 | */ | 82 | */ |
80 | #ifndef WIN32 | ||
81 | static Bu::File tempFile( Bu::FString &sName ); | 83 | static Bu::File tempFile( Bu::FString &sName ); |
82 | 84 | ||
83 | /** | 85 | #ifndef WIN32 |
84 | * Set the size of the file to (nSize). You can either grow or shrink | ||
85 | * the file. | ||
86 | *@param nSize (long) The new size of the file. | ||
87 | */ | ||
88 | void truncate( long nSize ); | ||
89 | |||
90 | /** | 86 | /** |
91 | * Change the file access permissions. | 87 | * Change the file access permissions. |
92 | *@param t (mode_t) The new file access permissions. | 88 | *@param t (mode_t) The new file access permissions. |
diff --git a/src/filter.cpp b/src/filter.cpp index 4208555..8dc3694 100644 --- a/src/filter.cpp +++ b/src/filter.cpp | |||
@@ -87,6 +87,10 @@ void Bu::Filter::setBlocking( bool bBlocking ) | |||
87 | rNext.setBlocking( bBlocking ); | 87 | rNext.setBlocking( bBlocking ); |
88 | } | 88 | } |
89 | 89 | ||
90 | void Bu::Filter::setSize( long iSize ) | ||
91 | { | ||
92 | } | ||
93 | |||
90 | void Bu::Filter::flush() | 94 | void Bu::Filter::flush() |
91 | { | 95 | { |
92 | rNext.flush(); | 96 | rNext.flush(); |
diff --git a/src/filter.h b/src/filter.h index 67ffce2..5507daa 100644 --- a/src/filter.h +++ b/src/filter.h | |||
@@ -62,6 +62,12 @@ namespace Bu | |||
62 | virtual bool isBlocking(); | 62 | virtual bool isBlocking(); |
63 | virtual void setBlocking( bool bBlocking=true ); | 63 | virtual void setBlocking( bool bBlocking=true ); |
64 | 64 | ||
65 | /** | ||
66 | * Most filters won't re-implement this, it doesn't make a lot of sense | ||
67 | * for filters, in general. | ||
68 | */ | ||
69 | virtual void setSize( long iSize ); | ||
70 | |||
65 | protected: | 71 | protected: |
66 | Bu::Stream &rNext; | 72 | Bu::Stream &rNext; |
67 | 73 | ||
diff --git a/src/membuf.cpp b/src/membuf.cpp index 0c1c441..b822641 100644 --- a/src/membuf.cpp +++ b/src/membuf.cpp | |||
@@ -140,6 +140,15 @@ void Bu::MemBuf::setBlocking( bool ) | |||
140 | { | 140 | { |
141 | } | 141 | } |
142 | 142 | ||
143 | void Bu::MemBuf::setSize( long iSize ) | ||
144 | { | ||
145 | if( iSize < 0 ) | ||
146 | iSize = 0; | ||
147 | sBuf.setSize( iSize ); | ||
148 | if( nPos > iSize ) | ||
149 | nPos = iSize; | ||
150 | } | ||
151 | |||
143 | Bu::FString &Bu::MemBuf::getString() | 152 | Bu::FString &Bu::MemBuf::getString() |
144 | { | 153 | { |
145 | return sBuf; | 154 | return sBuf; |
diff --git a/src/membuf.h b/src/membuf.h index c6c8079..9e406c1 100644 --- a/src/membuf.h +++ b/src/membuf.h | |||
@@ -45,6 +45,7 @@ namespace Bu | |||
45 | virtual bool isSeekable(); | 45 | virtual bool isSeekable(); |
46 | virtual bool isBlocking(); | 46 | virtual bool isBlocking(); |
47 | virtual void setBlocking( bool bBlocking=true ); | 47 | virtual void setBlocking( bool bBlocking=true ); |
48 | virtual void setSize( long iSize ); | ||
48 | 49 | ||
49 | Bu::FString &getString(); | 50 | Bu::FString &getString(); |
50 | void setString( const Bu::FString &sNewData ); | 51 | void setString( const Bu::FString &sNewData ); |
diff --git a/src/myriad.cpp b/src/myriad.cpp index 4476d53..044e35e 100644 --- a/src/myriad.cpp +++ b/src/myriad.cpp | |||
@@ -426,3 +426,9 @@ void Bu::Myriad::syncBlock( Block *pBlock ) | |||
426 | } | 426 | } |
427 | } | 427 | } |
428 | 428 | ||
429 | void Bu::Myriad::setStreamSize( Stream *pStream, long iSize ) | ||
430 | { | ||
431 | sio << "Oh man, you have to implement Bu::Myriad::setStreamSize!!! (line " | ||
432 | << __LINE__ << ")" << sio.nl; | ||
433 | } | ||
434 | |||
diff --git a/src/myriad.h b/src/myriad.h index 9bbc812..8e7cfb1 100644 --- a/src/myriad.h +++ b/src/myriad.h | |||
@@ -150,6 +150,8 @@ namespace Bu | |||
150 | void releaseBlock( Block *pBlock ); | 150 | void releaseBlock( Block *pBlock ); |
151 | void syncBlock( Block *pBlock ); | 151 | void syncBlock( Block *pBlock ); |
152 | 152 | ||
153 | void setStreamSize( Stream *pStream, long iSize ); | ||
154 | |||
153 | private: | 155 | private: |
154 | Bu::Stream &sStore; | 156 | Bu::Stream &sStore; |
155 | int iBlockSize; | 157 | int iBlockSize; |
diff --git a/src/myriadstream.cpp b/src/myriadstream.cpp index 2218ae4..41c5b53 100644 --- a/src/myriadstream.cpp +++ b/src/myriadstream.cpp | |||
@@ -281,3 +281,10 @@ void Bu::MyriadStream::setBlocking( bool /*bBlocking*/ ) | |||
281 | { | 281 | { |
282 | } | 282 | } |
283 | 283 | ||
284 | void Bu::MyriadStream::setSize( long iSize ) | ||
285 | { | ||
286 | rMyriad.setStreamSize( pStream, iSize ); | ||
287 | if( iPos > iSize ) | ||
288 | iPos = iSize; | ||
289 | } | ||
290 | |||
diff --git a/src/myriadstream.h b/src/myriadstream.h index e2e3ba7..1a5e552 100644 --- a/src/myriadstream.h +++ b/src/myriadstream.h | |||
@@ -43,6 +43,7 @@ namespace Bu | |||
43 | virtual bool isSeekable(); | 43 | virtual bool isSeekable(); |
44 | virtual bool isBlocking(); | 44 | virtual bool isBlocking(); |
45 | virtual void setBlocking( bool bBlocking=true ); | 45 | virtual void setBlocking( bool bBlocking=true ); |
46 | virtual void setSize( long iSize ); | ||
46 | 47 | ||
47 | private: | 48 | private: |
48 | Myriad &rMyriad; | 49 | Myriad &rMyriad; |
diff --git a/src/process.cpp b/src/process.cpp index 7cb5983..2d8eda0 100644 --- a/src/process.cpp +++ b/src/process.cpp | |||
@@ -278,6 +278,10 @@ void Bu::Process::setBlocking( bool bBlocking ) | |||
278 | this->bBlocking = bBlocking; | 278 | this->bBlocking = bBlocking; |
279 | } | 279 | } |
280 | 280 | ||
281 | void Bu::Process::setSize( long iSize ) | ||
282 | { | ||
283 | } | ||
284 | |||
281 | void Bu::Process::select( bool &bStdOut, bool &bStdErr ) | 285 | void Bu::Process::select( bool &bStdOut, bool &bStdErr ) |
282 | { | 286 | { |
283 | fd_set rfds; | 287 | fd_set rfds; |
diff --git a/src/process.h b/src/process.h index 3fcf1f2..68678bd 100644 --- a/src/process.h +++ b/src/process.h | |||
@@ -68,6 +68,8 @@ namespace Bu | |||
68 | virtual bool isBlocking(); | 68 | virtual bool isBlocking(); |
69 | virtual void setBlocking( bool bBlocking=true ); | 69 | virtual void setBlocking( bool bBlocking=true ); |
70 | 70 | ||
71 | virtual void setSize( long iSize ); | ||
72 | |||
71 | void select( bool &bStdOut, bool &bStdErr ); | 73 | void select( bool &bStdOut, bool &bStdErr ); |
72 | 74 | ||
73 | bool isRunning(); | 75 | bool isRunning(); |
diff --git a/src/queuebuf.cpp b/src/queuebuf.cpp index 01d92f8..1a902bc 100644 --- a/src/queuebuf.cpp +++ b/src/queuebuf.cpp | |||
@@ -249,6 +249,10 @@ void Bu::QueueBuf::setBlocking( bool ) | |||
249 | { | 249 | { |
250 | } | 250 | } |
251 | 251 | ||
252 | void Bu::QueueBuf::setSize( long iSize ) | ||
253 | { | ||
254 | } | ||
255 | |||
252 | void Bu::QueueBuf::addBlock() | 256 | void Bu::QueueBuf::addBlock() |
253 | { | 257 | { |
254 | lBlocks.append( new char[iBlockSize] ); | 258 | lBlocks.append( new char[iBlockSize] ); |
diff --git a/src/queuebuf.h b/src/queuebuf.h index 382863d..395c6ba 100644 --- a/src/queuebuf.h +++ b/src/queuebuf.h | |||
@@ -45,6 +45,7 @@ namespace Bu | |||
45 | virtual bool isSeekable(); | 45 | virtual bool isSeekable(); |
46 | virtual bool isBlocking(); | 46 | virtual bool isBlocking(); |
47 | virtual void setBlocking( bool bBlocking=true ); | 47 | virtual void setBlocking( bool bBlocking=true ); |
48 | virtual void setSize( long iSize ); | ||
48 | 49 | ||
49 | private: | 50 | private: |
50 | void addBlock(); | 51 | void addBlock(); |
diff --git a/src/socket.cpp b/src/socket.cpp index 6a30f44..41e0763 100644 --- a/src/socket.cpp +++ b/src/socket.cpp | |||
@@ -405,6 +405,10 @@ void Bu::Socket::setBlocking( bool bBlocking ) | |||
405 | #endif | 405 | #endif |
406 | } | 406 | } |
407 | 407 | ||
408 | void Bu::Socket::setSize( long iSize ) | ||
409 | { | ||
410 | } | ||
411 | |||
408 | void Bu::Socket::flush() | 412 | void Bu::Socket::flush() |
409 | { | 413 | { |
410 | } | 414 | } |
diff --git a/src/socket.h b/src/socket.h index f907b95..c8f78f0 100644 --- a/src/socket.h +++ b/src/socket.h | |||
@@ -92,6 +92,8 @@ namespace Bu | |||
92 | virtual bool isBlocking(); | 92 | virtual bool isBlocking(); |
93 | virtual void setBlocking( bool bBlocking=true ); | 93 | virtual void setBlocking( bool bBlocking=true ); |
94 | 94 | ||
95 | virtual void setSize( long iSize ); | ||
96 | |||
95 | Bu::FString getAddress() const; | 97 | Bu::FString getAddress() const; |
96 | operator int() const; | 98 | operator int() const; |
97 | 99 | ||
diff --git a/src/stdstream.cpp b/src/stdstream.cpp index fb6cd36..4c2c828 100644 --- a/src/stdstream.cpp +++ b/src/stdstream.cpp | |||
@@ -96,3 +96,7 @@ void Bu::StdStream::setBlocking( bool ) | |||
96 | { | 96 | { |
97 | } | 97 | } |
98 | 98 | ||
99 | void Bu::StdStream::setSize( long iSize ) | ||
100 | { | ||
101 | } | ||
102 | |||
diff --git a/src/stdstream.h b/src/stdstream.h index 144a24f..4efeece 100644 --- a/src/stdstream.h +++ b/src/stdstream.h | |||
@@ -40,6 +40,7 @@ namespace Bu | |||
40 | virtual bool isSeekable(); | 40 | virtual bool isSeekable(); |
41 | virtual bool isBlocking(); | 41 | virtual bool isBlocking(); |
42 | virtual void setBlocking( bool bBlocking=true ); | 42 | virtual void setBlocking( bool bBlocking=true ); |
43 | virtual void setSize( long iSize ); | ||
43 | }; | 44 | }; |
44 | } | 45 | } |
45 | 46 | ||
diff --git a/src/stream.h b/src/stream.h index bfe3ef9..0ea5560 100644 --- a/src/stream.h +++ b/src/stream.h | |||
@@ -152,6 +152,14 @@ namespace Bu | |||
152 | */ | 152 | */ |
153 | virtual void setBlocking( bool bBlocking=true ) = 0; | 153 | virtual void setBlocking( bool bBlocking=true ) = 0; |
154 | 154 | ||
155 | /** | ||
156 | * Set the size of the stream, this does not apply to many types of | ||
157 | * streams. For those that it does apply to, data will be added or | ||
158 | * removed from the end of the stream, but the content of the added | ||
159 | * data is undefined. | ||
160 | */ | ||
161 | virtual void setSize( long iSize ) = 0; | ||
162 | |||
155 | public: // Filters | 163 | public: // Filters |
156 | 164 | ||
157 | 165 | ||
diff --git a/src/unit/myriad.unit b/src/unit/myriad.unit index bc05bf7..cf861a3 100644 --- a/src/unit/myriad.unit +++ b/src/unit/myriad.unit | |||
@@ -76,7 +76,7 @@ suite Myriad | |||
76 | { | 76 | { |
77 | FString sFileName("myriad-XXXXXXX"); | 77 | FString sFileName("myriad-XXXXXXX"); |
78 | 78 | ||
79 | File::tempFile( sFileName ); | 79 | tempFile( sFileName ); |
80 | File fMyriad( sFileName, File::WriteNew|File::Read ); | 80 | File fMyriad( sFileName, File::WriteNew|File::Read ); |
81 | Myriad m( fMyriad ); | 81 | Myriad m( fMyriad ); |
82 | m.initialize( 64 ); | 82 | m.initialize( 64 ); |
diff --git a/src/unitsuite.cpp b/src/unitsuite.cpp index a66160e..51cca10 100644 --- a/src/unitsuite.cpp +++ b/src/unitsuite.cpp | |||
@@ -6,6 +6,9 @@ | |||
6 | */ | 6 | */ |
7 | 7 | ||
8 | #include "bu/unitsuite.h" | 8 | #include "bu/unitsuite.h" |
9 | #include "bu/file.h" | ||
10 | |||
11 | #include <unistd.h> | ||
9 | 12 | ||
10 | Bu::UnitSuite::UnitSuite() : | 13 | Bu::UnitSuite::UnitSuite() : |
11 | iOptions( 0 ) | 14 | iOptions( 0 ) |
@@ -102,9 +105,20 @@ int Bu::UnitSuite::run( int /*argc*/, char * /*argv */ [] ) | |||
102 | if( iUPass == 0 && iUFail == 0 ) | 105 | if( iUPass == 0 && iUFail == 0 ) |
103 | printf("\tNothing unexpected.\n\n"); | 106 | printf("\tNothing unexpected.\n\n"); |
104 | 107 | ||
108 | for( StrList::iterator i = lFileCleanup.begin(); i; i++ ) | ||
109 | { | ||
110 | unlink( (*i).getStr() ); | ||
111 | } | ||
112 | |||
105 | return 0; | 113 | return 0; |
106 | } | 114 | } |
107 | 115 | ||
116 | void Bu::UnitSuite::tempFile( Bu::FString &sFileName ) | ||
117 | { | ||
118 | Bu::File::tempFile( sFileName ); | ||
119 | lFileCleanup.append( sFileName ); | ||
120 | } | ||
121 | |||
108 | void Bu::UnitSuite::add( Test fTest, const Bu::FString &sName, Expect e ) | 122 | void Bu::UnitSuite::add( Test fTest, const Bu::FString &sName, Expect e ) |
109 | { | 123 | { |
110 | TestInfo ti; | 124 | TestInfo ti; |
diff --git a/src/unitsuite.h b/src/unitsuite.h index ad6bedb..7d026c2 100644 --- a/src/unitsuite.h +++ b/src/unitsuite.h | |||
@@ -61,6 +61,8 @@ namespace Bu | |||
61 | 61 | ||
62 | int run( int argc=0, char *argv[]=NULL ); | 62 | int run( int argc=0, char *argv[]=NULL ); |
63 | 63 | ||
64 | void tempFile( Bu::FString &sFileName ); | ||
65 | |||
64 | typedef void (UnitSuite::*Test)(); | 66 | typedef void (UnitSuite::*Test)(); |
65 | 67 | ||
66 | class Failed | 68 | class Failed |
@@ -105,6 +107,9 @@ namespace Bu | |||
105 | FString sSuiteName; | 107 | FString sSuiteName; |
106 | 108 | ||
107 | int iOptions; | 109 | int iOptions; |
110 | |||
111 | typedef Bu::List<Bu::FString> StrList; | ||
112 | StrList lFileCleanup; | ||
108 | }; | 113 | }; |
109 | } | 114 | } |
110 | 115 | ||