Files
UnrealEngine/Engine/Source/ThirdParty/Alembic/alembic-1.8.7/bin/AbcEcho/AbcEcho.cpp
2025-05-18 13:04:45 +08:00

268 lines
9.0 KiB
C++

//-*****************************************************************************
//
// Copyright (c) 2009-2013,
// Sony Pictures Imageworks, Inc. and
// Industrial Light & Magic, a division of Lucasfilm Entertainment Company Ltd.
//
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Sony Pictures Imageworks, nor
// Industrial Light & Magic nor the names of their contributors may be used
// to endorse or promote products derived from this software without specific
// prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
//-*****************************************************************************
#include <Alembic/AbcGeom/All.h>
#include <Alembic/AbcCoreAbstract/All.h>
#include <Alembic/AbcCoreFactory/All.h>
#include <Alembic/Util/All.h>
#include <Alembic/Abc/TypedPropertyTraits.h>
#include <iostream>
#include <sstream>
//-*****************************************************************************
using namespace ::Alembic::AbcGeom;
static const std::string g_sep( ";" );
//-*****************************************************************************
// FORWARD
void visitProperties( ICompoundProperty, std::string & );
//-*****************************************************************************
template <class PROP>
void visitSimpleArrayProperty( PROP iProp, const std::string &iIndent )
{
std::string ptype = "ArrayProperty ";
size_t asize = 0;
AbcA::ArraySamplePtr samp;
index_t maxSamples = iProp.getNumSamples();
for ( index_t i = 0 ; i < maxSamples; ++i )
{
iProp.get( samp, ISampleSelector( i ) );
asize = samp->size();
};
std::string mdstring = "interpretation=";
mdstring += iProp.getMetaData().get( "interpretation" );
std::stringstream dtype;
dtype << "datatype=";
dtype << iProp.getDataType();
std::stringstream asizestr;
asizestr << ";arraysize=";
asizestr << asize;
mdstring += g_sep;
mdstring += dtype.str();
mdstring += asizestr.str();
std::cout << iIndent << " " << ptype << "name=" << iProp.getName()
<< g_sep << mdstring << g_sep << "numsamps="
<< iProp.getNumSamples() << std::endl;
}
//-*****************************************************************************
template <class PROP>
void visitSimpleScalarProperty( PROP iProp, const std::string &iIndent )
{
std::string ptype = "ScalarProperty ";
size_t asize = 0;
const AbcA::DataType &dt = iProp.getDataType();
const Alembic::Util ::uint8_t extent = dt.getExtent();
Alembic::Util::Dimensions dims( extent );
AbcA::ArraySamplePtr samp =
AbcA::AllocateArraySample( dt, dims );
index_t maxSamples = iProp.getNumSamples();
for ( index_t i = 0 ; i < maxSamples; ++i )
{
iProp.get( const_cast<void*>( samp->getData() ),
ISampleSelector( i ) );
asize = samp->size();
};
std::string mdstring = "interpretation=";
mdstring += iProp.getMetaData().get( "interpretation" );
std::stringstream dtype;
dtype << "datatype=";
dtype << dt;
std::stringstream asizestr;
asizestr << ";arraysize=";
asizestr << asize;
mdstring += g_sep;
mdstring += dtype.str();
mdstring += asizestr.str();
std::cout << iIndent << " " << ptype << "name=" << iProp.getName()
<< g_sep << mdstring << g_sep << "numsamps="
<< iProp.getNumSamples() << std::endl;
}
//-*****************************************************************************
void visitCompoundProperty( ICompoundProperty iProp, std::string &ioIndent )
{
std::string oldIndent = ioIndent;
ioIndent += " ";
std::string interp = "schema=";
interp += iProp.getMetaData().get( "schema" );
std::cout << ioIndent << "CompoundProperty " << "name=" << iProp.getName()
<< g_sep << interp << std::endl;
visitProperties( iProp, ioIndent );
ioIndent = oldIndent;
}
//-*****************************************************************************
void visitProperties( ICompoundProperty iParent,
std::string &ioIndent )
{
std::string oldIndent = ioIndent;
for ( size_t i = 0 ; i < iParent.getNumProperties() ; i++ )
{
PropertyHeader header = iParent.getPropertyHeader( i );
if ( header.isCompound() )
{
visitCompoundProperty( ICompoundProperty( iParent,
header.getName() ),
ioIndent );
}
else if ( header.isScalar() )
{
visitSimpleScalarProperty( IScalarProperty( iParent,
header.getName() ),
ioIndent );
}
else
{
assert( header.isArray() );
visitSimpleArrayProperty( IArrayProperty( iParent,
header.getName() ),
ioIndent );
}
}
ioIndent = oldIndent;
}
//-*****************************************************************************
void visitObject( IObject iObj,
std::string iIndent )
{
// Object has a name, a full name, some meta data,
// and then it has a compound property full of properties.
std::string path = iObj.getFullName();
if ( path != "/" )
{
std::cout << "Object " << "name=" << path << std::endl;
}
// Get the properties.
ICompoundProperty props = iObj.getProperties();
visitProperties( props, iIndent );
// now the child objects
for ( size_t i = 0 ; i < iObj.getNumChildren() ; i++ )
{
visitObject( IObject( iObj, iObj.getChildHeader( i ).getName() ),
iIndent );
}
}
//-*****************************************************************************
//-*****************************************************************************
// DO IT.
//-*****************************************************************************
//-*****************************************************************************
int main( int argc, char *argv[] )
{
if ( argc != 2 )
{
std::cerr << "USAGE: " << argv[0] << " <AlembicArchive.abc>"
<< std::endl;
exit( -1 );
}
// Scoped.
{
Alembic::AbcCoreFactory::IFactory factory;
factory.setPolicy(ErrorHandler::kQuietNoopPolicy);
IArchive archive = factory.getArchive( argv[1] );
if (archive)
{
std::cout << "AbcEcho for "
<< Alembic::AbcCoreAbstract::GetLibraryVersion ()
<< std::endl;;
std::string appName;
std::string libraryVersionString;
Alembic::Util::uint32_t libraryVersion;
std::string whenWritten;
std::string userDescription;
GetArchiveInfo (archive,
appName,
libraryVersionString,
libraryVersion,
whenWritten,
userDescription);
if (appName != "")
{
std::cout << " file written by: " << appName << std::endl;
std::cout << " using Alembic : " << libraryVersionString << std::endl;
std::cout << " written on : " << whenWritten << std::endl;
std::cout << " user description : " << userDescription << std::endl;
std::cout << std::endl;
}
else
{
std::cout << argv[1] << std::endl;
std::cout << " (file doesn't have any ArchiveInfo)"
<< std::endl;
std::cout << std::endl;
}
}
visitObject( archive.getTop(), "" );
}
return 0;
}