~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/util/string.h

  • Committer: Brian Aker
  • Date: 2009-02-21 00:18:15 UTC
  • Revision ID: brian@tangent.org-20090221001815-x20e8h71e984lvs1
Completion (?) of uint conversion.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 * Copyright (C) 2010 Brian Aker
5
 
 * All rights reserved.
6
 
 *
7
 
 * Redistribution and use in source and binary forms, with or without
8
 
 * modification, are permitted provided that the following conditions are met:
9
 
 *
10
 
 *   * Redistributions of source code must retain the above copyright notice,
11
 
 *     this list of conditions and the following disclaimer.
12
 
 *   * Redistributions in binary form must reproduce the above copyright notice,
13
 
 *     this list of conditions and the following disclaimer in the documentation
14
 
 *     and/or other materials provided with the distribution.
15
 
 *   * Neither the name of Patrick Galbraith nor the names of its contributors
16
 
 *     may be used to endorse or promote products derived from this software
17
 
 *     without specific prior written permission.
18
 
 *
19
 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20
 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
 
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
 
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23
 
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24
 
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
 
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
 
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
 
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
 
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
29
 
 * THE POSSIBILITY OF SUCH DAMAGE.
30
 
 */
31
 
 
32
 
/*
33
 
  Some sections of this code came from the Boost examples.
34
 
*/
35
 
 
36
 
#ifndef DRIZZLED_UTIL_STRING_H
37
 
#define DRIZZLED_UTIL_STRING_H
38
 
 
39
 
#include <utility>
40
 
#include <string>
41
 
#include <vector>
42
 
 
43
 
#include <boost/algorithm/string/predicate.hpp>
44
 
#include <boost/functional/hash.hpp>
45
 
#include <boost/shared_ptr.hpp>
46
 
 
47
 
namespace drizzled
48
 
{
49
 
 
50
 
namespace util
51
 
{
52
 
 
53
 
 
54
 
namespace string {
55
 
typedef boost::shared_ptr<std::string> shared_ptr;
56
 
typedef boost::shared_ptr<const std::string> const_shared_ptr;
57
 
}
58
 
 
59
 
struct insensitive_equal_to : std::binary_function<std::string, std::string, bool>
60
 
{
61
 
  bool operator()(std::string const& x, std::string const& y) const
62
 
  {
63
 
    return boost::algorithm::iequals(x, y, std::locale());
64
 
  }
65
 
};
66
 
 
67
 
struct insensitive_hash : std::unary_function<std::string, std::size_t>
68
 
{
69
 
  std::size_t operator()(std::string const& x) const
70
 
  {
71
 
    std::size_t seed = 0;
72
 
    std::locale locale;
73
 
 
74
 
    for(std::string::const_iterator it = x.begin(); it != x.end(); ++it)
75
 
    {
76
 
      boost::hash_combine(seed, std::toupper(*it, locale));
77
 
    }
78
 
 
79
 
    return seed;
80
 
  }
81
 
};
82
 
 
83
 
struct sensitive_hash : std::unary_function< std::vector<char>, std::size_t>
84
 
{
85
 
  std::size_t operator()(std::vector<char> const& x) const
86
 
  {
87
 
    std::size_t seed = 0;
88
 
 
89
 
    for(std::vector<char>::const_iterator it = x.begin(); it != x.end(); ++it)
90
 
    {
91
 
      boost::hash_combine(seed, *it);
92
 
    }
93
 
 
94
 
    return seed;
95
 
  }
96
 
};
97
 
 
98
 
} /* namespace util */
99
 
} /* namespace drizzled */
100
 
 
101
 
#endif /* DRIZZLED_UTIL_STRING_H */