2006-08-13 22:54:59 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
/**
|
|
|
|
* \file docstring.h
|
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
|
|
|
*
|
2008-11-14 15:58:50 +00:00
|
|
|
* \author Lars Gullik Bjønnes
|
2006-09-01 15:41:38 +00:00
|
|
|
* \author Georg Baum
|
2006-08-13 22:54:59 +00:00
|
|
|
*
|
|
|
|
* Full author contact details are available in file CREDITS.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LYX_DOCSTRING_H
|
|
|
|
#define LYX_DOCSTRING_H
|
|
|
|
|
2007-10-31 22:40:34 +00:00
|
|
|
#include "support/strfwd.h"
|
2006-09-13 21:13:49 +00:00
|
|
|
|
2006-08-13 22:54:59 +00:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace lyx {
|
|
|
|
|
2007-11-01 22:17:22 +00:00
|
|
|
/// Creates a docstring from a C string of ASCII characters
|
|
|
|
docstring const from_ascii(char const *);
|
|
|
|
|
|
|
|
/// Creates a docstring from a std::string of ASCII characters
|
|
|
|
docstring const from_ascii(std::string const &);
|
|
|
|
|
|
|
|
/// Creates a std::string of ASCII characters from a docstring
|
|
|
|
std::string const to_ascii(docstring const &);
|
|
|
|
|
|
|
|
/// Creates a docstring from a UTF8 string. This should go eventually.
|
|
|
|
docstring const from_utf8(std::string const &);
|
|
|
|
|
|
|
|
/// Creates a UTF8 string from a docstring. This should go eventually.
|
|
|
|
std::string const to_utf8(docstring const &);
|
|
|
|
|
|
|
|
/// convert \p s from the encoding of the locale to ucs4.
|
|
|
|
docstring const from_local8bit(std::string const & s);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert \p s from ucs4 to the encoding of the locale.
|
|
|
|
* This may fail and throw an exception, the caller is expected to act
|
|
|
|
* appropriately.
|
|
|
|
*/
|
|
|
|
std::string const to_local8bit(docstring const & s);
|
|
|
|
|
|
|
|
/// convert \p s from the encoding of the file system to ucs4.
|
|
|
|
docstring const from_filesystem8bit(std::string const & s);
|
|
|
|
|
|
|
|
/// convert \p s from ucs4 to the encoding of the file system.
|
|
|
|
std::string const to_filesystem8bit(docstring const & s);
|
|
|
|
|
2010-02-10 10:24:10 +00:00
|
|
|
/// convert \p s from ucs4 to the \p encoding.
|
|
|
|
std::string const to_iconv_encoding(docstring const & s,
|
|
|
|
std::string const & encoding);
|
|
|
|
|
|
|
|
/// convert \p s from \p encoding to ucs4.
|
|
|
|
docstring const from_iconv_encoding(std::string const & s,
|
|
|
|
std::string const & encoding);
|
|
|
|
|
2007-11-01 22:17:22 +00:00
|
|
|
/// normalize \p s to precomposed form c
|
|
|
|
docstring const normalize_c(docstring const & s);
|
|
|
|
|
|
|
|
/// Compare a docstring with a C string of ASCII characters
|
|
|
|
bool operator==(docstring const &, char const *);
|
|
|
|
|
|
|
|
/// Compare a C string of ASCII characters with a docstring
|
|
|
|
inline bool operator==(char const * l, docstring const & r) { return r == l; }
|
|
|
|
|
|
|
|
/// Compare a docstring with a C string of ASCII characters
|
|
|
|
inline bool operator!=(docstring const & l, char const * r) { return !(l == r); }
|
|
|
|
|
|
|
|
/// Compare a C string of ASCII characters with a docstring
|
|
|
|
inline bool operator!=(char const * l, docstring const & r) { return !(r == l); }
|
|
|
|
|
|
|
|
/// Concatenate a docstring and a C string of ASCII characters
|
|
|
|
docstring operator+(docstring const &, char const *);
|
|
|
|
|
|
|
|
/// Concatenate a C string of ASCII characters and a docstring
|
|
|
|
docstring operator+(char const *, docstring const &);
|
|
|
|
|
|
|
|
/// Concatenate a docstring and a single ASCII character
|
|
|
|
docstring operator+(docstring const & l, char r);
|
|
|
|
|
|
|
|
/// Concatenate a single ASCII character and a docstring
|
|
|
|
docstring operator+(char l, docstring const & r);
|
|
|
|
|
|
|
|
/// Append a C string of ASCII characters to a docstring
|
|
|
|
docstring & operator+=(docstring &, char const *);
|
|
|
|
|
|
|
|
/// Append a single ASCII character to a docstring
|
|
|
|
docstring & operator+=(docstring & l, char r);
|
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
} // namespace lyx
|
|
|
|
|
2006-08-13 22:54:59 +00:00
|
|
|
#endif
|