diff options
| author | Alan Conway <aconway@apache.org> | 2008-03-11 22:13:10 +0000 |
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2008-03-11 22:13:10 +0000 |
| commit | eadb91781ab0d6e786500a3798f1bf2a83293a05 (patch) | |
| tree | e582626920f3583e27deda835a2e2389c9c5e8c7 /cpp/src/qpid/sys | |
| parent | 2250ec787ae5fb84fbebfee35bd9925ebd1dd679 (diff) | |
| download | qpid-python-eadb91781ab0d6e786500a3798f1bf2a83293a05.tar.gz | |
rubygen/0-10/specification.rb:
- Simplified enum mapping/encoding.
- struct encoding
- ostream << operators
src/qpid/Serializer.h
- free funciton serialization
- separate Encoder/Decoder for const correctness
- split() to allow separate encode/decode for complex cases.
src/qpid/amqp_0_10/Assembly.cpp, Assembly.h: AMQP 0-10 final Assembly
src/qpid/amqp_0_10/Codec.h
- Replaced enable_if with overloads, simpler & more flexible.
src/qpid/amqp_0_10/Frame.cpp, .h: AMQP 0-10 final frame.
src/qpid/amqp_0_10/Holder.h:
- provide const and non-const apply
src/qpid/amqp_0_10/Segment.cpp, .h: AMQP 0-10 final Segment.
src/qpid/amqp_0_10/apply.h
- ConstApplyFunctor for const apply.
src/qpid/amqp_0_10/built_in_types.h
- SerializableString encoding
src/qpid/amqp_0_10/complex_types.cpp, .h
- const application
- Action base class for command/control.
src/qpid/framing/AMQBody.h
- removed 0-10 final changes, moving integration point down the stack.
src/qpid/sys/Shlib.h
- removed unused and uncompilable (on some compilers) function.
src/qpid/sys/Time.h, .cpp
- ostream << for AbsTime and Duration.
src/tests/Assembly.cpp, Segment.cpp, apply.cpp, serialize.cpp: testing new code.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@636126 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/sys')
| -rw-r--r-- | cpp/src/qpid/sys/Shlib.h | 6 | ||||
| -rw-r--r-- | cpp/src/qpid/sys/Time.h | 4 | ||||
| -rw-r--r-- | cpp/src/qpid/sys/posix/Time.cpp | 28 |
3 files changed, 30 insertions, 8 deletions
diff --git a/cpp/src/qpid/sys/Shlib.h b/cpp/src/qpid/sys/Shlib.h index debf231125..e2752dc7d6 100644 --- a/cpp/src/qpid/sys/Shlib.h +++ b/cpp/src/qpid/sys/Shlib.h @@ -56,12 +56,6 @@ class Shlib { this->getSymbol(symbol))); } - /** Look up symbol in shared library. */ - template <class T*> - void* getSymbol(const std::string& symbol) { - return getSymbol<T>(symbol.c_str()); - } - private: void* handle; void load(const char* libname); diff --git a/cpp/src/qpid/sys/Time.h b/cpp/src/qpid/sys/Time.h index c87bd6f05b..860fc49097 100644 --- a/cpp/src/qpid/sys/Time.h +++ b/cpp/src/qpid/sys/Time.h @@ -24,6 +24,7 @@ #include <stdint.h> #include <limits> +#include <iosfwd> namespace qpid { namespace sys { @@ -54,6 +55,8 @@ class AbsTime { friend bool operator>(const AbsTime& a, const AbsTime& b); }; +std::ostream& operator << (std::ostream&, const AbsTime&); + class Duration { static int64_t max() { return std::numeric_limits<int64_t>::max(); } int64_t nanosecs; @@ -67,6 +70,7 @@ class Duration { inline operator int64_t() const; }; +std::ostream& operator << (std::ostream&, const Duration&); AbsTime::AbsTime(const AbsTime& t, const Duration& d) : time_ns(d == Duration::max() ? max() : t.time_ns+d.nanosecs) diff --git a/cpp/src/qpid/sys/posix/Time.cpp b/cpp/src/qpid/sys/posix/Time.cpp index ac63a3d038..b2b7a81130 100644 --- a/cpp/src/qpid/sys/posix/Time.cpp +++ b/cpp/src/qpid/sys/posix/Time.cpp @@ -22,7 +22,7 @@ #include "PrivatePosix.h" #include "qpid/sys/Time.h" - +#include <ostream> #include <time.h> #include <sys/time.h> @@ -40,7 +40,7 @@ AbsTime AbsTime::now() { struct timespec& toTimespec(struct timespec& ts, const Duration& t) { ts.tv_sec = t / TIME_SEC; ts.tv_nsec = t % TIME_SEC; - return ts; + return ts; } struct timeval& toTimeval(struct timeval& tv, const Duration& t) { @@ -53,5 +53,29 @@ Duration toTime(const struct timespec& ts) { return ts.tv_sec*TIME_SEC + ts.tv_nsec; } +std::ostream& operator<<(std::ostream& o, const Duration& d) { + return o << int64_t(d) << "ns"; +} + +std::ostream& operator<<(std::ostream& o, const AbsTime& t) { + static const char * month_abbrevs[] = { + "jan", "feb", "mar", "apr", "may", "jun", "jul", "aug", "sep", "oct", "nov", "dec" + }; + struct tm * timeinfo; + time_t rawtime(t.timeValue()/TIME_SEC); + timeinfo = localtime (&rawtime); + char time_string[100]; + sprintf ( time_string, + "%d-%s-%02d %02d:%02d:%02d", + 1900 + timeinfo->tm_year, + month_abbrevs[timeinfo->tm_mon], + timeinfo->tm_mday, + timeinfo->tm_hour, + timeinfo->tm_min, + timeinfo->tm_sec + ); + return o << time_string; +} + }} |
