diff options
| author | Mike Buland <eichlan@xagasoft.com> | 2012-09-05 20:44:55 +0000 | 
|---|---|---|
| committer | Mike Buland <eichlan@xagasoft.com> | 2012-09-05 20:44:55 +0000 | 
| commit | e5f2e1ce7faeb8fb4609f7291e77d5b682685057 (patch) | |
| tree | c00b5d47966aef916f8a2f055aedadade5fa95d3 /src/stable | |
| parent | 69d1606ac97547896a0ede8dee5e59fc4a5de7c2 (diff) | |
| download | libbu++-e5f2e1ce7faeb8fb4609f7291e77d5b682685057.tar.gz libbu++-e5f2e1ce7faeb8fb4609f7291e77d5b682685057.tar.bz2 libbu++-e5f2e1ce7faeb8fb4609f7291e77d5b682685057.tar.xz libbu++-e5f2e1ce7faeb8fb4609f7291e77d5b682685057.zip | |
This'll make *everything* rebuild.  String formatters now support the end()
call, which will force substitution and return a string.  They now also support
ending actions, which let us do great stuff like printing stuff out after
formatting finished...and other stuff.
Diffstat (limited to 'src/stable')
| -rw-r--r-- | src/stable/sio.cpp | 38 | ||||
| -rw-r--r-- | src/stable/sio.h | 8 | ||||
| -rw-r--r-- | src/stable/string.cpp | 19 | ||||
| -rw-r--r-- | src/stable/string.h | 32 | 
4 files changed, 75 insertions, 22 deletions
| diff --git a/src/stable/sio.cpp b/src/stable/sio.cpp index 02ba631..e7f7565 100644 --- a/src/stable/sio.cpp +++ b/src/stable/sio.cpp | |||
| @@ -10,25 +10,45 @@ | |||
| 10 | Bu::StdStream Bu::sioRaw; | 10 | Bu::StdStream Bu::sioRaw; | 
| 11 | Bu::Formatter Bu::sio( Bu::sioRaw ); | 11 | Bu::Formatter Bu::sio( Bu::sioRaw ); | 
| 12 | 12 | ||
| 13 | Bu::size Bu::print( Bu::Stream &s, const Bu::String &str ) | 13 | class PrintEndAction : public Bu::String::FormatProxyEndAction | 
| 14 | { | 14 | { | 
| 15 | return s.write( str.getStr(), str.getSize() ); | 15 | public: | 
| 16 | PrintEndAction( Bu::Stream &s, bool bEndLn ) : | ||
| 17 | s( s ), | ||
| 18 | bEndLn( bEndLn ) | ||
| 19 | { | ||
| 20 | } | ||
| 21 | |||
| 22 | virtual void operator()( const Bu::String &sFinal ) | ||
| 23 | { | ||
| 24 | s.write( sFinal.getStr(), sFinal.getSize() ); | ||
| 25 | if( bEndLn ) | ||
| 26 | { | ||
| 27 | s.write("\n", 1); | ||
| 28 | s.flush(); | ||
| 29 | } | ||
| 30 | } | ||
| 31 | |||
| 32 | Bu::Stream &s; | ||
| 33 | bool bEndLn; | ||
| 34 | }; | ||
| 35 | |||
| 36 | Bu::String::FormatProxy Bu::print( Bu::Stream &s, const Bu::String &str ) | ||
| 37 | { | ||
| 38 | return str.format( new PrintEndAction( s, false ) ); | ||
| 16 | } | 39 | } | 
| 17 | 40 | ||
| 18 | Bu::size Bu::print( const Bu::String &str ) | 41 | Bu::String::FormatProxy Bu::print( const Bu::String &str ) | 
| 19 | { | 42 | { | 
| 20 | return print( sioRaw, str ); | 43 | return print( sioRaw, str ); | 
| 21 | } | 44 | } | 
| 22 | 45 | ||
| 23 | Bu::size Bu::println( Bu::Stream &s, const Bu::String &str ) | 46 | Bu::String::FormatProxy Bu::println( Bu::Stream &s, const Bu::String &str ) | 
| 24 | { | 47 | { | 
| 25 | Bu::size sRet = s.write( str.getStr(), str.getSize() ); | 48 | return str.format( new PrintEndAction( s, true ) ); | 
| 26 | sRet += s.write("\n", 1 ); | ||
| 27 | s.flush(); | ||
| 28 | return sRet; | ||
| 29 | } | 49 | } | 
| 30 | 50 | ||
| 31 | Bu::size Bu::println( const Bu::String &str ) | 51 | Bu::String::FormatProxy Bu::println( const Bu::String &str ) | 
| 32 | { | 52 | { | 
| 33 | return println( sioRaw, str ); | 53 | return println( sioRaw, str ); | 
| 34 | } | 54 | } | 
| diff --git a/src/stable/sio.h b/src/stable/sio.h index cc7b098..d9761b2 100644 --- a/src/stable/sio.h +++ b/src/stable/sio.h | |||
| @@ -16,11 +16,11 @@ namespace Bu | |||
| 16 | extern Bu::StdStream sioRaw; | 16 | extern Bu::StdStream sioRaw; | 
| 17 | extern Bu::Formatter sio; | 17 | extern Bu::Formatter sio; | 
| 18 | 18 | ||
| 19 | Bu::size print( Bu::Stream &s, const Bu::String &str ); | 19 | Bu::String::FormatProxy print( Bu::Stream &s, const Bu::String &str ); | 
| 20 | Bu::size print( const Bu::String &str ); | 20 | Bu::String::FormatProxy print( const Bu::String &str ); | 
| 21 | 21 | ||
| 22 | Bu::size println( Bu::Stream &s, const Bu::String &str ); | 22 | Bu::String::FormatProxy println( Bu::Stream &s, const Bu::String &str ); | 
| 23 | Bu::size println( const Bu::String &str ); | 23 | Bu::String::FormatProxy println( const Bu::String &str ); | 
| 24 | }; | 24 | }; | 
| 25 | 25 | ||
| 26 | #endif | 26 | #endif | 
| diff --git a/src/stable/string.cpp b/src/stable/string.cpp index 4cef6b1..d1f76aa 100644 --- a/src/stable/string.cpp +++ b/src/stable/string.cpp | |||
| @@ -1228,16 +1228,23 @@ bool Bu::String::isFlat() const | |||
| 1228 | // Sub-class Bu::String::FormatProxy | 1228 | // Sub-class Bu::String::FormatProxy | 
| 1229 | // | 1229 | // | 
| 1230 | 1230 | ||
| 1231 | Bu::String::FormatProxy::FormatProxy( const String &rFmt ) : | 1231 | Bu::String::FormatProxy::FormatProxy( const String &rFmt, | 
| 1232 | rFmt( rFmt ) | 1232 | String::FormatProxyEndAction *pAct ) : | 
| 1233 | rFmt( rFmt ), | ||
| 1234 | pAct( pAct ), | ||
| 1235 | bOpen( true ) | ||
| 1233 | { | 1236 | { | 
| 1234 | } | 1237 | } | 
| 1235 | 1238 | ||
| 1236 | Bu::String::FormatProxy::~FormatProxy() | 1239 | Bu::String::FormatProxy::~FormatProxy() | 
| 1237 | { | 1240 | { | 
| 1241 | if( pAct && bOpen ) | ||
| 1242 | end(); | ||
| 1243 | |||
| 1244 | delete pAct; | ||
| 1238 | } | 1245 | } | 
| 1239 | 1246 | ||
| 1240 | Bu::String::FormatProxy::operator Bu::String() const | 1247 | Bu::String Bu::String::FormatProxy::end() const | 
| 1241 | { | 1248 | { | 
| 1242 | int iCount = lArgs.getSize(); | 1249 | int iCount = lArgs.getSize(); | 
| 1243 | ArgList::const_iterator *aArg = | 1250 | ArgList::const_iterator *aArg = | 
| @@ -1287,8 +1294,12 @@ Bu::String::FormatProxy::operator Bu::String() const | |||
| 1287 | } | 1294 | } | 
| 1288 | s++; | 1295 | s++; | 
| 1289 | } | 1296 | } | 
| 1290 | 1297 | ||
| 1298 | bOpen = false; | ||
| 1291 | delete[] aArg; | 1299 | delete[] aArg; | 
| 1300 | |||
| 1301 | if( pAct ) | ||
| 1302 | (*pAct)( mbOut.getString() ); | ||
| 1292 | return mbOut.getString(); | 1303 | return mbOut.getString(); | 
| 1293 | } | 1304 | } | 
| 1294 | 1305 | ||
| diff --git a/src/stable/string.h b/src/stable/string.h index 82b903b..c92a704 100644 --- a/src/stable/string.h +++ b/src/stable/string.h | |||
| @@ -946,12 +946,21 @@ namespace Bu | |||
| 946 | void flatten() const; | 946 | void flatten() const; | 
| 947 | bool isFlat() const; | 947 | bool isFlat() const; | 
| 948 | 948 | ||
| 949 | public: | ||
| 950 | class FormatProxyEndAction | ||
| 951 | { | ||
| 952 | public: | ||
| 953 | virtual void operator()( const Bu::String &sFinal )=0; | ||
| 954 | }; | ||
| 955 | |||
| 949 | class FormatProxy | 956 | class FormatProxy | 
| 950 | { | 957 | { | 
| 958 | friend class Bu::String; | ||
| 959 | private: | ||
| 960 | FormatProxy( const String &rFmt, FormatProxyEndAction *pAct=NULL ); | ||
| 961 | |||
| 951 | public: | 962 | public: | 
| 952 | FormatProxy( const String &rFmt ); | ||
| 953 | virtual ~FormatProxy(); | 963 | virtual ~FormatProxy(); | 
| 954 | |||
| 955 | template<typename T> | 964 | template<typename T> | 
| 956 | FormatProxy &arg( const T &x ) | 965 | FormatProxy &arg( const T &x ) | 
| 957 | { | 966 | { | 
| @@ -968,7 +977,8 @@ namespace Bu | |||
| 968 | return *this; | 977 | return *this; | 
| 969 | } | 978 | } | 
| 970 | 979 | ||
| 971 | operator String() const; | 980 | String end() const; | 
| 981 | operator String() const { return end(); } | ||
| 972 | 982 | ||
| 973 | private: | 983 | private: | 
| 974 | const String &rFmt; | 984 | const String &rFmt; | 
| @@ -993,20 +1003,32 @@ namespace Bu | |||
| 993 | }; | 1003 | }; | 
| 994 | typedef Bu::List<Arg> ArgList; | 1004 | typedef Bu::List<Arg> ArgList; | 
| 995 | ArgList lArgs; | 1005 | ArgList lArgs; | 
| 1006 | FormatProxyEndAction *pAct; | ||
| 1007 | mutable bool bOpen; | ||
| 996 | }; | 1008 | }; | 
| 997 | 1009 | ||
| 998 | public: | 1010 | public: | 
| 999 | template<typename ArgType> | 1011 | template<typename ArgType> | 
| 1000 | FormatProxy arg( const ArgType &x ) | 1012 | FormatProxy arg( const ArgType &x ) const | 
| 1001 | { | 1013 | { | 
| 1002 | return FormatProxy( *this ).arg( x ); | 1014 | return FormatProxy( *this ).arg( x ); | 
| 1003 | } | 1015 | } | 
| 1004 | 1016 | ||
| 1005 | template<typename ArgType> | 1017 | template<typename ArgType> | 
| 1006 | FormatProxy arg( const ArgType &x, const Bu::Fmt &f ) | 1018 | FormatProxy arg( const ArgType &x, const Bu::Fmt &f ) const | 
| 1007 | { | 1019 | { | 
| 1008 | return FormatProxy( *this ).arg( x, f ); | 1020 | return FormatProxy( *this ).arg( x, f ); | 
| 1009 | } | 1021 | } | 
| 1022 | |||
| 1023 | FormatProxy format() const | ||
| 1024 | { | ||
| 1025 | return FormatProxy( *this ); | ||
| 1026 | } | ||
| 1027 | |||
| 1028 | FormatProxy format( FormatProxyEndAction *pEndAction ) const | ||
| 1029 | { | ||
| 1030 | return FormatProxy( *this, pEndAction ); | ||
| 1031 | } | ||
| 1010 | }; | 1032 | }; | 
| 1011 | 1033 | ||
| 1012 | template<class T> String operator+( const T *pLeft, const String &rRight ) | 1034 | template<class T> String operator+( const T *pLeft, const String &rRight ) | 
