forked from mozilla/gecko-dev
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnsUConvPropertySearch.cpp
40 lines (33 loc) · 1.17 KB
/
nsUConvPropertySearch.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "nsUConvPropertySearch.h"
#include "nsCRT.h"
#include "nsString.h"
#include "mozilla/BinarySearch.h"
namespace {
struct PropertyComparator {
const nsCString& mKey;
explicit PropertyComparator(const nsCString& aKey) : mKey(aKey) {}
int operator()(const nsUConvProp& aProperty) const {
return Compare(mKey, nsDependentCString(aProperty.mKey));
}
};
} // namespace
// static
nsresult nsUConvPropertySearch::SearchPropertyValue(
const nsUConvProp aProperties[], int32_t aNumberOfProperties,
const nsACString& aKey, nsACString& aValue) {
using mozilla::BinarySearchIf;
const nsCString& flat = PromiseFlatCString(aKey);
size_t index;
if (BinarySearchIf(aProperties, 0, aNumberOfProperties,
PropertyComparator(flat), &index)) {
nsDependentCString val(aProperties[index].mValue,
aProperties[index].mValueLength);
aValue.Assign(val);
return NS_OK;
}
aValue.Truncate();
return NS_ERROR_FAILURE;
}