tomwalters@570: /* tomwalters@570: oscpack -- Open Sound Control packet manipulation library tomwalters@570: http://www.audiomulch.com/~rossb/oscpack tomwalters@570: tomwalters@570: Copyright (c) 2004-2005 Ross Bencina tomwalters@570: tomwalters@570: Permission is hereby granted, free of charge, to any person obtaining tomwalters@570: a copy of this software and associated documentation files tomwalters@570: (the "Software"), to deal in the Software without restriction, tomwalters@570: including without limitation the rights to use, copy, modify, merge, tomwalters@570: publish, distribute, sublicense, and/or sell copies of the Software, tomwalters@570: and to permit persons to whom the Software is furnished to do so, tomwalters@570: subject to the following conditions: tomwalters@570: tomwalters@570: The above copyright notice and this permission notice shall be tomwalters@570: included in all copies or substantial portions of the Software. tomwalters@570: tomwalters@570: Any person wishing to distribute modifications to the Software is tomwalters@570: requested to send the modifications to the original developer so that tomwalters@570: they can be incorporated into the canonical version. tomwalters@570: tomwalters@570: THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, tomwalters@570: EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF tomwalters@570: MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. tomwalters@570: IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR tomwalters@570: ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF tomwalters@570: CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION tomwalters@570: WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. tomwalters@570: */ tomwalters@570: #include "OscPrintReceivedElements.h" tomwalters@570: tomwalters@570: #include tomwalters@570: #include tomwalters@570: #include tomwalters@570: tomwalters@570: tomwalters@570: namespace osc{ tomwalters@570: tomwalters@570: tomwalters@570: std::ostream& operator<<( std::ostream & os, tomwalters@570: const ReceivedMessageArgument& arg ) tomwalters@570: { tomwalters@570: switch( arg.TypeTag() ){ tomwalters@570: case TRUE_TYPE_TAG: tomwalters@570: os << "bool:true"; tomwalters@570: break; tomwalters@570: tomwalters@570: case FALSE_TYPE_TAG: tomwalters@570: os << "bool:false"; tomwalters@570: break; tomwalters@570: tomwalters@570: case NIL_TYPE_TAG: tomwalters@570: os << "(Nil)"; tomwalters@570: break; tomwalters@570: tomwalters@570: case INFINITUM_TYPE_TAG: tomwalters@570: os << "(Infinitum)"; tomwalters@570: break; tomwalters@570: tomwalters@570: case INT32_TYPE_TAG: tomwalters@570: os << "int32:" << arg.AsInt32Unchecked(); tomwalters@570: break; tomwalters@570: tomwalters@570: case FLOAT_TYPE_TAG: tomwalters@570: os << "float32:" << arg.AsFloatUnchecked(); tomwalters@570: break; tomwalters@570: tomwalters@570: case CHAR_TYPE_TAG: tomwalters@570: { tomwalters@570: char s[2] = {0}; tomwalters@570: s[0] = arg.AsCharUnchecked(); tomwalters@570: os << "char:'" << s << "'"; tomwalters@570: } tomwalters@570: break; tomwalters@570: tomwalters@570: case RGBA_COLOR_TYPE_TAG: tomwalters@570: { tomwalters@570: uint32 color = arg.AsRgbaColorUnchecked(); tomwalters@570: tomwalters@570: os << "RGBA:0x" tomwalters@570: << std::hex << std::setfill('0') tomwalters@570: << std::setw(2) << (int)((color>>24) & 0xFF) tomwalters@570: << std::setw(2) << (int)((color>>16) & 0xFF) tomwalters@570: << std::setw(2) << (int)((color>>8) & 0xFF) tomwalters@570: << std::setw(2) << (int)(color & 0xFF) tomwalters@570: << std::setfill(' '); tomwalters@570: os.unsetf(std::ios::basefield); tomwalters@570: } tomwalters@570: break; tomwalters@570: tomwalters@570: case MIDI_MESSAGE_TYPE_TAG: tomwalters@570: { tomwalters@570: uint32 m = arg.AsMidiMessageUnchecked(); tomwalters@570: os << "midi (port, status, data1, data2):<<" tomwalters@570: << std::hex << std::setfill('0') tomwalters@570: << "0x" << std::setw(2) << (int)((m>>24) & 0xFF) tomwalters@570: << " 0x" << std::setw(2) << (int)((m>>16) & 0xFF) tomwalters@570: << " 0x" << std::setw(2) << (int)((m>>8) & 0xFF) tomwalters@570: << " 0x" << std::setw(2) << (int)(m & 0xFF) tomwalters@570: << std::setfill(' ') << ">>"; tomwalters@570: os.unsetf(std::ios::basefield); tomwalters@570: } tomwalters@570: break; tomwalters@570: tomwalters@570: case INT64_TYPE_TAG: tomwalters@570: os << "int64:" << arg.AsInt64Unchecked(); tomwalters@570: break; tomwalters@570: tomwalters@570: case TIME_TAG_TYPE_TAG: tomwalters@570: { tomwalters@570: os << "OSC-timetag:" << arg.AsTimeTagUnchecked(); tomwalters@570: tomwalters@570: std::time_t t = tomwalters@570: (unsigned long)( arg.AsTimeTagUnchecked() >> 32 ); tomwalters@570: tomwalters@570: // strip trailing newline from string returned by ctime tomwalters@570: const char *timeString = std::ctime( &t ); tomwalters@570: size_t len = strlen( timeString ); tomwalters@570: char *s = new char[ len + 1 ]; tomwalters@570: strcpy( s, timeString ); tomwalters@570: if( len ) tomwalters@570: s[ len - 1 ] = '\0'; tomwalters@570: tomwalters@570: os << " " << s; tomwalters@570: } tomwalters@570: break; tomwalters@570: tomwalters@570: case DOUBLE_TYPE_TAG: tomwalters@570: os << "double:" << arg.AsDoubleUnchecked(); tomwalters@570: break; tomwalters@570: tomwalters@570: case STRING_TYPE_TAG: tomwalters@570: os << "OSC-string:`" << arg.AsStringUnchecked() << "'"; tomwalters@570: break; tomwalters@570: tomwalters@570: case SYMBOL_TYPE_TAG: tomwalters@570: os << "OSC-string (symbol):`" << arg.AsSymbolUnchecked() << "'"; tomwalters@570: break; tomwalters@570: tomwalters@570: case BLOB_TYPE_TAG: tomwalters@570: { tomwalters@570: unsigned long size; tomwalters@570: const void *data; tomwalters@570: arg.AsBlobUnchecked( data, size ); tomwalters@570: os << "OSC-blob:<<" << std::hex << std::setfill('0'); tomwalters@570: unsigned char *p = (unsigned char*)data; tomwalters@570: for( unsigned long i = 0; i < size; ++i ){ tomwalters@570: os << "0x" << std::setw(2) << int(p[i]); tomwalters@570: if( i != size-1 ) tomwalters@570: os << ' '; tomwalters@570: } tomwalters@570: os.unsetf(std::ios::basefield); tomwalters@570: os << ">>" << std::setfill(' '); tomwalters@570: } tomwalters@570: break; tomwalters@570: tomwalters@570: default: tomwalters@570: os << "unknown"; tomwalters@570: } tomwalters@570: tomwalters@570: return os; tomwalters@570: } tomwalters@570: tomwalters@570: tomwalters@570: std::ostream& operator<<( std::ostream & os, const ReceivedMessage& m ) tomwalters@570: { tomwalters@570: tomwalters@570: os << "[" << m.AddressPattern(); tomwalters@570: bool first = true; tomwalters@570: tomwalters@570: for( ReceivedMessage::const_iterator i = m.ArgumentsBegin(); tomwalters@570: i != m.ArgumentsEnd(); ++i ){ tomwalters@570: if( first ){ tomwalters@570: os << " "; tomwalters@570: first = false; tomwalters@570: }else{ tomwalters@570: os << ", "; tomwalters@570: } tomwalters@570: tomwalters@570: os << *i; tomwalters@570: } tomwalters@570: tomwalters@570: os << "]"; tomwalters@570: tomwalters@570: return os; tomwalters@570: } tomwalters@570: tomwalters@570: tomwalters@570: std::ostream& operator<<( std::ostream & os, const ReceivedBundle& b ) tomwalters@570: { tomwalters@570: static int indent = 0; tomwalters@570: tomwalters@570: for( int j=0; j < indent; ++j ) tomwalters@570: os << " "; tomwalters@570: os << "{ ( "; tomwalters@570: if( b.TimeTag() == 1 ) tomwalters@570: os << "immediate"; tomwalters@570: else tomwalters@570: os << b.TimeTag(); tomwalters@570: os << " )\n"; tomwalters@570: tomwalters@570: ++indent; tomwalters@570: tomwalters@570: for( ReceivedBundle::const_iterator i = b.ElementsBegin(); tomwalters@570: i != b.ElementsEnd(); ++i ){ tomwalters@570: if( i->IsBundle() ){ tomwalters@570: ReceivedBundle b(*i); tomwalters@570: os << b << "\n"; tomwalters@570: }else{ tomwalters@570: ReceivedMessage m(*i); tomwalters@570: for( int j=0; j < indent; ++j ) tomwalters@570: os << " "; tomwalters@570: os << m << "\n"; tomwalters@570: } tomwalters@570: } tomwalters@570: tomwalters@570: --indent; tomwalters@570: tomwalters@570: for( int j=0; j < indent; ++j ) tomwalters@570: os << " "; tomwalters@570: os << "}"; tomwalters@570: tomwalters@570: return os; tomwalters@570: } tomwalters@570: tomwalters@570: tomwalters@570: std::ostream& operator<<( std::ostream & os, const ReceivedPacket& p ) tomwalters@570: { tomwalters@570: if( p.IsBundle() ){ tomwalters@570: ReceivedBundle b(p); tomwalters@570: os << b << "\n"; tomwalters@570: }else{ tomwalters@570: ReceivedMessage m(p); tomwalters@570: os << m << "\n"; tomwalters@570: } tomwalters@570: tomwalters@570: return os; tomwalters@570: } tomwalters@570: tomwalters@570: } // namespace osc