aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/ADT/StringSet.h
blob: 7bea577f34d33f411f592d15b8be050d119d4441 (plain)
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
41
42
43
44
45
//===--- StringSet.h - The LLVM Compiler Driver -----------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open
// Source License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
//  StringSet - A set-like wrapper for the StringMap.
//
//===----------------------------------------------------------------------===//

#ifndef LLVM_ADT_STRINGSET_H
#define LLVM_ADT_STRINGSET_H

#include "llvm/ADT/StringMap.h"

namespace llvm {

  /// StringSet - A wrapper for StringMap that provides set-like functionality.
  template <class AllocatorTy = llvm::MallocAllocator>
  class StringSet : public llvm::StringMap<char, AllocatorTy> {
    typedef llvm::StringMap<char, AllocatorTy> base;
  public:

    /// insert - Insert the specified key into the set.  If the key already
    /// exists in the set, return false and ignore the request, otherwise insert
    /// it and return true.
    bool insert(StringRef Key) {
      // Get or create the map entry for the key; if it doesn't exist the value
      // type will be default constructed which we use to detect insert.
      //
      // We use '+' as the sentinel value in the map.
      assert(!Key.empty());
      StringMapEntry<char> &Entry = this->GetOrCreateValue(Key);
      if (Entry.getValue() == '+')
        return false;
      Entry.setValue('+');
      return true;
    }
  };
}

#endif // LLVM_ADT_STRINGSET_H