mirror of
https://github.com/tesseract-ocr/tesseract.git
synced 2024-12-15 09:34:30 +08:00
8299e2a605
git-svn-id: https://tesseract-ocr.googlecode.com/svn/trunk@979 d0cd1f9f-072b-0410-8dd7-cf729c803f20
86 lines
2.4 KiB
C++
86 lines
2.4 KiB
C++
/**********************************************************************
|
|
* File: hashfn.h (Formerly hash.h)
|
|
* Description: Portability hacks for hash_map, hash_set and unique_ptr.
|
|
* Author: Ray Smith
|
|
* Created: Wed Jan 08 14:08:25 PST 2014
|
|
*
|
|
* (C) Copyright 2014, Google Inc.
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
** you may not use this file except in compliance with the License.
|
|
** You may obtain a copy of the License at
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
** See the License for the specific language governing permissions and
|
|
** limitations under the License.
|
|
*
|
|
**********************************************************************/
|
|
|
|
#ifndef HASHFN_H
|
|
#define HASHFN_H
|
|
|
|
#ifdef USE_STD_NAMESPACE
|
|
#if (__cplusplus >= 201103L) || defined(_MSC_VER) // Visual Studio
|
|
#include <unordered_map>
|
|
#include <unordered_set>
|
|
#define hash_map std::unordered_map
|
|
#if (_MSC_VER >= 1500 && _MSC_VER < 1600) // Visual Studio 2008
|
|
using namespace std::tr1;
|
|
#else // _MSC_VER
|
|
using std::unordered_map;
|
|
using std::unordered_set;
|
|
#include <memory>
|
|
#define SmartPtr std::unique_ptr
|
|
#define HAVE_UNIQUE_PTR
|
|
#endif // _MSC_VER
|
|
#elif (defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ > 0)) || \
|
|
__GNUC__ >= 4)) // gcc
|
|
// hash_set is deprecated in gcc
|
|
#include <ext/hash_map>
|
|
#include <ext/hash_set>
|
|
using __gnu_cxx::hash_map;
|
|
using __gnu_cxx::hash_set;
|
|
#define unordered_map hash_map
|
|
#define unordered_set hash_set
|
|
#else
|
|
#include <hash_map>
|
|
#include <hash_set>
|
|
#endif // gcc
|
|
#else // USE_STD_NAMESPACE
|
|
#include <hash_map>
|
|
#include <hash_set>
|
|
#define unordered_map hash_map
|
|
#define unordered_set hash_set
|
|
#endif // USE_STD_NAMESPACE
|
|
|
|
#ifndef HAVE_UNIQUE_PTR
|
|
// Trivial smart ptr. Expand to add features of std::unique_ptr as required.
|
|
template<class T> class SmartPtr {
|
|
public:
|
|
SmartPtr() : ptr_(NULL) {}
|
|
explicit SmartPtr(T* ptr) : ptr_(ptr) {}
|
|
~SmartPtr() {
|
|
delete ptr_;
|
|
}
|
|
|
|
T* get() const {
|
|
return ptr_;
|
|
}
|
|
void reset(T* ptr) {
|
|
if (ptr_ != NULL) delete ptr_;
|
|
ptr_ = ptr;
|
|
}
|
|
bool operator==(const T* ptr) const {
|
|
return ptr_ == ptr;
|
|
}
|
|
T* operator->() const {
|
|
return ptr_;
|
|
}
|
|
private:
|
|
T* ptr_;
|
|
};
|
|
#endif // HAVE_UNIQUE_PTR
|
|
|
|
#endif // HASHFN_H
|