Equalizer  1.2.1
eqPixelBench/configEvent.cpp
00001 
00002 /* Copyright (c) 2007-2010, Stefan Eilemann <eile@equalizergraphics.com> 
00003  *
00004  * Redistribution and use in source and binary forms, with or without
00005  * modification, are permitted provided that the following conditions are met:
00006  *
00007  * - Redistributions of source code must retain the above copyright notice, this
00008  *   list of conditions and the following disclaimer.
00009  * - Redistributions in binary form must reproduce the above copyright notice,
00010  *   this list of conditions and the following disclaimer in the documentation
00011  *   and/or other materials provided with the distribution.
00012  * - Neither the name of Eyescale Software GmbH nor the names of its
00013  *   contributors may be used to endorse or promote products derived from this
00014  *   software without specific prior written permission.
00015  *
00016  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00017  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00018  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00019  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
00020  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00021  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00022  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00023  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00024  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00025  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00026  * POSSIBILITY OF SUCH DAMAGE.
00027  */
00028 
00029 #include "configEvent.h"
00030 
00031 namespace eqPixelBench
00032 {
00033 std::ostream& operator << ( std::ostream& os, const ConfigEvent* event )
00034 {
00035     switch( event->data.type )
00036     {
00037         case ConfigEvent::READBACK:
00038             os  << "readback";
00039             break;
00040 
00041         case ConfigEvent::ASSEMBLE:
00042             os  << "assemble";
00043             break;
00044         case ConfigEvent::START_LATENCY:
00045             os  << "        ";
00046             break;
00047         default:
00048             os << static_cast< const eq::ConfigEvent* >( event );
00049             return os;
00050     }
00051     
00052 
00053     os << " \"" << event->data.user.data << "\" " << event->formatType
00054        << std::string( 32-strlen( event->formatType ), ' ' ) << event->area.x()
00055        << "x" << event->area.y() << ": ";
00056 
00057     if( event->msec < 0.0f )
00058         os << "error 0x" << std::hex << static_cast< int >( -event->msec )
00059            << std::dec;
00060     else
00061         os << static_cast< uint32_t >( event->area.x() * event->area.y() / 
00062                                        event->msec  / 1048.576f )
00063            << "MPix/sec (" << event->msec << "ms, " << 
00064             unsigned(1000.0f / event->msec) << "FPS)";
00065 
00066 #if 0
00067     if ( event->data.type == ConfigEvent::READBACK )
00068     {
00069         os << event->area << "( size GPU : " << event->dataSizeGPU << " bytes ";
00070         os << "/ size CPU : " << event->dataSizeCPU << " bytes ";
00071         os << "/ time : " <<  event->msec << "ms )";
00072     }
00073     else if ( event->data.type == ConfigEvent::ASSEMBLE )
00074     {
00075         os << event->area << "( size CPU : " << event->dataSizeCPU << " bytes ";
00076         os << "/ time : " <<  event->msec << "ms )";
00077     }
00078 #endif
00079     return os;
00080 }
00081 }
Generated on Fri Jun 8 2012 15:44:29 for Equalizer 1.2.1 by  doxygen 1.8.0