Equalizer  1.4.1
eqPixelBench/configEvent.cpp
00001 
00002 /* Copyright (c) 2007-2012, 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         case ConfigEvent::ASSEMBLE:
00041             os << "assemble";
00042             break;
00043         case ConfigEvent::START_LATENCY:
00044             os << "        ";
00045             break;
00046         default:
00047             os << static_cast< const eq::ConfigEvent* >( event );
00048             return os;
00049     }
00050 
00051     os << " \"" << event->data.user.data << "\" " << event->formatType
00052        << std::string( 32-strlen( event->formatType ), ' ' );
00053 
00054     if( event->msec < 0.0f )
00055         return os << "Got " << eq::glError( uint32_t( -event->msec ))
00056                   << std::dec;
00057 
00058     return os << event->area.x() << "x" << event->area.y() << ": "
00059               << static_cast< uint32_t >( event->area.x() * event->area.y() /
00060                                           event->msec  / 1048.576f )
00061               << "MPix/sec (" << event->msec << "ms, "
00062               << unsigned(1000.0f / event->msec) << "FPS)";
00063 }
00064 }
Generated on Mon Nov 26 2012 14:41:48 for Equalizer 1.4.1 by  doxygen 1.7.6.1