blob: e429411971290cf7fbbd4f448eac33fc4218afe1 [file] [log] [blame]
Andreas Huber1aec3972016-08-26 09:26:32 -07001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Andreas Huberc9410c72016-07-28 12:18:40 -070017#include "ArrayType.h"
18
Iliyan Malcheva72e0d22016-09-09 11:03:08 -070019#include <hidl-util/Formatter.h>
Andreas Huber881227d2016-08-02 14:20:21 -070020#include <android-base/logging.h>
21
Yifan Hongf24fa852016-09-23 11:03:15 -070022#include "ConstantExpression.h"
23
Andreas Huberc9410c72016-07-28 12:18:40 -070024namespace android {
25
Yifan Hongf24fa852016-09-23 11:03:15 -070026ArrayType::ArrayType(ArrayType *srcArray, ConstantExpression *size)
Andreas Huber709b62d2016-09-19 11:21:18 -070027 : mElementType(srcArray->mElementType),
Yifan Hong5706a432016-11-02 09:44:18 -070028 mSizes(srcArray->mSizes) {
Yifan Hongbd33e382016-11-02 13:30:17 -070029 prependDimension(size);
Andreas Huber709b62d2016-09-19 11:21:18 -070030}
31
Yifan Hongf24fa852016-09-23 11:03:15 -070032ArrayType::ArrayType(Type *elementType, ConstantExpression *size)
Andreas Huber709b62d2016-09-19 11:21:18 -070033 : mElementType(elementType) {
Yifan Hongbd33e382016-11-02 13:30:17 -070034 prependDimension(size);
Andreas Huber709b62d2016-09-19 11:21:18 -070035}
36
Yifan Hongbd33e382016-11-02 13:30:17 -070037void ArrayType::prependDimension(ConstantExpression *size) {
Yifan Hong5706a432016-11-02 09:44:18 -070038 mSizes.insert(mSizes.begin(), size);
Andreas Huberc9410c72016-07-28 12:18:40 -070039}
40
Yifan Hongbd33e382016-11-02 13:30:17 -070041void ArrayType::appendDimension(ConstantExpression *size) {
Yifan Hong5706a432016-11-02 09:44:18 -070042 mSizes.push_back(size);
Yifan Hongbd33e382016-11-02 13:30:17 -070043}
44
Andreas Huberf03332a2016-09-22 15:35:43 -070045size_t ArrayType::countDimensions() const {
46 return mSizes.size();
47}
48
Steven Moreland979e0992016-09-07 09:18:08 -070049void ArrayType::addNamedTypesToSet(std::set<const FQName> &set) const {
50 mElementType->addNamedTypesToSet(set);
51}
52
Andreas Huber709b62d2016-09-19 11:21:18 -070053bool ArrayType::isArray() const {
54 return true;
55}
56
Andreas Huberf03332a2016-09-22 15:35:43 -070057Type *ArrayType::getElementType() const {
58 return mElementType;
59}
60
Steven Moreland979e0992016-09-07 09:18:08 -070061std::string ArrayType::getCppType(StorageMode mode,
Steven Moreland979e0992016-09-07 09:18:08 -070062 bool specifyNamespaces) const {
Yifan Hong3b320f82016-11-01 15:15:54 -070063 const std::string base = mElementType->getCppStackType(specifyNamespaces);
Andreas Huber881227d2016-08-02 14:20:21 -070064
Steven Morelandc46e9842016-11-02 13:21:26 -070065 std::string space = specifyNamespaces ? "::android::hardware::" : "";
66 std::string arrayType = space + "hidl_array<" + base;
Andreas Huberf03332a2016-09-22 15:35:43 -070067
68 for (size_t i = 0; i < mSizes.size(); ++i) {
69 arrayType += ", ";
Yifan Hong5706a432016-11-02 09:44:18 -070070 arrayType += mSizes[i]->cppValue();
Andreas Huberf03332a2016-09-22 15:35:43 -070071
Yifan Hong5706a432016-11-02 09:44:18 -070072 if (!mSizes[i]->descriptionIsTrivial()) {
73 arrayType += " /* ";
74 arrayType += mSizes[i]->description();
75 arrayType += " */";
76 }
Andreas Huber709b62d2016-09-19 11:21:18 -070077 }
78
Andreas Huberf03332a2016-09-22 15:35:43 -070079 arrayType += ">";
Andreas Huber881227d2016-08-02 14:20:21 -070080
81 switch (mode) {
Martijn Coenenac587892016-11-17 15:14:19 +010082 case StorageMode_Compound:
Andreas Huber881227d2016-08-02 14:20:21 -070083 case StorageMode_Stack:
Andreas Huberf03332a2016-09-22 15:35:43 -070084 return arrayType;
Andreas Huber881227d2016-08-02 14:20:21 -070085
86 case StorageMode_Argument:
Andreas Huberf03332a2016-09-22 15:35:43 -070087 return "const " + arrayType + "&";
88
Andreas Huber881227d2016-08-02 14:20:21 -070089 case StorageMode_Result:
Andreas Huberf03332a2016-09-22 15:35:43 -070090 return "const " + arrayType + "*";
Andreas Huber881227d2016-08-02 14:20:21 -070091 }
Andreas Huberf03332a2016-09-22 15:35:43 -070092
93 CHECK(!"Should not be here");
Andreas Huber881227d2016-08-02 14:20:21 -070094}
95
Yifan Hong4ed13472016-11-02 10:44:11 -070096std::string ArrayType::getJavaType(bool forInitializer) const {
97 std::string base =
98 mElementType->getJavaType(forInitializer);
Andreas Huber709b62d2016-09-19 11:21:18 -070099
Yifan Hongf24fa852016-09-23 11:03:15 -0700100 for (size_t i = 0; i < mSizes.size(); ++i) {
Yifan Hong4ed13472016-11-02 10:44:11 -0700101 base += "[";
Andreas Huber709b62d2016-09-19 11:21:18 -0700102
103 if (forInitializer) {
Yifan Hong4ed13472016-11-02 10:44:11 -0700104 base += mSizes[i]->javaValue();
Andreas Huber709b62d2016-09-19 11:21:18 -0700105 }
106
Yifan Hong5706a432016-11-02 09:44:18 -0700107 if (!forInitializer || !mSizes[i]->descriptionIsTrivial()) {
108 if (forInitializer)
Yifan Hong4ed13472016-11-02 10:44:11 -0700109 base += " ";
110 base += "/* " + mSizes[i]->description() + " */";
Yifan Hong5706a432016-11-02 09:44:18 -0700111 }
Yifan Hongf24fa852016-09-23 11:03:15 -0700112
Yifan Hong4ed13472016-11-02 10:44:11 -0700113 base += "]";
Andreas Huber4c865b72016-09-14 15:26:27 -0700114 }
Andreas Huber4c865b72016-09-14 15:26:27 -0700115
116 return base;
Andreas Huber2831d512016-08-15 09:33:47 -0700117}
118
Andreas Huberf03332a2016-09-22 15:35:43 -0700119std::string ArrayType::getJavaWrapperType() const {
120 return mElementType->getJavaWrapperType();
121}
122
Zhuoyao Zhangc5ea9f52016-10-06 15:05:39 -0700123std::string ArrayType::getVtsType() const {
124 return "TYPE_ARRAY";
125}
126
Andreas Huber881227d2016-08-02 14:20:21 -0700127void ArrayType::emitReaderWriter(
128 Formatter &out,
129 const std::string &name,
130 const std::string &parcelObj,
131 bool parcelObjIsPointer,
132 bool isReader,
133 ErrorMode mode) const {
Yifan Hong3b320f82016-11-01 15:15:54 -0700134 std::string baseType = mElementType->getCppStackType();
Andreas Huber881227d2016-08-02 14:20:21 -0700135
Iliyan Malchev549e2592016-08-10 08:59:12 -0700136 const std::string parentName = "_hidl_" + name + "_parent";
Andreas Huber881227d2016-08-02 14:20:21 -0700137
138 out << "size_t " << parentName << ";\n\n";
139
140 const std::string parcelObjDeref =
141 parcelObj + (parcelObjIsPointer ? "->" : ".");
142
143 if (isReader) {
Andreas Huberf03332a2016-09-22 15:35:43 -0700144
Andreas Huber881227d2016-08-02 14:20:21 -0700145 out << name
Andreas Huberf03332a2016-09-22 15:35:43 -0700146 << " = ("
Yifan Hong3b320f82016-11-01 15:15:54 -0700147 << getCppResultType()
Andreas Huberf03332a2016-09-22 15:35:43 -0700148 << ")"
Andreas Huber881227d2016-08-02 14:20:21 -0700149 << parcelObjDeref
150 << "readBuffer(&"
151 << parentName
152 << ");\n\n";
153
154 out << "if (" << name << " == nullptr) {\n";
155
156 out.indent();
157
Iliyan Malchev549e2592016-08-10 08:59:12 -0700158 out << "_hidl_err = ::android::UNKNOWN_ERROR;\n";
Andreas Huber881227d2016-08-02 14:20:21 -0700159 handleError2(out, mode);
160
161 out.unindent();
162 out << "}\n\n";
163 } else {
Andreas Huberf03332a2016-09-22 15:35:43 -0700164 size_t numArrayElements = 1;
165 for (auto size : mSizes) {
Yifan Hong5706a432016-11-02 09:44:18 -0700166 numArrayElements *= size->castSizeT();
Andreas Huberf03332a2016-09-22 15:35:43 -0700167 }
168
Iliyan Malchev549e2592016-08-10 08:59:12 -0700169 out << "_hidl_err = "
Andreas Huber881227d2016-08-02 14:20:21 -0700170 << parcelObjDeref
171 << "writeBuffer("
172 << name
Andreas Huberf03332a2016-09-22 15:35:43 -0700173 << ".data(), "
174 << numArrayElements
175 << " * sizeof("
Andreas Huber881227d2016-08-02 14:20:21 -0700176 << baseType
177 << "), &"
178 << parentName
179 << ");\n";
180
181 handleError(out, mode);
182 }
183
184 emitReaderWriterEmbedded(
185 out,
Andreas Huberf9d49f12016-09-12 14:58:36 -0700186 0 /* depth */,
Andreas Huber881227d2016-08-02 14:20:21 -0700187 name,
Yifan Hongbe2a3732016-10-05 13:33:41 -0700188 name /* sanitizedName */,
Andreas Huber881227d2016-08-02 14:20:21 -0700189 isReader /* nameIsPointer */,
190 parcelObj,
191 parcelObjIsPointer,
192 isReader,
193 mode,
194 parentName,
195 "0 /* parentOffset */");
196}
197
198void ArrayType::emitReaderWriterEmbedded(
199 Formatter &out,
Andreas Huberf9d49f12016-09-12 14:58:36 -0700200 size_t depth,
Andreas Huber881227d2016-08-02 14:20:21 -0700201 const std::string &name,
Yifan Hongbe2a3732016-10-05 13:33:41 -0700202 const std::string &sanitizedName,
Andreas Huber881227d2016-08-02 14:20:21 -0700203 bool nameIsPointer,
204 const std::string &parcelObj,
205 bool parcelObjIsPointer,
206 bool isReader,
207 ErrorMode mode,
208 const std::string &parentName,
209 const std::string &offsetText) const {
210 if (!mElementType->needsEmbeddedReadWrite()) {
211 return;
212 }
213
214 const std::string nameDeref = name + (nameIsPointer ? "->" : ".");
215
Yifan Hong3b320f82016-11-01 15:15:54 -0700216 std::string baseType = mElementType->getCppStackType();
Andreas Huber881227d2016-08-02 14:20:21 -0700217
Andreas Huberf9d49f12016-09-12 14:58:36 -0700218 std::string iteratorName = "_hidl_index_" + std::to_string(depth);
219
220 out << "for (size_t "
221 << iteratorName
222 << " = 0; "
223 << iteratorName
224 << " < "
Yifan Hongbf459bc2016-08-23 16:50:37 -0700225 << dimension()
Andreas Huberf9d49f12016-09-12 14:58:36 -0700226 << "; ++"
227 << iteratorName
228 << ") {\n";
Andreas Huber881227d2016-08-02 14:20:21 -0700229
230 out.indent();
231
232 mElementType->emitReaderWriterEmbedded(
233 out,
Andreas Huberf9d49f12016-09-12 14:58:36 -0700234 depth + 1,
Andreas Huberf03332a2016-09-22 15:35:43 -0700235 nameDeref + "data()[" + iteratorName + "]",
Yifan Hongbe2a3732016-10-05 13:33:41 -0700236 sanitizedName + "_indexed",
Andreas Huber881227d2016-08-02 14:20:21 -0700237 false /* nameIsPointer */,
238 parcelObj,
239 parcelObjIsPointer,
240 isReader,
241 mode,
242 parentName,
Andreas Huberf9d49f12016-09-12 14:58:36 -0700243 offsetText
244 + " + " + iteratorName + " * sizeof("
245 + baseType
Andreas Huberf9d49f12016-09-12 14:58:36 -0700246 + ")");
Andreas Huber881227d2016-08-02 14:20:21 -0700247
248 out.unindent();
249
250 out << "}\n\n";
251}
252
Yifan Hongbf459bc2016-08-23 16:50:37 -0700253void ArrayType::emitResolveReferences(
254 Formatter &out,
255 const std::string &name,
256 bool nameIsPointer,
257 const std::string &parcelObj,
258 bool parcelObjIsPointer,
259 bool isReader,
260 ErrorMode mode) const {
261 emitResolveReferencesEmbedded(
262 out,
263 0 /* depth */,
264 name,
265 name /* sanitizedName */,
266 nameIsPointer,
267 parcelObj,
268 parcelObjIsPointer,
269 isReader,
270 mode,
271 "_hidl_" + name + "_parent",
272 "0 /* parentOffset */");
273}
274
275void ArrayType::emitResolveReferencesEmbedded(
276 Formatter &out,
277 size_t depth,
278 const std::string &name,
279 const std::string &sanitizedName,
280 bool nameIsPointer,
281 const std::string &parcelObj,
282 bool parcelObjIsPointer,
283 bool isReader,
284 ErrorMode mode,
285 const std::string &parentName,
286 const std::string &offsetText) const {
287 CHECK(needsResolveReferences() && mElementType->needsResolveReferences());
288
289 const std::string nameDeref = name + (nameIsPointer ? "->" : ".");
290
Yifan Hong3b320f82016-11-01 15:15:54 -0700291 std::string baseType = mElementType->getCppStackType();
Yifan Hongbf459bc2016-08-23 16:50:37 -0700292
293 std::string iteratorName = "_hidl_index_" + std::to_string(depth);
294
295 out << "for (size_t "
296 << iteratorName
297 << " = 0; "
298 << iteratorName
299 << " < "
300 << dimension()
301 << "; ++"
302 << iteratorName
303 << ") {\n";
304
305 out.indent();
306
307 mElementType->emitResolveReferencesEmbedded(
308 out,
309 depth + 1,
310 nameDeref + "data()[" + iteratorName + "]",
311 sanitizedName + "_indexed",
312 false /* nameIsPointer */,
313 parcelObj,
314 parcelObjIsPointer,
315 isReader,
316 mode,
317 parentName,
318 offsetText + " + " + iteratorName + " * sizeof("
319 + baseType
320 + ")");
321
322 out.unindent();
323
324 out << "}\n\n";
325}
326
327
Andreas Huber881227d2016-08-02 14:20:21 -0700328bool ArrayType::needsEmbeddedReadWrite() const {
329 return mElementType->needsEmbeddedReadWrite();
330}
331
Yifan Hongbf459bc2016-08-23 16:50:37 -0700332bool ArrayType::needsResolveReferences() const {
333 return mElementType->needsResolveReferences();
334}
335
Andreas Huberf03332a2016-09-22 15:35:43 -0700336bool ArrayType::resultNeedsDeref() const {
337 return true;
338}
339
Andreas Huber2831d512016-08-15 09:33:47 -0700340void ArrayType::emitJavaReaderWriter(
341 Formatter &out,
342 const std::string &parcelObj,
343 const std::string &argName,
344 bool isReader) const {
Andreas Huber709b62d2016-09-19 11:21:18 -0700345 if (isReader) {
Andreas Huber709b62d2016-09-19 11:21:18 -0700346 out << "new "
Yifan Hong4ed13472016-11-02 10:44:11 -0700347 << getJavaType(true /* forInitializer */)
Andreas Huber709b62d2016-09-19 11:21:18 -0700348 << ";\n";
Andreas Huberf630bc82016-09-09 14:52:25 -0700349 }
350
Andreas Huber709b62d2016-09-19 11:21:18 -0700351 out << "{\n";
352 out.indent();
353
Yifan Hong1af73532016-11-09 14:32:58 -0800354 out << "android.os.HwBlob _hidl_blob = ";
Andreas Huber709b62d2016-09-19 11:21:18 -0700355
356 if (isReader) {
357 out << parcelObj
358 << ".readBuffer();\n";
359 } else {
360 size_t align, size;
361 getAlignmentAndSize(&align, &size);
362
Yifan Hong1af73532016-11-09 14:32:58 -0800363 out << "new android.os.HwBlob("
Andreas Huber709b62d2016-09-19 11:21:18 -0700364 << size
365 << " /* size */);\n";
366 }
367
368 emitJavaFieldReaderWriter(
Andreas Huber2831d512016-08-15 09:33:47 -0700369 out,
Andreas Huber709b62d2016-09-19 11:21:18 -0700370 0 /* depth */,
Andreas Huber2831d512016-08-15 09:33:47 -0700371 parcelObj,
Andreas Huber709b62d2016-09-19 11:21:18 -0700372 "_hidl_blob",
Andreas Huber2831d512016-08-15 09:33:47 -0700373 argName,
Andreas Huber709b62d2016-09-19 11:21:18 -0700374 "0 /* offset */",
375 isReader);
376
377 if (!isReader) {
378 out << parcelObj << ".writeBuffer(_hidl_blob);\n";
379 }
380
381 out.unindent();
382 out << "}\n";
Andreas Huber2831d512016-08-15 09:33:47 -0700383}
384
Andreas Huber85eabdb2016-08-25 11:24:49 -0700385void ArrayType::emitJavaFieldInitializer(
386 Formatter &out, const std::string &fieldName) const {
Yifan Hong4ed13472016-11-02 10:44:11 -0700387 std::string typeName = getJavaType(false /* forInitializer */);
388 std::string initName = getJavaType(true /* forInitializer */);
Andreas Huber4c865b72016-09-14 15:26:27 -0700389
Andreas Hubercd5e6662016-08-30 15:02:59 -0700390 out << "final "
Andreas Huber4c865b72016-09-14 15:26:27 -0700391 << typeName
Andreas Huber4c865b72016-09-14 15:26:27 -0700392 << " "
Andreas Huber85eabdb2016-08-25 11:24:49 -0700393 << fieldName
394 << " = new "
Yifan Hong4ed13472016-11-02 10:44:11 -0700395 << initName
Andreas Huber4c865b72016-09-14 15:26:27 -0700396 << ";\n";
Andreas Huber85eabdb2016-08-25 11:24:49 -0700397}
398
399void ArrayType::emitJavaFieldReaderWriter(
400 Formatter &out,
Andreas Huber4c865b72016-09-14 15:26:27 -0700401 size_t depth,
Andreas Huber709b62d2016-09-19 11:21:18 -0700402 const std::string &parcelName,
Andreas Huber85eabdb2016-08-25 11:24:49 -0700403 const std::string &blobName,
404 const std::string &fieldName,
405 const std::string &offset,
406 bool isReader) const {
Andreas Huber90e8fc22016-09-21 16:36:15 -0700407 out << "{\n";
408 out.indent();
409
Andreas Huber709b62d2016-09-19 11:21:18 -0700410 std::string offsetName = "_hidl_array_offset_" + std::to_string(depth);
411 out << "long " << offsetName << " = " << offset << ";\n";
Andreas Huber4c865b72016-09-14 15:26:27 -0700412
Andreas Huber709b62d2016-09-19 11:21:18 -0700413 std::string indexString;
414 for (size_t dim = 0; dim < mSizes.size(); ++dim) {
415 std::string iteratorName =
416 "_hidl_index_" + std::to_string(depth) + "_" + std::to_string(dim);
Andreas Huber85eabdb2016-08-25 11:24:49 -0700417
Andreas Huber709b62d2016-09-19 11:21:18 -0700418 out << "for (int "
419 << iteratorName
420 << " = 0; "
421 << iteratorName
422 << " < "
Yifan Hong5706a432016-11-02 09:44:18 -0700423 << mSizes[dim]->javaValue()
Andreas Huber709b62d2016-09-19 11:21:18 -0700424 << "; ++"
425 << iteratorName
426 << ") {\n";
Andreas Huber85eabdb2016-08-25 11:24:49 -0700427
Andreas Huber709b62d2016-09-19 11:21:18 -0700428 out.indent();
429
430 indexString += "[" + iteratorName + "]";
431 }
432
433 if (isReader && mElementType->isCompoundType()) {
Andreas Huber709b62d2016-09-19 11:21:18 -0700434 std::string typeName =
Yifan Hong4ed13472016-11-02 10:44:11 -0700435 mElementType->getJavaType(false /* forInitializer */);
Andreas Huber709b62d2016-09-19 11:21:18 -0700436
437 out << fieldName
438 << indexString
439 << " = new "
440 << typeName
441 << "();\n";
442 }
Andreas Huber85eabdb2016-08-25 11:24:49 -0700443
444 mElementType->emitJavaFieldReaderWriter(
445 out,
Andreas Huber4c865b72016-09-14 15:26:27 -0700446 depth + 1,
Andreas Huber709b62d2016-09-19 11:21:18 -0700447 parcelName,
Andreas Huber85eabdb2016-08-25 11:24:49 -0700448 blobName,
Andreas Huber709b62d2016-09-19 11:21:18 -0700449 fieldName + indexString,
450 offsetName,
Andreas Huber85eabdb2016-08-25 11:24:49 -0700451 isReader);
452
Andreas Huber709b62d2016-09-19 11:21:18 -0700453 size_t elementAlign, elementSize;
454 mElementType->getAlignmentAndSize(&elementAlign, &elementSize);
455
456 out << offsetName << " += " << std::to_string(elementSize) << ";\n";
457
458 for (size_t dim = 0; dim < mSizes.size(); ++dim) {
459 out.unindent();
460 out << "}\n";
461 }
Andreas Huber90e8fc22016-09-21 16:36:15 -0700462
463 out.unindent();
464 out << "}\n";
Andreas Huber85eabdb2016-08-25 11:24:49 -0700465}
466
Zhuoyao Zhang5158db42016-08-10 10:25:20 -0700467status_t ArrayType::emitVtsTypeDeclarations(Formatter &out) const {
Zhuoyao Zhangc5ea9f52016-10-06 15:05:39 -0700468 out << "type: " << getVtsType() << "\n";
469 out << "vector_value: {\n";
Zhuoyao Zhang5158db42016-08-10 10:25:20 -0700470 out.indent();
Yifan Hong5706a432016-11-02 09:44:18 -0700471 out << "vector_size: " << mSizes[0]->value() << "\n";
Zhuoyao Zhangeb355ee2016-10-20 16:00:40 -0700472 // Simple array case.
473 if (mSizes.size() == 1) {
474 status_t err = mElementType->emitVtsTypeDeclarations(out);
475 if (err != OK) {
476 return err;
477 }
478 } else { // Multi-dimension array case.
479 for (size_t index = 1; index < mSizes.size(); index++) {
480 out << "type: " << getVtsType() << "\n";
481 out << "vector_value: {\n";
482 out.indent();
Yifan Hong5706a432016-11-02 09:44:18 -0700483 out << "vector_size: " << mSizes[index]->value() << "\n";
Zhuoyao Zhangeb355ee2016-10-20 16:00:40 -0700484 if (index == mSizes.size() - 1) {
485 status_t err = mElementType->emitVtsTypeDeclarations(out);
486 if (err != OK) {
487 return err;
488 }
489 }
490 }
Zhuoyao Zhang5158db42016-08-10 10:25:20 -0700491 }
Zhuoyao Zhangeb355ee2016-10-20 16:00:40 -0700492 for (size_t index = 0; index < mSizes.size(); index++) {
493 out.unindent();
494 out << "}\n";
495 }
Zhuoyao Zhang5158db42016-08-10 10:25:20 -0700496 return OK;
497}
498
Andreas Huber70a59e12016-08-16 12:57:01 -0700499bool ArrayType::isJavaCompatible() const {
500 return mElementType->isJavaCompatible();
501}
502
Andreas Huber85eabdb2016-08-25 11:24:49 -0700503void ArrayType::getAlignmentAndSize(size_t *align, size_t *size) const {
504 mElementType->getAlignmentAndSize(align, size);
505
Andreas Huber709b62d2016-09-19 11:21:18 -0700506 for (auto sizeInDimension : mSizes) {
Yifan Hong5706a432016-11-02 09:44:18 -0700507 (*size) *= sizeInDimension->castSizeT();
Andreas Huber709b62d2016-09-19 11:21:18 -0700508 }
Andreas Huber85eabdb2016-08-25 11:24:49 -0700509}
510
Yifan Hongbf459bc2016-08-23 16:50:37 -0700511size_t ArrayType::dimension() const {
512 size_t numArrayElements = 1;
513 for (auto size : mSizes) {
Yifan Hong5706a432016-11-02 09:44:18 -0700514 numArrayElements *= size->castSizeT();
Yifan Hongbf459bc2016-08-23 16:50:37 -0700515 }
516 return numArrayElements;
517}
518
Andreas Huberc9410c72016-07-28 12:18:40 -0700519} // namespace android
520