| Index: third_party/libaddressinput/chromium/trie.h
 | 
| diff --git a/third_party/libaddressinput/chromium/trie.h b/third_party/libaddressinput/chromium/trie.h
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..914897e9b53644ca3ca2a7a4a4ad0a7c27e239e5
 | 
| --- /dev/null
 | 
| +++ b/third_party/libaddressinput/chromium/trie.h
 | 
| @@ -0,0 +1,54 @@
 | 
| +// Copyright 2014 The Chromium Authors. All rights reserved.
 | 
| +// Use of this source code is governed by a BSD-style license that can be
 | 
| +// found in the LICENSE file.
 | 
| +
 | 
| +#ifndef THIRD_PARTY_LIBADDRESSINPUT_CHROMIUM_TRIE_H_
 | 
| +#define THIRD_PARTY_LIBADDRESSINPUT_CHROMIUM_TRIE_H_
 | 
| +
 | 
| +#include <stdint.h>
 | 
| +#include <map>
 | 
| +#include <set>
 | 
| +#include <vector>
 | 
| +
 | 
| +namespace autofill {
 | 
| +
 | 
| +// A prefix search tree. Can return all objects whose keys start with a prefix
 | 
| +// byte sequence.
 | 
| +//
 | 
| +// Maps keys to multiple objects. This property is useful when mapping region
 | 
| +// names to region objects. For example, there's a "St. Petersburg" in Florida,
 | 
| +// and there's a "St. Petersburg" in Russia. A lookup for "St. Petersburg" key
 | 
| +// should return two distinct objects.
 | 
| +template <typename T>
 | 
| +class Trie {
 | 
| + public:
 | 
| +  Trie();
 | 
| +  ~Trie();
 | 
| +
 | 
| +  // Returns true if no data was added in AddDataForKey().
 | 
| +  bool empty() const { return data_list_.empty() && sub_nodes_.empty(); }
 | 
| +
 | 
| +  // Adds a mapping from the 0 terminated |key| to |data_item|. Can be called
 | 
| +  // with the same |key| multiple times.
 | 
| +  void AddDataForKey(const std::vector<uint8_t>& key, const T& data_item);
 | 
| +
 | 
| +  // Adds all objects whose keys start with the 0 terminated |key_prefix| to the
 | 
| +  // |results| parameter. The |results| parameter should not be NULL.
 | 
| +  void FindDataForKeyPrefix(const std::vector<uint8_t>& key_prefix,
 | 
| +                            std::set<T>* results) const;
 | 
| +
 | 
| + private:
 | 
| +  // All objects for this node in the Trie. This field is a collection to enable
 | 
| +  // mapping the same key to multiple objects.
 | 
| +  std::set<T> data_list_;
 | 
| +
 | 
| +  // Trie sub nodes. The root Trie stores the objects for the empty key. The
 | 
| +  // children of the root Trie store the objects for the one-byte keys. The
 | 
| +  // grand-children of the root Trie store the objects for the two-byte keys,
 | 
| +  // and so on.
 | 
| +  std::map<uint8_t, Trie<T> > sub_nodes_;
 | 
| +};
 | 
| +
 | 
| +}  // namespace autofill
 | 
| +
 | 
| +#endif  // THIRD_PARTY_LIBADDRESSINPUT_CHROMIUM_TRIE_H_
 | 
| 
 |