blob: 97ce8c8affa47611ff0f7574d83de198794f26e4 [file] [log] [blame]
Jason Samsa5597fc2009-07-08 18:01:53 -07001
2/*
3 * Copyright (C) 2009 The Android Open Source Project
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070018#ifndef ANDROID_RS_BUILD_FOR_HOST
Jason Samsa5597fc2009-07-08 18:01:53 -070019#include "rsContext.h"
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070020#else
21#include "rsContextHostStub.h"
22#endif
Jason Samsa5597fc2009-07-08 18:01:53 -070023
Jason Samsa5597fc2009-07-08 18:01:53 -070024#include "rsFileA3D.h"
25
26#include "rsMesh.h"
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070027#include "rsAnimation.h"
Jason Samsa5597fc2009-07-08 18:01:53 -070028
Alex Sakhartchoukd3e0ad42010-06-24 17:15:34 -070029
Jason Samsa5597fc2009-07-08 18:01:53 -070030using namespace android;
31using namespace android::renderscript;
32
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080033FileA3D::FileA3D(Context *rsc) : ObjectBase(rsc) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070034 mAlloc = NULL;
35 mData = NULL;
36 mWriteStream = NULL;
37 mReadStream = NULL;
Alex Sakhartchouk5224a272011-01-07 11:12:08 -080038 mAsset = NULL;
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070039
40 mMajorVersion = 0;
41 mMinorVersion = 1;
42 mDataSize = 0;
Jason Samsa5597fc2009-07-08 18:01:53 -070043}
44
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080045FileA3D::~FileA3D() {
46 for (size_t i = 0; i < mIndex.size(); i ++) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070047 delete mIndex[i];
48 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080049 for (size_t i = 0; i < mWriteIndex.size(); i ++) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070050 delete mWriteIndex[i];
51 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080052 if (mWriteStream) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070053 delete mWriteStream;
54 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080055 if (mReadStream) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070056 delete mWriteStream;
57 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080058 if (mAlloc) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -070059 free(mAlloc);
60 }
Alex Sakhartchouk5224a272011-01-07 11:12:08 -080061 if (mAsset) {
62 delete mAsset;
63 }
Jason Samsa5597fc2009-07-08 18:01:53 -070064}
65
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080066void FileA3D::parseHeader(IStream *headerStream) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070067 mMajorVersion = headerStream->loadU32();
68 mMinorVersion = headerStream->loadU32();
69 uint32_t flags = headerStream->loadU32();
70 mUse64BitOffsets = (flags & 1) != 0;
71
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070072 uint32_t numIndexEntries = headerStream->loadU32();
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080073 for (uint32_t i = 0; i < numIndexEntries; i ++) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070074 A3DIndexEntry *entry = new A3DIndexEntry();
75 headerStream->loadString(&entry->mObjectName);
Alex Sakhartchouk383e5b12010-09-23 16:16:33 -070076 LOGV("Header data, entry name = %s", entry->mObjectName.string());
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070077 entry->mType = (RsA3DClassID)headerStream->loadU32();
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080078 if (mUse64BitOffsets){
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070079 entry->mOffset = headerStream->loadOffset();
80 entry->mLength = headerStream->loadOffset();
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080081 } else {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070082 entry->mOffset = headerStream->loadU32();
83 entry->mLength = headerStream->loadU32();
84 }
85 entry->mRsObj = NULL;
86 mIndex.push(entry);
87 }
88}
89
Alex Sakhartchouk5224a272011-01-07 11:12:08 -080090bool FileA3D::load(Asset *asset) {
91 mAsset = asset;
92 return load(asset->getBuffer(false), asset->getLength());
93}
94
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -080095bool FileA3D::load(const void *data, size_t length) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -070096 const uint8_t *localData = (const uint8_t *)data;
97
98 size_t lengthRemaining = length;
99 size_t magicStrLen = 12;
100 if ((length < magicStrLen) ||
101 memcmp(data, "Android3D_ff", magicStrLen)) {
102 return false;
103 }
104
105 localData += magicStrLen;
106 lengthRemaining -= magicStrLen;
107
108 // Next we get our header size
109 uint64_t headerSize = 0;
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800110 if (lengthRemaining < sizeof(headerSize)) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700111 return false;
112 }
113
114 memcpy(&headerSize, localData, sizeof(headerSize));
115 localData += sizeof(headerSize);
116 lengthRemaining -= sizeof(headerSize);
117
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800118 if (lengthRemaining < headerSize) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700119 return false;
120 }
121
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700122 // Now open the stream to parse the header
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700123 IStream headerStream(localData, false);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700124 parseHeader(&headerStream);
125
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700126 localData += headerSize;
127 lengthRemaining -= headerSize;
128
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800129 if (lengthRemaining < sizeof(mDataSize)) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700130 return false;
131 }
132
133 // Read the size of the data
134 memcpy(&mDataSize, localData, sizeof(mDataSize));
135 localData += sizeof(mDataSize);
136 lengthRemaining -= sizeof(mDataSize);
137
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800138 if (lengthRemaining < mDataSize) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700139 return false;
140 }
141
142 // We should know enough to read the file in at this point.
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700143 mData = (uint8_t *)localData;
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700144 mReadStream = new IStream(mData, mUse64BitOffsets);
145
146 return true;
147}
148
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800149bool FileA3D::load(FILE *f) {
Jason Samsa5597fc2009-07-08 18:01:53 -0700150 char magicString[12];
151 size_t len;
152
Alex Sakhartchouk383e5b12010-09-23 16:16:33 -0700153 LOGV("file open 1");
Jason Samsa5597fc2009-07-08 18:01:53 -0700154 len = fread(magicString, 1, 12, f);
155 if ((len != 12) ||
156 memcmp(magicString, "Android3D_ff", 12)) {
157 return false;
158 }
159
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700160 // Next thing is the size of the header
161 uint64_t headerSize = 0;
162 len = fread(&headerSize, 1, sizeof(headerSize), f);
163 if (len != sizeof(headerSize) || headerSize == 0) {
Jason Samsa5597fc2009-07-08 18:01:53 -0700164 return false;
165 }
166
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700167 uint8_t *headerData = (uint8_t *)malloc(headerSize);
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800168 if (!headerData) {
Jason Samsa5597fc2009-07-08 18:01:53 -0700169 return false;
170 }
171
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700172 len = fread(headerData, 1, headerSize, f);
173 if (len != headerSize) {
Jason Samsa5597fc2009-07-08 18:01:53 -0700174 return false;
175 }
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700176
177 // Now open the stream to parse the header
178 IStream headerStream(headerData, false);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700179 parseHeader(&headerStream);
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700180
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700181 free(headerData);
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700182
183 // Next thing is the size of the header
184 len = fread(&mDataSize, 1, sizeof(mDataSize), f);
185 if (len != sizeof(mDataSize) || mDataSize == 0) {
186 return false;
Jason Samsa5597fc2009-07-08 18:01:53 -0700187 }
188
Alex Sakhartchouk383e5b12010-09-23 16:16:33 -0700189 LOGV("file open size = %lli", mDataSize);
Jason Samsa5597fc2009-07-08 18:01:53 -0700190
191 // We should know enough to read the file in at this point.
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700192 mAlloc = malloc(mDataSize);
Jason Samsa5597fc2009-07-08 18:01:53 -0700193 if (!mAlloc) {
194 return false;
195 }
196 mData = (uint8_t *)mAlloc;
197 len = fread(mAlloc, 1, mDataSize, f);
198 if (len != mDataSize) {
199 return false;
200 }
201
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700202 mReadStream = new IStream(mData, mUse64BitOffsets);
203
Alex Sakhartchouk383e5b12010-09-23 16:16:33 -0700204 LOGV("Header is read an stream initialized");
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700205 return true;
Jason Samsa5597fc2009-07-08 18:01:53 -0700206}
207
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700208size_t FileA3D::getNumIndexEntries() const {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700209 return mIndex.size();
210}
Jason Samsa5597fc2009-07-08 18:01:53 -0700211
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700212const FileA3D::A3DIndexEntry *FileA3D::getIndexEntry(size_t index) const {
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800213 if (index < mIndex.size()) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700214 return mIndex[index];
Jason Samsa5597fc2009-07-08 18:01:53 -0700215 }
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700216 return NULL;
Jason Samsa5597fc2009-07-08 18:01:53 -0700217}
218
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700219ObjectBase *FileA3D::initializeFromEntry(size_t index) {
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800220 if (index >= mIndex.size()) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700221 return NULL;
222 }
223
224 FileA3D::A3DIndexEntry *entry = mIndex[index];
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800225 if (!entry) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700226 return NULL;
227 }
228
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800229 if (entry->mRsObj) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700230 entry->mRsObj->incUserRef();
231 return entry->mRsObj;
232 }
233
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700234 // Seek to the beginning of object
235 mReadStream->reset(entry->mOffset);
236 switch (entry->mType) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700237 case RS_A3D_CLASS_ID_UNKNOWN:
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700238 return NULL;
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700239 case RS_A3D_CLASS_ID_MESH:
240 entry->mRsObj = Mesh::createFromStream(mRSC, mReadStream);
241 break;
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700242 case RS_A3D_CLASS_ID_TYPE:
243 entry->mRsObj = Type::createFromStream(mRSC, mReadStream);
244 break;
245 case RS_A3D_CLASS_ID_ELEMENT:
246 entry->mRsObj = Element::createFromStream(mRSC, mReadStream);
247 break;
248 case RS_A3D_CLASS_ID_ALLOCATION:
249 entry->mRsObj = Allocation::createFromStream(mRSC, mReadStream);
250 break;
251 case RS_A3D_CLASS_ID_PROGRAM_VERTEX:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800252 //entry->mRsObj = ProgramVertex::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700253 break;
254 case RS_A3D_CLASS_ID_PROGRAM_RASTER:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800255 //entry->mRsObj = ProgramRaster::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700256 break;
257 case RS_A3D_CLASS_ID_PROGRAM_FRAGMENT:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800258 //entry->mRsObj = ProgramFragment::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700259 break;
260 case RS_A3D_CLASS_ID_PROGRAM_STORE:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800261 //entry->mRsObj = ProgramStore::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700262 break;
263 case RS_A3D_CLASS_ID_SAMPLER:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800264 //entry->mRsObj = Sampler::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700265 break;
266 case RS_A3D_CLASS_ID_ANIMATION:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800267 //entry->mRsObj = Animation::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700268 break;
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700269 case RS_A3D_CLASS_ID_ADAPTER_1D:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800270 //entry->mRsObj = Adapter1D::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700271 break;
272 case RS_A3D_CLASS_ID_ADAPTER_2D:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800273 //entry->mRsObj = Adapter2D::createFromStream(mRSC, mReadStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700274 break;
275 case RS_A3D_CLASS_ID_SCRIPT_C:
Alex Sakhartchouk099d7d32011-01-28 09:31:47 -0800276 break;
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700277 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800278 if (entry->mRsObj) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700279 entry->mRsObj->incUserRef();
280 }
281 return entry->mRsObj;
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700282}
283
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800284bool FileA3D::writeFile(const char *filename) {
285 if (!mWriteStream) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700286 LOGE("No objects to write\n");
287 return false;
288 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800289 if (mWriteStream->getPos() == 0) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700290 LOGE("No objects to write\n");
291 return false;
292 }
Jason Samsa5597fc2009-07-08 18:01:53 -0700293
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700294 FILE *writeHandle = fopen(filename, "wb");
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800295 if (!writeHandle) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700296 LOGE("Couldn't open the file for writing\n");
297 return false;
298 }
Jason Samsa5597fc2009-07-08 18:01:53 -0700299
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700300 // Open a new stream to make writing the header easier
301 OStream headerStream(5*1024, false);
302 headerStream.addU32(mMajorVersion);
303 headerStream.addU32(mMinorVersion);
304 uint32_t is64Bit = 0;
305 headerStream.addU32(is64Bit);
Jason Samsa5597fc2009-07-08 18:01:53 -0700306
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700307 uint32_t writeIndexSize = mWriteIndex.size();
308 headerStream.addU32(writeIndexSize);
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800309 for (uint32_t i = 0; i < writeIndexSize; i ++) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700310 headerStream.addString(&mWriteIndex[i]->mObjectName);
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700311 headerStream.addU32((uint32_t)mWriteIndex[i]->mType);
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800312 if (mUse64BitOffsets){
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700313 headerStream.addOffset(mWriteIndex[i]->mOffset);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700314 headerStream.addOffset(mWriteIndex[i]->mLength);
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800315 } else {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700316 uint32_t offset = (uint32_t)mWriteIndex[i]->mOffset;
317 headerStream.addU32(offset);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700318 offset = (uint32_t)mWriteIndex[i]->mLength;
319 headerStream.addU32(offset);
Jason Samsa5597fc2009-07-08 18:01:53 -0700320 }
321 }
322
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700323 // Write our magic string so we know we are reading the right file
324 String8 magicString(A3D_MAGIC_KEY);
325 fwrite(magicString.string(), sizeof(char), magicString.size(), writeHandle);
Jason Samsa5597fc2009-07-08 18:01:53 -0700326
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700327 // Store the size of the header to make it easier to parse when we read it
328 uint64_t headerSize = headerStream.getPos();
329 fwrite(&headerSize, sizeof(headerSize), 1, writeHandle);
Jason Samsa5597fc2009-07-08 18:01:53 -0700330
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700331 // Now write our header
332 fwrite(headerStream.getPtr(), sizeof(uint8_t), headerStream.getPos(), writeHandle);
Jason Samsa5597fc2009-07-08 18:01:53 -0700333
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700334 // Now write the size of the data part of the file for easier parsing later
335 uint64_t fileDataSize = mWriteStream->getPos();
336 fwrite(&fileDataSize, sizeof(fileDataSize), 1, writeHandle);
337
338 fwrite(mWriteStream->getPtr(), sizeof(uint8_t), mWriteStream->getPos(), writeHandle);
339
340 int status = fclose(writeHandle);
341
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800342 if (status != 0) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700343 LOGE("Couldn't close file\n");
344 return false;
Jason Samsa5597fc2009-07-08 18:01:53 -0700345 }
346
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700347 return true;
Jason Samsa5597fc2009-07-08 18:01:53 -0700348}
349
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700350void FileA3D::appendToFile(ObjectBase *obj) {
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800351 if (!obj) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700352 return;
Jason Samsa5597fc2009-07-08 18:01:53 -0700353 }
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800354 if (!mWriteStream) {
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700355 const uint64_t initialStreamSize = 256*1024;
356 mWriteStream = new OStream(initialStreamSize, false);
Jason Samsa5597fc2009-07-08 18:01:53 -0700357 }
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700358 A3DIndexEntry *indexEntry = new A3DIndexEntry();
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700359 indexEntry->mObjectName.setTo(obj->getName());
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700360 indexEntry->mType = obj->getClassId();
361 indexEntry->mOffset = mWriteStream->getPos();
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700362 indexEntry->mRsObj = obj;
Alex Sakhartchoukfb6b6142010-05-21 12:53:13 -0700363 mWriteIndex.push(indexEntry);
364 obj->serialize(mWriteStream);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700365 indexEntry->mLength = mWriteStream->getPos() - indexEntry->mOffset;
366 mWriteStream->align(4);
Jason Samsa5597fc2009-07-08 18:01:53 -0700367}
368
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800369RsObjectBase rsaFileA3DGetEntryByIndex(RsContext con, uint32_t index, RsFile file) {
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700370 FileA3D *fa3d = static_cast<FileA3D *>(file);
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800371 if (!fa3d) {
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700372 LOGE("Can't load entry. No valid file");
373 return NULL;
374 }
375
376 ObjectBase *obj = fa3d->initializeFromEntry(index);
377 LOGV("Returning object with name %s", obj->getName());
378
379 return obj;
380}
381
382
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800383void rsaFileA3DGetNumIndexEntries(RsContext con, int32_t *numEntries, RsFile file) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700384 FileA3D *fa3d = static_cast<FileA3D *>(file);
385
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800386 if (fa3d) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700387 *numEntries = fa3d->getNumIndexEntries();
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800388 } else {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700389 *numEntries = 0;
390 }
391}
392
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800393void rsaFileA3DGetIndexEntries(RsContext con, RsFileIndexEntry *fileEntries, uint32_t numEntries, RsFile file) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700394 FileA3D *fa3d = static_cast<FileA3D *>(file);
395
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800396 if (!fa3d) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700397 LOGE("Can't load index entries. No valid file");
398 return;
399 }
400
401 uint32_t numFileEntries = fa3d->getNumIndexEntries();
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800402 if (numFileEntries != numEntries || numEntries == 0 || fileEntries == NULL) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700403 LOGE("Can't load index entries. Invalid number requested");
404 return;
405 }
406
Alex Sakhartchoukafb743a2010-11-09 17:00:54 -0800407 for (uint32_t i = 0; i < numFileEntries; i ++) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700408 const FileA3D::A3DIndexEntry *entry = fa3d->getIndexEntry(i);
409 fileEntries[i].classID = entry->getType();
410 fileEntries[i].objectName = entry->getObjectName().string();
411 }
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700412}
413
Alex Sakhartchouk5224a272011-01-07 11:12:08 -0800414RsFile rsaFileA3DCreateFromMemory(RsContext con, const void *data, uint32_t len) {
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700415 if (data == NULL) {
416 LOGE("File load failed. Asset stream is NULL");
417 return NULL;
418 }
419
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700420 Context *rsc = static_cast<Context *>(con);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700421 FileA3D *fa3d = new FileA3D(rsc);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700422 fa3d->incUserRef();
423
Alex Sakhartchoukdc763f32010-10-27 14:10:07 -0700424 fa3d->load(data, len);
Alex Sakhartchoukb825f672010-06-04 10:06:50 -0700425 return fa3d;
426}
Alex Sakhartchouk5224a272011-01-07 11:12:08 -0800427
428RsFile rsaFileA3DCreateFromAsset(RsContext con, void *_asset) {
429 Context *rsc = static_cast<Context *>(con);
430 Asset *asset = static_cast<Asset *>(_asset);
431 FileA3D *fa3d = new FileA3D(rsc);
432 fa3d->incUserRef();
433
434 fa3d->load(asset);
435 return fa3d;
436}
437
438RsFile rsaFileA3DCreateFromFile(RsContext con, const char *path) {
439 if (path == NULL) {
440 LOGE("File load failed. Path is NULL");
441 return NULL;
442 }
443
444 Context *rsc = static_cast<Context *>(con);
445 FileA3D *fa3d = NULL;
446
447 FILE *f = fopen(path, "rb");
448 if (f) {
449 fa3d = new FileA3D(rsc);
450 fa3d->incUserRef();
451 fa3d->load(f);
452 fclose(f);
453 } else {
454 LOGE("Could not open file %s", path);
455 }
456
457 return fa3d;
458}