| /* | 
 |  * Copyright (C) 2007 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. | 
 |  */ | 
 |  | 
 | // | 
 | // Miscellaneous zip/gzip utility functions. | 
 | // | 
 | #ifndef __LIBS_ZIPUTILS_H | 
 | #define __LIBS_ZIPUTILS_H | 
 |  | 
 | #include <stdio.h> | 
 |  | 
 | namespace android { | 
 |  | 
 | /* | 
 |  * Container class for utility functions, primarily for namespace reasons. | 
 |  */ | 
 | class ZipUtils { | 
 | public: | 
 |     /* | 
 |      * General utility function for uncompressing "deflate" data from a file | 
 |      * to a buffer. | 
 |      */ | 
 |     static bool inflateToBuffer(int fd, void* buf, long uncompressedLen, | 
 |         long compressedLen); | 
 |     static bool inflateToBuffer(FILE* fp, void* buf, long uncompressedLen, | 
 |         long compressedLen); | 
 |  | 
 |     /* | 
 |      * Someday we might want to make this generic and handle bzip2 ".bz2" | 
 |      * files too. | 
 |      * | 
 |      * We could declare gzip to be a sub-class of zip that has exactly | 
 |      * one always-compressed entry, but we currently want to treat Zip | 
 |      * and gzip as distinct, so there's no value. | 
 |      * | 
 |      * The zlib library has some gzip utilities, but it has no interface | 
 |      * for extracting the uncompressed length of the file (you do *not* | 
 |      * want to gzseek to the end). | 
 |      * | 
 |      * Pass in a seeked file pointer for the gzip file.  If this is a gzip | 
 |      * file, we set our return values appropriately and return "true" with | 
 |      * the file seeked to the start of the compressed data. | 
 |      */ | 
 |     static bool examineGzip(FILE* fp, int* pCompressionMethod, | 
 |         long* pUncompressedLen, long* pCompressedLen, unsigned long* pCRC32); | 
 |  | 
 | private: | 
 |     ZipUtils() {} | 
 |     ~ZipUtils() {} | 
 | }; | 
 |  | 
 | }; // namespace android | 
 |  | 
 | #endif /*__LIBS_ZIPUTILS_H*/ |