1 //-*****************************************************************************
2 //
3 // Copyright (c) 2013,
4 //  Sony Pictures Imageworks Inc. and
5 //  Industrial Light & Magic, a division of Lucasfilm Entertainment Company Ltd.
6 //
7 // All rights reserved.
8 //
9 // Redistribution and use in source and binary forms, with or without
10 // modification, are permitted provided that the following conditions are
11 // met:
12 // *       Redistributions of source code must retain the above copyright
13 // notice, this list of conditions and the following disclaimer.
14 // *       Redistributions in binary form must reproduce the above
15 // copyright notice, this list of conditions and the following disclaimer
16 // in the documentation and/or other materials provided with the
17 // distribution.
18 // *       Neither the name of Sony Pictures Imageworks, nor
19 // Industrial Light & Magic, nor the names of their contributors may be used
20 // to endorse or promote products derived from this software without specific
21 // prior written permission.
22 //
23 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 //
35 //-*****************************************************************************
36 
37 #include <Alembic/AbcCoreOgawa/OrImpl.h>
38 #include <Alembic/AbcCoreOgawa/StreamManager.h>
39 
40 namespace Alembic {
41 namespace AbcCoreOgawa {
42 namespace ALEMBIC_VERSION_NS {
43 
44 //-*****************************************************************************
45 //-*****************************************************************************
46 // OBJECT READER IMPLEMENTATION
47 //-*****************************************************************************
48 //-*****************************************************************************
49 
50 //-*****************************************************************************
51 // Reading as a child of a parent.
OrImpl(AbcA::ObjectReaderPtr iParent,Ogawa::IGroupPtr iParentGroup,std::size_t iGroupIndex,ObjectHeaderPtr iHeader)52 OrImpl::OrImpl( AbcA::ObjectReaderPtr iParent,
53                 Ogawa::IGroupPtr iParentGroup,
54                 std::size_t iGroupIndex,
55                 ObjectHeaderPtr iHeader )
56     : m_header( iHeader )
57 {
58     m_parent = Alembic::Util::dynamic_pointer_cast< OrImpl,
59         AbcA::ObjectReader > (iParent);
60 
61     // Check validity of all inputs.
62     ABCA_ASSERT( m_parent, "Invalid parent in OrImpl(Object)" );
63     ABCA_ASSERT( m_header, "Invalid header in OrImpl(Object)" );
64 
65     m_archive = m_parent->getArchiveImpl();
66     ABCA_ASSERT( m_archive, "Invalid archive in OrImpl(Object)" );
67 
68     StreamIDPtr streamId = m_archive->getStreamID();
69     std::size_t id = streamId->getID();
70     Ogawa::IGroupPtr group = iParentGroup->getGroup( iGroupIndex, false, id );
71     m_data.reset( new OrData( group, iHeader->getFullName(), id,
72         *m_archive, m_archive->getIndexedMetaData() ) );
73 }
74 
75 //-*****************************************************************************
OrImpl(Alembic::Util::shared_ptr<ArImpl> iArchive,OrDataPtr iData,ObjectHeaderPtr iHeader)76 OrImpl::OrImpl( Alembic::Util::shared_ptr< ArImpl > iArchive,
77                 OrDataPtr iData,
78                 ObjectHeaderPtr iHeader )
79     : m_archive( iArchive )
80     , m_data( iData )
81     , m_header( iHeader )
82 {
83 
84     ABCA_ASSERT( m_archive, "Invalid archive in OrImpl(Archive)" );
85     ABCA_ASSERT( m_data, "Invalid data in OrImpl(Archive)" );
86     ABCA_ASSERT( m_header, "Invalid header in OrImpl(Archive)" );
87 }
88 
89 //-*****************************************************************************
~OrImpl()90 OrImpl::~OrImpl()
91 {
92     // Nothing.
93 }
94 
95 //-*****************************************************************************
getHeader() const96 const AbcA::ObjectHeader & OrImpl::getHeader() const
97 {
98     return *m_header;
99 }
100 
101 //-*****************************************************************************
getArchive()102 AbcA::ArchiveReaderPtr OrImpl::getArchive()
103 {
104     return m_archive;
105 }
106 
107 //-*****************************************************************************
getParent()108 AbcA::ObjectReaderPtr OrImpl::getParent()
109 {
110     return m_parent;
111 }
112 
113 //-*****************************************************************************
getProperties()114 AbcA::CompoundPropertyReaderPtr OrImpl::getProperties()
115 {
116     return m_data->getProperties( asObjectPtr() );
117 }
118 
119 //-*****************************************************************************
getNumChildren()120 size_t OrImpl::getNumChildren()
121 {
122     return m_data->getNumChildren();
123 }
124 
125 //-*****************************************************************************
getChildHeader(size_t i)126 const AbcA::ObjectHeader & OrImpl::getChildHeader( size_t i )
127 {
128     return m_data->getChildHeader( asObjectPtr(), i );
129 }
130 
131 //-*****************************************************************************
getChildHeader(const std::string & iName)132 const AbcA::ObjectHeader * OrImpl::getChildHeader( const std::string &iName )
133 {
134     return m_data->getChildHeader( asObjectPtr(), iName );
135 }
136 
137 //-*****************************************************************************
getChild(const std::string & iName)138 AbcA::ObjectReaderPtr OrImpl::getChild( const std::string &iName )
139 {
140     return m_data->getChild( asObjectPtr(), iName );
141 }
142 
getChild(size_t i)143 AbcA::ObjectReaderPtr OrImpl::getChild( size_t i )
144 {
145     return m_data->getChild( asObjectPtr(), i );
146 }
147 
148 //-*****************************************************************************
asObjectPtr()149 AbcA::ObjectReaderPtr OrImpl::asObjectPtr()
150 {
151     return shared_from_this();
152 }
153 
154 //-*****************************************************************************
getPropertiesHash(Util::Digest & oDigest)155 bool OrImpl::getPropertiesHash( Util::Digest & oDigest )
156 {
157     StreamIDPtr streamId = m_archive->getStreamID();
158     std::size_t id = streamId->getID();
159     m_data->getPropertiesHash( oDigest, id );
160     return true;
161 }
162 
163 //-*****************************************************************************
getChildrenHash(Util::Digest & oDigest)164 bool OrImpl::getChildrenHash( Util::Digest & oDigest )
165 {
166     StreamIDPtr streamId = m_archive->getStreamID();
167     std::size_t id = streamId->getID();
168     m_data->getChildrenHash( oDigest, id );
169     return true;
170 }
171 
172 //-*****************************************************************************
getArchiveImpl() const173 Alembic::Util::shared_ptr< ArImpl > OrImpl::getArchiveImpl() const
174 {
175     return m_archive;
176 }
177 
178 } // End namespace ALEMBIC_VERSION_NS
179 } // End namespace AbcCoreOgawa
180 } // End namespace Alembic
181