diff options
author | Mathias Agopian <mathias@google.com> | 2012-02-20 16:58:20 -0800 |
---|---|---|
committer | Mathias Agopian <mathias@google.com> | 2012-02-20 22:38:43 -0800 |
commit | 83c64e6b624a876436d2ef5d2f173b10407e27b4 (patch) | |
tree | c4effc3260ab399e8fdae23baf06b076cd87a604 /libs/androidfw/AssetDir.cpp | |
parent | 94d0024557f415b8463f085c9784a3e1d02b58c6 (diff) |
frameworks/base refactoring
create the new libandroidfw from parts of libui and libutils
Change-Id: I1584995616fff5d527a2aba63921b682a6194d58
Diffstat (limited to 'libs/androidfw/AssetDir.cpp')
-rw-r--r-- | libs/androidfw/AssetDir.cpp | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/libs/androidfw/AssetDir.cpp b/libs/androidfw/AssetDir.cpp new file mode 100644 index 000000000000..475f521c117b --- /dev/null +++ b/libs/androidfw/AssetDir.cpp @@ -0,0 +1,66 @@ +/* + * Copyright (C) 2006 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. + */ + +// +// Provide access to a virtual directory in "asset space". Most of the +// implementation is in the header file or in friend functions in +// AssetManager. +// +#include <androidfw/AssetDir.h> + +using namespace android; + + +/* + * Find a matching entry in a vector of FileInfo. Because it's sorted, we + * can use a binary search. + * + * Assumes the vector is sorted in ascending order. + */ +/*static*/ int AssetDir::FileInfo::findEntry(const SortedVector<FileInfo>* pVector, + const String8& fileName) +{ + FileInfo tmpInfo; + + tmpInfo.setFileName(fileName); + return pVector->indexOf(tmpInfo); + +#if 0 // don't need this after all (uses 1/2 compares of SortedVector though) + int lo, hi, cur; + + lo = 0; + hi = pVector->size() -1; + while (lo <= hi) { + int cmp; + + cur = (hi + lo) / 2; + cmp = strcmp(pVector->itemAt(cur).getFileName(), fileName); + if (cmp == 0) { + /* match, bail */ + return cur; + } else if (cmp < 0) { + /* too low */ + lo = cur + 1; + } else { + /* too high */ + hi = cur -1; + } + } + + return -1; +#endif +} + |