SmallString.h revision 3670a01d0be3bab1aa5856fea02a854aee2b65d6
1//===- llvm/ADT/SmallString.h - 'Normally small' strings --------*- C++ -*-===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// This file defines the SmallString class. 11// 12//===----------------------------------------------------------------------===// 13 14#ifndef LLVM_ADT_SMALLSTRING_H 15#define LLVM_ADT_SMALLSTRING_H 16 17#include "llvm/ADT/SmallVector.h" 18#include "llvm/ADT/StringRef.h" 19 20namespace llvm { 21 22/// SmallString - A SmallString is just a SmallVector with methods and accessors 23/// that make it work better as a string (e.g. operator+ etc). 24template<unsigned InternalLen> 25class SmallString : public SmallVector<char, InternalLen> { 26public: 27 // Default ctor - Initialize to empty. 28 SmallString() {} 29 30 // Initialize with a range. 31 template<typename ItTy> 32 SmallString(ItTy S, ItTy E) : SmallVector<char, InternalLen>(S, E) {} 33 34 // Copy ctor. 35 SmallString(const SmallString &RHS) : SmallVector<char, InternalLen>(RHS) {} 36 37 38 // Extra methods. 39 StringRef str() const { return StringRef(this->begin(), this->size()); } 40 41 const char *c_str() { 42 this->push_back(0); 43 this->pop_back(); 44 return this->data(); 45 } 46 47 // Extra operators. 48 const SmallString &operator=(StringRef RHS) { 49 this->clear(); 50 return *this += RHS; 51 } 52 53 SmallString &operator+=(StringRef RHS) { 54 this->append(RHS.begin(), RHS.end()); 55 return *this; 56 } 57 SmallString &operator+=(char C) { 58 this->push_back(C); 59 return *this; 60 } 61}; 62 63} 64 65#endif 66