Blame exrheader/main.cpp

Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
//
Packit 0d464f
// Copyright (c) 2012, Industrial Light & Magic, a division of Lucas
Packit 0d464f
// Digital Ltd. LLC
Packit 0d464f
// 
Packit 0d464f
// All rights reserved.
Packit 0d464f
// 
Packit 0d464f
// Redistribution and use in source and binary forms, with or without
Packit 0d464f
// modification, are permitted provided that the following conditions are
Packit 0d464f
// met:
Packit 0d464f
// *       Redistributions of source code must retain the above copyright
Packit 0d464f
// notice, this list of conditions and the following disclaimer.
Packit 0d464f
// *       Redistributions in binary form must reproduce the above
Packit 0d464f
// copyright notice, this list of conditions and the following disclaimer
Packit 0d464f
// in the documentation and/or other materials provided with the
Packit 0d464f
// distribution.
Packit 0d464f
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 0d464f
// its contributors may be used to endorse or promote products derived
Packit 0d464f
// from this software without specific prior written permission. 
Packit 0d464f
// 
Packit 0d464f
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 0d464f
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 0d464f
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 0d464f
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 0d464f
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 0d464f
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 0d464f
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 0d464f
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 0d464f
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 0d464f
//
Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
Packit 0d464f
Packit 0d464f
//-----------------------------------------------------------------------------
Packit 0d464f
//
Packit 0d464f
//	Utility program to print an image file's header
Packit 0d464f
//
Packit 0d464f
//-----------------------------------------------------------------------------
Packit 0d464f
Packit 0d464f
#include "ImfNamespace.h"
Packit 0d464f
#include <ImfMultiPartInputFile.h>
Packit 0d464f
#include <ImfBoxAttribute.h>
Packit 0d464f
#include <ImfChannelListAttribute.h>
Packit 0d464f
#include <ImfChromaticitiesAttribute.h>
Packit 0d464f
#include <ImfCompressionAttribute.h>
Packit 0d464f
#include <ImfDoubleAttribute.h>
Packit 0d464f
#include <ImfEnvmapAttribute.h>
Packit 0d464f
#include <ImfFloatAttribute.h>
Packit 0d464f
#include <ImfIntAttribute.h>
Packit 0d464f
#include <ImfKeyCodeAttribute.h>
Packit 0d464f
#include <ImfLineOrderAttribute.h>
Packit 0d464f
#include <ImfMatrixAttribute.h>
Packit 0d464f
#include <ImfPreviewImageAttribute.h>
Packit 0d464f
#include <ImfRationalAttribute.h>
Packit 0d464f
#include <ImfStringAttribute.h>
Packit 0d464f
#include <ImfStringVectorAttribute.h>
Packit 0d464f
#include <ImfTileDescriptionAttribute.h>
Packit 0d464f
#include <ImfTimeCodeAttribute.h>
Packit 0d464f
#include <ImfVecAttribute.h>
Packit 0d464f
#include <ImfVersion.h>
Packit 0d464f
#include <ImfHeader.h>
Packit 0d464f
Packit 0d464f
#include <iostream>
Packit 0d464f
#include <iomanip>
Packit 0d464f
Packit 0d464f
Packit 0d464f
using namespace OPENEXR_IMF_NAMESPACE;
Packit 0d464f
using namespace std;
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printCompression (Compression c)
Packit 0d464f
{
Packit 0d464f
    switch (c)
Packit 0d464f
    {
Packit 0d464f
        case NO_COMPRESSION:
Packit 0d464f
            cout << "none";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case RLE_COMPRESSION:
Packit 0d464f
            cout << "run-length encoding";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case ZIPS_COMPRESSION:
Packit 0d464f
            cout << "zip, individual scanlines";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case ZIP_COMPRESSION:
Packit 0d464f
            cout << "zip, multi-scanline blocks";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case PIZ_COMPRESSION:
Packit 0d464f
            cout << "piz";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case PXR24_COMPRESSION:
Packit 0d464f
            cout << "pxr24";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case B44_COMPRESSION:
Packit 0d464f
            cout << "b44";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case B44A_COMPRESSION:
Packit 0d464f
            cout << "b44a";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case DWAA_COMPRESSION:
Packit 0d464f
            cout << "dwa, small scanline blocks";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case DWAB_COMPRESSION:
Packit 0d464f
            cout << "dwa, medium scanline blocks";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << int (c);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printLineOrder (LineOrder lo)
Packit 0d464f
{
Packit 0d464f
    switch (lo)
Packit 0d464f
    {
Packit 0d464f
        case INCREASING_Y:
Packit 0d464f
            cout << "increasing y";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case DECREASING_Y:
Packit 0d464f
            cout << "decreasing y";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case RANDOM_Y:
Packit 0d464f
            cout << "random y";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << int (lo);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printPixelType (PixelType pt)
Packit 0d464f
{
Packit 0d464f
    switch (pt)
Packit 0d464f
    {
Packit 0d464f
        case UINT:
Packit 0d464f
            cout << "32-bit unsigned integer";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case HALF:
Packit 0d464f
            cout << "16-bit floating-point";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case FLOAT:
Packit 0d464f
            cout << "32-bit floating-point";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << "type " << int (pt);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printLevelMode (LevelMode lm)
Packit 0d464f
{
Packit 0d464f
    switch (lm)
Packit 0d464f
    {
Packit 0d464f
        case ONE_LEVEL:
Packit 0d464f
            cout << "single level";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case MIPMAP_LEVELS:
Packit 0d464f
            cout << "mip-map";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case RIPMAP_LEVELS:
Packit 0d464f
            cout << "rip-map";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << "level mode " << int (lm);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printLevelRoundingMode (LevelRoundingMode lm)
Packit 0d464f
{
Packit 0d464f
    switch (lm)
Packit 0d464f
    {
Packit 0d464f
        case ROUND_DOWN:
Packit 0d464f
            cout << "down";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case ROUND_UP:
Packit 0d464f
            cout << "up";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << "mode " << int (lm);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printTimeCode (TimeCode tc)
Packit 0d464f
{
Packit 0d464f
    cout << "    "
Packit 0d464f
    "time " <<
Packit 0d464f
    setfill ('0') <<
Packit 0d464f
#ifndef HAVE_COMPLETE_IOMANIP
Packit 0d464f
    setw (2) << tc.hours() << ":" <<
Packit 0d464f
    setw (2) << tc.minutes() << ":" <<
Packit 0d464f
    setw (2) << tc.seconds() << ":" <<
Packit 0d464f
    setw (2) << tc.frame() << "\n" <<
Packit 0d464f
#else
Packit 0d464f
    setw (2) << right << tc.hours() << ":" <<
Packit 0d464f
    setw (2) << right << tc.minutes() << ":" <<
Packit 0d464f
    setw (2) << right << tc.seconds() << ":" <<
Packit 0d464f
    setw (2) << right << tc.frame() << "\n" <<
Packit 0d464f
#endif
Packit 0d464f
    setfill (' ') <<
Packit 0d464f
    "    "
Packit 0d464f
    "drop frame " << tc.dropFrame() << ", "
Packit 0d464f
    "color frame " << tc.colorFrame() << ", "
Packit 0d464f
    "field/phase " << tc.fieldPhase() << "\n"
Packit 0d464f
    "    "
Packit 0d464f
    "bgf0 " << tc.bgf0() << ", "
Packit 0d464f
    "bgf1 " << tc.bgf1() << ", "
Packit 0d464f
    "bgf2 " << tc.bgf2() << "\n"
Packit 0d464f
    "    "
Packit 0d464f
    "user data 0x" << hex << tc.userData() << dec;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printEnvmap (Envmap e)
Packit 0d464f
{
Packit 0d464f
    switch (e)
Packit 0d464f
    {
Packit 0d464f
        case ENVMAP_LATLONG:
Packit 0d464f
            cout << "latitude-longitude map";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        case ENVMAP_CUBE:
Packit 0d464f
            cout << "cube-face map";
Packit 0d464f
            break;
Packit 0d464f
Packit 0d464f
        default:
Packit 0d464f
            cout << "map type " << int (e);
Packit 0d464f
            break;
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printChannelList (const ChannelList &cl)
Packit 0d464f
{
Packit 0d464f
    for (ChannelList::ConstIterator i = cl.begin(); i != cl.end(); ++i)
Packit 0d464f
    {
Packit 0d464f
        cout << "\n    " << i.name() << ", ";
Packit 0d464f
Packit 0d464f
        printPixelType (i.channel().type);
Packit 0d464f
Packit 0d464f
        cout << ", sampling " <<
Packit 0d464f
        i.channel().xSampling << " " <<
Packit 0d464f
        i.channel().ySampling;
Packit 0d464f
Packit 0d464f
        if (i.channel().pLinear)
Packit 0d464f
            cout << ", plinear";
Packit 0d464f
    }
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
printInfo (const char fileName[])
Packit 0d464f
{
Packit 0d464f
    MultiPartInputFile in (fileName);
Packit 0d464f
    int parts = in.parts();
Packit 0d464f
Packit 0d464f
    //
Packit 0d464f
    // Check to see if any parts are incomplete
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    bool fileComplete = true;
Packit 0d464f
Packit 0d464f
    for (int i = 0; i < parts && fileComplete; ++i)
Packit 0d464f
        if (!in.partComplete (i))
Packit 0d464f
            fileComplete = false;
Packit 0d464f
Packit 0d464f
    //
Packit 0d464f
    // Print file name and file format version
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    cout << "\nfile " << fileName <<
Packit 0d464f
            (fileComplete? "": " (incomplete)") <<
Packit 0d464f
            ":\n\n";
Packit 0d464f
Packit 0d464f
    cout << "file format version: " <<
Packit 0d464f
            getVersion (in.version()) << ", "
Packit 0d464f
            "flags 0x" <<
Packit 0d464f
            setbase (16) << getFlags (in.version()) << setbase (10) << "\n";
Packit 0d464f
Packit 0d464f
    //
Packit 0d464f
    // Print the header of every part in the file
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    for (int p = 0; p < parts ; ++p)
Packit 0d464f
    {
Packit 0d464f
        const Header & h = in.header (p);
Packit 0d464f
Packit 0d464f
        if (parts != 1)
Packit 0d464f
        {
Packit 0d464f
            cout  << "\n\n part " << p <<
Packit 0d464f
            (in.partComplete (p)? "": " (incomplete)") <<
Packit 0d464f
            ":\n";
Packit 0d464f
Packit 0d464f
        }
Packit 0d464f
	 
Packit 0d464f
        for (Header::ConstIterator i = h.begin(); i != h.end(); ++i)
Packit 0d464f
        {
Packit 0d464f
            const Attribute *a = &i.attribute();
Packit 0d464f
            cout << i.name() << " (type " << a->typeName() << ")";
Packit 0d464f
Packit 0d464f
            if (const Box2iAttribute *ta =
Packit 0d464f
                            dynamic_cast <const Box2iAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value().min << " - " << ta->value().max;
Packit 0d464f
            }
Packit 0d464f
Packit 0d464f
            else if (const Box2fAttribute *ta =
Packit 0d464f
                            dynamic_cast <const Box2fAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value().min << " - " << ta->value().max;
Packit 0d464f
            }
Packit 0d464f
            else if (const ChannelListAttribute *ta =
Packit 0d464f
                            dynamic_cast <const ChannelListAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":";
Packit 0d464f
                printChannelList (ta->value());
Packit 0d464f
            }
Packit 0d464f
            else if (const ChromaticitiesAttribute *ta =
Packit 0d464f
                            dynamic_cast <const ChromaticitiesAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n"
Packit 0d464f
                "    red   " << ta->value().red << "\n"
Packit 0d464f
                "    green " << ta->value().green << "\n"
Packit 0d464f
                "    blue  " << ta->value().blue << "\n"
Packit 0d464f
                "    white " << ta->value().white;
Packit 0d464f
            }
Packit 0d464f
            else if (const CompressionAttribute *ta =
Packit 0d464f
                            dynamic_cast <const CompressionAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": ";
Packit 0d464f
                printCompression (ta->value());
Packit 0d464f
            }
Packit 0d464f
            else if (const DoubleAttribute *ta =
Packit 0d464f
                            dynamic_cast <const DoubleAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const EnvmapAttribute *ta =
Packit 0d464f
                            dynamic_cast <const EnvmapAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": ";
Packit 0d464f
                printEnvmap (ta->value());
Packit 0d464f
            }
Packit 0d464f
            else if (const FloatAttribute *ta =
Packit 0d464f
                            dynamic_cast <const FloatAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const IntAttribute *ta =
Packit 0d464f
                            dynamic_cast <const IntAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const KeyCodeAttribute *ta =
Packit 0d464f
                            dynamic_cast <const KeyCodeAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n"
Packit 0d464f
                "    film manufacturer code " <<
Packit 0d464f
                ta->value().filmMfcCode() << "\n"
Packit 0d464f
                "    film type code " <<
Packit 0d464f
                ta->value().filmType() << "\n"
Packit 0d464f
                "    prefix " <<
Packit 0d464f
                ta->value().prefix() << "\n"
Packit 0d464f
                "    count " <<
Packit 0d464f
                ta->value().count() << "\n"
Packit 0d464f
                "    perf offset " <<
Packit 0d464f
                ta->value().perfOffset() << "\n"
Packit 0d464f
                "    perfs per frame " <<
Packit 0d464f
                ta->value().perfsPerFrame() << "\n"
Packit 0d464f
                "    perfs per count " <<
Packit 0d464f
                ta->value().perfsPerCount();
Packit 0d464f
            }
Packit 0d464f
            else if (const LineOrderAttribute *ta =
Packit 0d464f
                            dynamic_cast <const LineOrderAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": ";
Packit 0d464f
                printLineOrder (ta->value());
Packit 0d464f
            }
Packit 0d464f
            else if (const M33fAttribute *ta =
Packit 0d464f
                            dynamic_cast <const M33fAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n"
Packit 0d464f
                "   (" <<
Packit 0d464f
                ta->value()[0][0] << " " <<
Packit 0d464f
                ta->value()[0][1] << " " <<
Packit 0d464f
                ta->value()[0][2] << "\n    " <<
Packit 0d464f
                ta->value()[1][0] << " " <<
Packit 0d464f
                ta->value()[1][1] << " " <<
Packit 0d464f
                ta->value()[1][2] << "\n    " <<
Packit 0d464f
                ta->value()[2][0] << " " <<
Packit 0d464f
                ta->value()[2][1] << " " <<
Packit 0d464f
                ta->value()[2][2] << ")";
Packit 0d464f
            }
Packit 0d464f
            else if (const M44fAttribute *ta =
Packit 0d464f
                            dynamic_cast <const M44fAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n"
Packit 0d464f
                "   (" <<
Packit 0d464f
                ta->value()[0][0] << " " <<
Packit 0d464f
                ta->value()[0][1] << " " <<
Packit 0d464f
                ta->value()[0][2] << " " <<
Packit 0d464f
                ta->value()[0][3] << "\n    " <<
Packit 0d464f
                ta->value()[1][0] << " " <<
Packit 0d464f
                ta->value()[1][1] << " " <<
Packit 0d464f
                ta->value()[1][2] << " " <<
Packit 0d464f
                ta->value()[1][3] << "\n    " <<
Packit 0d464f
                ta->value()[2][0] << " " <<
Packit 0d464f
                ta->value()[2][1] << " " <<
Packit 0d464f
                ta->value()[2][2] << " " <<
Packit 0d464f
                ta->value()[2][3] << "\n    " <<
Packit 0d464f
                ta->value()[3][0] << " " <<
Packit 0d464f
                ta->value()[3][1] << " " <<
Packit 0d464f
                ta->value()[3][2] << " " <<
Packit 0d464f
                ta->value()[3][3] << ")";
Packit 0d464f
            }
Packit 0d464f
            else if (const PreviewImageAttribute *ta =
Packit 0d464f
                            dynamic_cast <const PreviewImageAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " <<
Packit 0d464f
                ta->value().width()  << " by " <<
Packit 0d464f
                ta->value().height() << " pixels";
Packit 0d464f
            }
Packit 0d464f
            else if (const StringAttribute *ta =
Packit 0d464f
                            dynamic_cast <const StringAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": \"" << ta->value() << "\"";
Packit 0d464f
            }
Packit 0d464f
            else if (const StringVectorAttribute * ta =
Packit 0d464f
                            dynamic_cast<const StringVectorAttribute *>(a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":";
Packit 0d464f
Packit 0d464f
                for (StringVector::const_iterator i = ta->value().begin();
Packit 0d464f
                                i != ta->value().end();
Packit 0d464f
                                ++i)
Packit 0d464f
                {
Packit 0d464f
                    cout << "\n    \"" << *i << "\"";
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            else if (const RationalAttribute *ta =
Packit 0d464f
                            dynamic_cast <const RationalAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value().n << "/" << ta->value().d <<
Packit 0d464f
                " (" << double (ta->value()) << ")";
Packit 0d464f
            }
Packit 0d464f
            else if (const TileDescriptionAttribute *ta =
Packit 0d464f
                            dynamic_cast <const TileDescriptionAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n    ";
Packit 0d464f
Packit 0d464f
                printLevelMode (ta->value().mode);
Packit 0d464f
Packit 0d464f
                cout << "\n    tile size " <<
Packit 0d464f
                ta->value().xSize << " by " <<
Packit 0d464f
                ta->value().ySize << " pixels";
Packit 0d464f
Packit 0d464f
                if (ta->value().mode != ONE_LEVEL)
Packit 0d464f
                {
Packit 0d464f
                    cout << "\n    level sizes rounded ";
Packit 0d464f
                    printLevelRoundingMode (ta->value().roundingMode);
Packit 0d464f
                }
Packit 0d464f
            }
Packit 0d464f
            else if (const TimeCodeAttribute *ta =
Packit 0d464f
                            dynamic_cast <const TimeCodeAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ":\n";
Packit 0d464f
                printTimeCode (ta->value());
Packit 0d464f
            }
Packit 0d464f
            else if (const V2iAttribute *ta =
Packit 0d464f
                            dynamic_cast <const V2iAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const V2fAttribute *ta =
Packit 0d464f
                            dynamic_cast <const V2fAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const V3iAttribute *ta =
Packit 0d464f
                            dynamic_cast <const V3iAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
            else if (const V3fAttribute *ta =
Packit 0d464f
                            dynamic_cast <const V3fAttribute *> (a))
Packit 0d464f
            {
Packit 0d464f
                cout << ": " << ta->value();
Packit 0d464f
            }
Packit 0d464f
Packit 0d464f
            cout << '\n';
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    cout << endl;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
usageMessage (const char argv0[])
Packit 0d464f
{
Packit 0d464f
    std::cerr << "usage: " << argv0 << " imagefile [imagefile ...]\n";
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
int
Packit 0d464f
main(int argc, char **argv)
Packit 0d464f
{
Packit 0d464f
    if (argc < 2)
Packit 0d464f
    {
Packit 0d464f
        usageMessage (argv[0]);
Packit 0d464f
        return 1;
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    for (int i = 1; i < argc; ++i)
Packit 0d464f
    {
Packit 0d464f
        if (!strcmp (argv[i], "-h"))
Packit 0d464f
        {
Packit 0d464f
            usageMessage (argv[0]);
Packit 0d464f
            return 1;
Packit 0d464f
        }
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    try
Packit 0d464f
    {
Packit 0d464f
        for (int i = 1; i < argc; ++i)
Packit 0d464f
            printInfo (argv[i]);
Packit 0d464f
Packit 0d464f
        return 0;
Packit 0d464f
    }
Packit 0d464f
    catch (const std::exception &e)
Packit 0d464f
    {
Packit 0d464f
        std::cerr << e.what() << std::endl;
Packit 0d464f
        return 1;
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
}