YouCompleteMe/cpp/ycm/LetterNodeListMap.h
Strahinja Val Markovic c8a9d0590e boost::array instead of std::vector in nodelist
This should provide a minor performance boost & memory reduction.
2013-03-01 20:10:12 -08:00

57 lines
1.5 KiB
C++

// Copyright (C) 2011, 2012 Strahinja Val Markovic <val@markovic.io>
//
// This file is part of YouCompleteMe.
//
// YouCompleteMe is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// YouCompleteMe is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
#ifndef LETTERNODELISTMAP_H_BRK2UMC1
#define LETTERNODELISTMAP_H_BRK2UMC1
#include <list>
#include <boost/utility.hpp>
#include <boost/array.hpp>
#define NUM_LETTERS 128
namespace YouCompleteMe {
class LetterNode;
extern const int kNumLetters;
int IndexForChar( char letter );
bool IsUppercase( char letter );
class LetterNodeListMap : boost::noncopyable {
public:
LetterNodeListMap();
~LetterNodeListMap();
bool HasLetter( char letter );
std::list< LetterNode * > &operator[] ( char letter );
std::list< LetterNode * > *ListPointerAt( char letter );
bool HasLetter( char letter ) const;
private:
boost::array< std::list< LetterNode * >*, NUM_LETTERS > letters_;
};
} // namespace YouCompleteMe
#endif /* end of include guard: LETTERNODELISTMAP_H_BRK2UMC1 */