2014-05-05 10:30:43 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
#ifndef nsNativeCharsetUtils_h__
|
|
|
|
#define nsNativeCharsetUtils_h__
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************************\
|
|
|
|
* *
|
|
|
|
* **** NOTICE **** *
|
|
|
|
* *
|
|
|
|
* *** THESE ARE NOT GENERAL PURPOSE CONVERTERS *** *
|
|
|
|
* *
|
|
|
|
* NS_CopyNativeToUnicode / NS_CopyUnicodeToNative should only be used *
|
|
|
|
* for converting *FILENAMES* between native and unicode. They are not *
|
|
|
|
* designed or tested for general encoding converter use. *
|
|
|
|
* *
|
|
|
|
\*****************************************************************************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* thread-safe conversion routines that do not depend on uconv libraries.
|
|
|
|
*/
|
2011-08-18 06:46:39 -07:00
|
|
|
nsresult NS_CopyNativeToUnicode(const nsACString &input, nsAString &output);
|
|
|
|
nsresult NS_CopyUnicodeToNative(const nsAString &input, nsACString &output);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2014-05-05 10:30:43 -07:00
|
|
|
/*
|
2007-03-22 10:30:00 -07:00
|
|
|
* This function indicates whether the character encoding used in the file
|
|
|
|
* system (more exactly what's used for |GetNativeFoo| and |SetNativeFoo|
|
2012-06-05 19:08:30 -07:00
|
|
|
* of |nsIFile|) is UTF-8 or not. Knowing that helps us avoid an
|
2007-03-22 10:30:00 -07:00
|
|
|
* unncessary encoding conversion in some cases. For instance, to get the leaf
|
2012-06-05 19:08:30 -07:00
|
|
|
* name in UTF-8 out of nsIFile, we can just use |GetNativeLeafName| rather
|
2014-05-05 10:30:43 -07:00
|
|
|
* than using |GetLeafName| and converting the result to UTF-8 if the file
|
2007-03-22 10:30:00 -07:00
|
|
|
* system encoding is UTF-8.
|
|
|
|
* On Unix (but not on Mac OS X), it depends on the locale and is not known
|
2014-05-05 10:30:43 -07:00
|
|
|
* in advance (at the compilation time) so that this function needs to be
|
|
|
|
* a real function. On Mac OS X it's always UTF-8 while on Windows
|
|
|
|
* and other platforms (e.g. OS2), it's never UTF-8.
|
2007-03-22 10:30:00 -07:00
|
|
|
*/
|
2010-06-01 12:02:42 -07:00
|
|
|
#if defined(XP_UNIX) && !defined(XP_MACOSX) && !defined(ANDROID)
|
2011-09-28 23:19:26 -07:00
|
|
|
bool NS_IsNativeUTF8();
|
2007-03-22 10:30:00 -07:00
|
|
|
#else
|
2011-09-28 23:19:26 -07:00
|
|
|
inline bool NS_IsNativeUTF8()
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
Bug 627277 - Remove (broken) BeOS support. r=biesi,dwitte,gavin,joe,jorendorff,josh,khuey,mfinkle,neil,Pike,roc,shaver,smontagu,taras
2011-02-19 11:10:24 -08:00
|
|
|
#if defined(XP_MACOSX) || defined(ANDROID)
|
2014-05-05 10:30:43 -07:00
|
|
|
return true;
|
2007-03-22 10:30:00 -07:00
|
|
|
#else
|
2014-05-05 10:30:43 -07:00
|
|
|
return false;
|
2007-03-22 10:30:00 -07:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* internal
|
|
|
|
*/
|
|
|
|
void NS_StartupNativeCharsetUtils();
|
|
|
|
void NS_ShutdownNativeCharsetUtils();
|
|
|
|
|
|
|
|
#endif // nsNativeCharsetUtils_h__
|