]> git.lyx.org Git - lyx.git/blob - src/support/strfwd.h
ee4888abd44e0dd05557571b1db91226e11fed29
[lyx.git] / src / support / strfwd.h
1 // -*- C++ -*-
2
3 // Heavily inspired by /usr/include/c++/4.1/bits
4 //
5 // Copyright (C) 2001, 2002 Free Software Foundation, Inc.
6 //
7 // This file is part of the GNU ISO C++ Library.  This library is free
8 // software; you can redistribute it and/or modify it under the
9 // terms of the GNU General Public License as published by the
10 // Free Software Foundation; either version 2, or (at your option)
11 // any later version.
12
13 #ifndef STRFWD_H
14 #define STRFWD_H
15
16 #ifdef USE_WCHAR_T
17
18 // Prefer this if possible because GNU libstdc++ has usable
19 // std::ctype<wchar_t> locale facets but not
20 // std::ctype<boost::uint32_t>. gcc older than 3.4 is also missing
21 // usable std::char_traits<boost::uint32_t>.
22 namespace lyx { typedef wchar_t char_type; }
23
24 #else
25
26 #include <boost/cstdint.hpp>
27 namespace lyx { typedef boost::uint32_t char_type; }
28
29 #endif
30
31 // Forward definitions do not work with libc++
32 #ifdef USE_LLVM_LIBCPP
33 #include <string>
34 #else
35
36 namespace std {
37
38 template<typename Alloc> class allocator;
39
40 template<typename Char> struct char_traits;
41 template<> struct char_traits<char>;
42 #ifdef USE_WCHAR_T
43 template<> struct char_traits<wchar_t>;
44 #endif
45
46 template<typename Char, typename Traits, typename Alloc> class basic_string;
47 typedef basic_string<char, char_traits<char>, allocator<char> > string;
48
49 template<class Char, class Traits> class basic_istream;
50 template<class Char, class Traits> class basic_ostream;
51 template<class Char, class Traits, class Allocator> class basic_ostringstream;
52
53 typedef basic_istream<char, char_traits<char> > istream;
54 typedef basic_ostream<char, char_traits<char> > ostream;
55 typedef basic_ostringstream<char, char_traits<char>, allocator<char> > ostringstream;
56
57 } // namepace std
58
59 #endif
60
61 namespace lyx {
62
63 /**
64  * String type for storing the main text in UCS4 encoding.
65  * Use std::string only in cases 7-bit ASCII is to be manipulated
66  * within the variable.
67  */
68 typedef std::basic_string<char_type, std::char_traits<char_type>,
69         std::allocator<char_type> > docstring;
70
71 /// Base class for UCS4 input streams
72 typedef std::basic_istream<char_type, std::char_traits<char_type> > idocstream;
73
74 /// Base class for UCS4 output streams
75 typedef std::basic_ostream<char_type, std::char_traits<char_type> > odocstream;
76
77 /// UCS4 output stringstream
78 typedef std::basic_ostringstream<char_type, std::char_traits<char_type>, std::allocator<char_type> > odocstringstream;
79
80 #if ! defined(USE_WCHAR_T)
81 extern odocstream & operator<<(odocstream &, char);
82 #endif
83
84 // defined in lstrings.cpp
85 docstring const & empty_docstring();
86 std::string const & empty_string();
87 // defined in docstring.cpp
88 bool operator==(docstring const &, char const *);
89
90 #ifdef STD_STRING_USES_COW
91 template<typename Char> class trivial_string;
92 typedef trivial_string<char> trivstring;
93 typedef trivial_string<char_type> trivdocstring;
94 #else
95 typedef std::string trivstring;
96 typedef docstring trivdocstring;
97 #endif
98
99 } // namespace lyx
100
101 #endif