diff options
| author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2009-08-18 20:56:02 +0000 |
|---|---|---|
| committer | Lorry <lorry@roadtrain.codethink.co.uk> | 2012-09-25 16:59:08 +0000 |
| commit | 9f8a09ed743cedd9547bf0661d518647966ab114 (patch) | |
| tree | 9c7803d3b27a8ec22e91792ac7f7932efa128b20 /Examples/ocaml/std_string/example.h | |
| download | swig-tarball-master.tar.gz | |
Imported from /srv/lorry/lorry-area/swig-tarball/swig-1.3.40.tar.gz.HEADswig-1.3.40master
Diffstat (limited to 'Examples/ocaml/std_string/example.h')
| -rw-r--r-- | Examples/ocaml/std_string/example.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/Examples/ocaml/std_string/example.h b/Examples/ocaml/std_string/example.h new file mode 100644 index 0000000..60de984 --- /dev/null +++ b/Examples/ocaml/std_string/example.h @@ -0,0 +1,36 @@ +/* File : example.h -- stolen from the guile std_vector example */ + +#include <string> +#include <algorithm> +#include <functional> +#include <numeric> +#include <stdlib.h> +#include <locale.h> + +std::string from_wstring_with_locale( const std::wstring source, + const std::string locale ) { + const char *current_locale = setlocale( LC_CTYPE, locale.c_str() ); + int required_chars = wcstombs( NULL, source.c_str(), 0 ); + std::string s; + char *temp_chars = new char[required_chars + 1]; + temp_chars[0] = 0; + wcstombs( temp_chars, source.c_str(), required_chars + 1 ); + s = temp_chars; + delete [] temp_chars; + setlocale( LC_CTYPE, current_locale ); + return s; +} + +std::wstring to_wstring_with_locale( const std::string source, + const std::string locale ) { + const char *current_locale = setlocale( LC_CTYPE, locale.c_str() ); + int required_chars = mbstowcs( NULL, source.c_str(), 0 ); + std::wstring s; + wchar_t *temp_chars = new wchar_t[required_chars + 1]; + temp_chars[0] = 0; + mbstowcs( temp_chars, source.c_str(), required_chars + 1 ); + s = temp_chars; + delete [] temp_chars; + setlocale( LC_CTYPE, current_locale ); + return s; +} |
