/* * Copyright (C) 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ART_LIBDEXFILE_EXTERNAL_INCLUDE_ART_API_DEX_FILE_EXTERNAL_H_ #define ART_LIBDEXFILE_EXTERNAL_INCLUDE_ART_API_DEX_FILE_EXTERNAL_H_ // Dex file external API #include #ifdef __cplusplus extern "C" { #endif // This is the stable C ABI that backs art_api::dex below. Structs and functions // may only be added here. C++ users should use dex_file_support.h instead. // Opaque wrapper for an std::string allocated in libdexfile which must be freed // using ExtDexFileFreeString. struct ExtDexFileString; // Returns an ExtDexFileString initialized to the given string. const struct ExtDexFileString* ExtDexFileMakeString(const char* str, size_t size); // Returns a pointer to the underlying null-terminated character array and its // size for the given ExtDexFileString. const char* ExtDexFileGetString(const struct ExtDexFileString* ext_string, /*out*/ size_t* size); // Frees an ExtDexFileString. void ExtDexFileFreeString(const struct ExtDexFileString* ext_string); struct ExtDexFileMethodInfo { int32_t offset; int32_t len; const struct ExtDexFileString* name; }; struct ExtDexFile; // See art_api::dex::DexFile::OpenFromMemory. Returns true on success. int ExtDexFileOpenFromMemory(const void* addr, /*inout*/ size_t* size, const char* location, /*out*/ const struct ExtDexFileString** error_msg, /*out*/ struct ExtDexFile** ext_dex_file); // See art_api::dex::DexFile::OpenFromFd. Returns true on success. int ExtDexFileOpenFromFd(int fd, off_t offset, const char* location, /*out*/ const struct ExtDexFileString** error_msg, /*out*/ struct ExtDexFile** ext_dex_file); // See art_api::dex::DexFile::GetMethodInfoForOffset. Returns true on success. int ExtDexFileGetMethodInfoForOffset(struct ExtDexFile* ext_dex_file, int64_t dex_offset, int with_signature, /*out*/ struct ExtDexFileMethodInfo* method_info); typedef void ExtDexFileMethodInfoCallback(const struct ExtDexFileMethodInfo* ext_method_info, void* user_data); // See art_api::dex::DexFile::GetAllMethodInfos. void ExtDexFileGetAllMethodInfos(struct ExtDexFile* ext_dex_file, int with_signature, ExtDexFileMethodInfoCallback* method_info_cb, void* user_data); // Frees an ExtDexFile. void ExtDexFileFree(struct ExtDexFile* ext_dex_file); #ifdef __cplusplus } // extern "C" #endif #endif // ART_LIBDEXFILE_EXTERNAL_INCLUDE_ART_API_DEX_FILE_EXTERNAL_H_