| Index: gecko-sdk/include/nsStringAPI.h
|
| ===================================================================
|
| --- gecko-sdk/include/nsStringAPI.h (revision 0)
|
| +++ gecko-sdk/include/nsStringAPI.h (revision 0)
|
| @@ -0,0 +1,1737 @@
|
| +/* vim:set ts=2 sw=2 et cindent: */
|
| +/* ***** BEGIN LICENSE BLOCK *****
|
| + * Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
| + *
|
| + * The contents of this file are subject to the Mozilla Public License Version
|
| + * 1.1 (the "License"); you may not use this file except in compliance with
|
| + * the License. You may obtain a copy of the License at
|
| + * http://www.mozilla.org/MPL/
|
| + *
|
| + * Software distributed under the License is distributed on an "AS IS" basis,
|
| + * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
| + * for the specific language governing rights and limitations under the
|
| + * License.
|
| + *
|
| + * The Original Code is Mozilla.
|
| + *
|
| + * The Initial Developer of the Original Code is IBM Corporation.
|
| + * Portions created by IBM Corporation are Copyright (C) 2003
|
| + * IBM Corporation. All Rights Reserved.
|
| + *
|
| + * Contributor(s):
|
| + * Darin Fisher <darin@meer.net>
|
| + *
|
| + * Alternatively, the contents of this file may be used under the terms of
|
| + * either the GNU General Public License Version 2 or later (the "GPL"), or
|
| + * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
| + * in which case the provisions of the GPL or the LGPL are applicable instead
|
| + * of those above. If you wish to allow use of your version of this file only
|
| + * under the terms of either the GPL or the LGPL, and not to allow others to
|
| + * use your version of this file under the terms of the MPL, indicate your
|
| + * decision by deleting the provisions above and replace them with the notice
|
| + * and other provisions required by the GPL or the LGPL. If you do not delete
|
| + * the provisions above, a recipient may use your version of this file under
|
| + * the terms of any one of the MPL, the GPL or the LGPL.
|
| + *
|
| + * ***** END LICENSE BLOCK ***** */
|
| +
|
| +#ifndef nsStringAPI_h__
|
| +#define nsStringAPI_h__
|
| +
|
| +#include <string.h>
|
| +
|
| +/**
|
| + * nsStringAPI.h
|
| + *
|
| + * This file describes a minimal API for working with XPCOM's abstract
|
| + * string classes. It divorces the consumer from having any run-time
|
| + * dependency on the implementation details of the abstract string types.
|
| + */
|
| +
|
| +// Map frozen functions to private symbol names if not using strict API.
|
| +#ifdef MOZILLA_INTERNAL_API
|
| +# define NS_StringContainerInit NS_StringContainerInit_P
|
| +# define NS_StringContainerInit2 NS_StringContainerInit2_P
|
| +# define NS_StringContainerFinish NS_StringContainerFinish_P
|
| +# define NS_StringGetData NS_StringGetData_P
|
| +# define NS_StringGetMutableData NS_StringGetMutableData_P
|
| +# define NS_StringCloneData NS_StringCloneData_P
|
| +# define NS_StringSetData NS_StringSetData_P
|
| +# define NS_StringSetDataRange NS_StringSetDataRange_P
|
| +# define NS_StringCopy NS_StringCopy_P
|
| +# define NS_CStringContainerInit NS_CStringContainerInit_P
|
| +# define NS_CStringContainerInit2 NS_CStringContainerInit2_P
|
| +# define NS_CStringContainerFinish NS_CStringContainerFinish_P
|
| +# define NS_CStringGetData NS_CStringGetData_P
|
| +# define NS_CStringGetMutableData NS_CStringGetMutableData_P
|
| +# define NS_CStringCloneData NS_CStringCloneData_P
|
| +# define NS_CStringSetData NS_CStringSetData_P
|
| +# define NS_CStringSetDataRange NS_CStringSetDataRange_P
|
| +# define NS_CStringCopy NS_CStringCopy_P
|
| +# define NS_CStringToUTF16 NS_CStringToUTF16_P
|
| +# define NS_UTF16ToCString NS_UTF16ToCString_P
|
| +#endif
|
| +
|
| +#include "nscore.h"
|
| +
|
| +#if defined( XPCOM_GLUE )
|
| +#define NS_STRINGAPI(type) extern "C" NS_HIDDEN_(type)
|
| +#elif defined( _IMPL_NS_STRINGAPI )
|
| +#define NS_STRINGAPI(type) extern "C" NS_EXPORT type
|
| +#else
|
| +#define NS_STRINGAPI(type) extern "C" NS_IMPORT type
|
| +#endif
|
| +
|
| +/* The base string types */
|
| +class nsAString;
|
| +class nsACString;
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * nsStringContainer
|
| + *
|
| + * This is an opaque data type that is large enough to hold the canonical
|
| + * implementation of nsAString. The binary structure of this class is an
|
| + * implementation detail.
|
| + *
|
| + * The string data stored in a string container is always single fragment
|
| + * and may be null-terminated depending on how it is initialized.
|
| + *
|
| + * Typically, string containers are allocated on the stack for temporary
|
| + * use. However, they can also be malloc'd if necessary. In either case,
|
| + * a string container is not useful until it has been initialized with a
|
| + * call to NS_StringContainerInit. The following example shows how to use
|
| + * a string container to call a function that takes a |nsAString &| out-param.
|
| + *
|
| + * NS_METHOD GetBlah(nsAString &aBlah);
|
| + *
|
| + * nsresult MyCode()
|
| + * {
|
| + * nsresult rv;
|
| + *
|
| + * nsStringContainer sc;
|
| + * rv = NS_StringContainerInit(sc);
|
| + * if (NS_FAILED(rv))
|
| + * return rv;
|
| + *
|
| + * rv = GetBlah(sc);
|
| + * if (NS_SUCCEEDED(rv))
|
| + * {
|
| + * const PRUnichar *data;
|
| + * NS_StringGetData(sc, &data);
|
| + * //
|
| + * // |data| now points to the result of the GetBlah function
|
| + * //
|
| + * }
|
| + *
|
| + * NS_StringContainerFinish(sc);
|
| + * return rv;
|
| + * }
|
| + *
|
| + * The following example show how to use a string container to pass a string
|
| + * parameter to a function taking a |const nsAString &| in-param.
|
| + *
|
| + * NS_METHOD SetBlah(const nsAString &aBlah);
|
| + *
|
| + * nsresult MyCode()
|
| + * {
|
| + * nsresult rv;
|
| + *
|
| + * nsStringContainer sc;
|
| + * rv = NS_StringContainerInit(sc);
|
| + * if (NS_FAILED(rv))
|
| + * return rv;
|
| + *
|
| + * const PRUnichar kData[] = {'x','y','z','\0'};
|
| + * rv = NS_StringSetData(sc, kData, sizeof(kData)/2 - 1);
|
| + * if (NS_SUCCEEDED(rv))
|
| + * rv = SetBlah(sc);
|
| + *
|
| + * NS_StringContainerFinish(sc);
|
| + * return rv;
|
| + * }
|
| + */
|
| +class nsStringContainer;
|
| +
|
| +/**
|
| + * Flags that may be OR'd together to pass to NS_StringContainerInit2:
|
| + */
|
| +enum {
|
| + /* Data passed into NS_StringContainerInit2 is not copied; instead, the
|
| + * string references the passed in data pointer directly. The caller must
|
| + * ensure that the data is valid for the lifetime of the string container.
|
| + * This flag should not be combined with NS_STRING_CONTAINER_INIT_ADOPT. */
|
| + NS_STRING_CONTAINER_INIT_DEPEND = (1 << 1),
|
| +
|
| + /* Data passed into NS_StringContainerInit2 is not copied; instead, the
|
| + * string takes ownership over the data pointer. The caller must have
|
| + * allocated the data array using the XPCOM memory allocator (nsMemory).
|
| + * This flag should not be combined with NS_STRING_CONTAINER_INIT_DEPEND. */
|
| + NS_STRING_CONTAINER_INIT_ADOPT = (1 << 2),
|
| +
|
| + /* Data passed into NS_StringContainerInit2 is a substring that is not
|
| + * null-terminated. */
|
| + NS_STRING_CONTAINER_INIT_SUBSTRING = (1 << 3)
|
| +};
|
| +
|
| +/**
|
| + * NS_StringContainerInit
|
| + *
|
| + * @param aContainer string container reference
|
| + * @return NS_OK if string container successfully initialized
|
| + *
|
| + * This function may allocate additional memory for aContainer. When
|
| + * aContainer is no longer needed, NS_StringContainerFinish should be called.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_StringContainerInit(nsStringContainer &aContainer);
|
| +
|
| +/**
|
| + * NS_StringContainerInit2
|
| + *
|
| + * @param aContainer string container reference
|
| + * @param aData character buffer (may be null)
|
| + * @param aDataLength number of characters stored at aData (may pass
|
| + * PR_UINT32_MAX if aData is null-terminated)
|
| + * @param aFlags flags affecting how the string container is
|
| + * initialized. this parameter is ignored when aData
|
| + * is null. otherwise, if this parameter is 0, then
|
| + * aData is copied into the string.
|
| + *
|
| + * This function resembles NS_StringContainerInit but provides further
|
| + * options that permit more efficient memory usage. When aContainer is
|
| + * no longer needed, NS_StringContainerFinish should be called.
|
| + *
|
| + * NOTE: NS_StringContainerInit2(container, nsnull, 0, 0) is equivalent to
|
| + * NS_StringContainerInit(container).
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_StringContainerInit2
|
| + (nsStringContainer &aContainer, const PRUnichar *aData = nsnull,
|
| + PRUint32 aDataLength = PR_UINT32_MAX, PRUint32 aFlags = 0);
|
| +
|
| +/**
|
| + * NS_StringContainerFinish
|
| + *
|
| + * @param aContainer string container reference
|
| + *
|
| + * This function frees any memory owned by aContainer.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(void)
|
| +NS_StringContainerFinish(nsStringContainer &aContainer);
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * NS_StringGetData
|
| + *
|
| + * This function returns a const character pointer to the string's internal
|
| + * buffer, the length of the string, and a boolean value indicating whether
|
| + * or not the buffer is null-terminated.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aData out param that will hold the address of aStr's
|
| + * internal buffer
|
| + * @param aTerminated if non-null, this out param will be set to indicate
|
| + * whether or not aStr's internal buffer is null-
|
| + * terminated
|
| + * @return length of aStr's internal buffer
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(PRUint32)
|
| +NS_StringGetData
|
| + (const nsAString &aStr, const PRUnichar **aData,
|
| + PRBool *aTerminated = nsnull);
|
| +
|
| +/**
|
| + * NS_StringGetMutableData
|
| + *
|
| + * This function provides mutable access to a string's internal buffer. It
|
| + * returns a pointer to an array of characters that may be modified. The
|
| + * returned pointer remains valid until the string object is passed to some
|
| + * other string function.
|
| + *
|
| + * Optionally, this function may be used to resize the string's internal
|
| + * buffer. The aDataLength parameter specifies the requested length of the
|
| + * string's internal buffer. By passing some value other than PR_UINT32_MAX,
|
| + * the caller can request that the buffer be resized to the specified number of
|
| + * characters before returning. The caller is not responsible for writing a
|
| + * null-terminator.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aDataLength number of characters to resize the string's internal
|
| + * buffer to or PR_UINT32_MAX if no resizing is needed
|
| + * @param aData out param that upon return holds the address of aStr's
|
| + * internal buffer or null if the function failed
|
| + * @return number of characters or zero if the function failed
|
| + *
|
| + * This function does not necessarily null-terminate aStr after resizing its
|
| + * internal buffer. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(PRUint32)
|
| +NS_StringGetMutableData
|
| + (nsAString &aStr, PRUint32 aDataLength, PRUnichar **aData);
|
| +
|
| +/**
|
| + * NS_StringCloneData
|
| + *
|
| + * This function returns a null-terminated copy of the string's
|
| + * internal buffer.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @return null-terminated copy of the string's internal buffer
|
| + * (it must be free'd using using nsMemory::Free)
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(PRUnichar *)
|
| +NS_StringCloneData
|
| + (const nsAString &aStr);
|
| +
|
| +/**
|
| + * NS_StringSetData
|
| + *
|
| + * This function copies aData into aStr.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to copy from source string (pass
|
| + * PR_UINT32_MAX to copy until end of aData, designated by
|
| + * a null character)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr after copying data
|
| + * from aData. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_StringSetData
|
| + (nsAString &aStr, const PRUnichar *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX);
|
| +
|
| +/**
|
| + * NS_StringSetDataRange
|
| + *
|
| + * This function copies aData into a section of aStr. As a result it can be
|
| + * used to insert new characters into the string.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aCutOffset starting index where the string's existing data
|
| + * is to be overwritten (pass PR_UINT32_MAX to cause
|
| + * aData to be appended to the end of aStr, in which
|
| + * case the value of aCutLength is ignored).
|
| + * @param aCutLength number of characters to overwrite starting at
|
| + * aCutOffset (pass PR_UINT32_MAX to overwrite until the
|
| + * end of aStr).
|
| + * @param aData character buffer (pass null to cause this function
|
| + * to simply remove the "cut" range)
|
| + * @param aDataLength number of characters to copy from source string (pass
|
| + * PR_UINT32_MAX to copy until end of aData, designated by
|
| + * a null character)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr after copying data
|
| + * from aData. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_StringSetDataRange
|
| + (nsAString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength,
|
| + const PRUnichar *aData, PRUint32 aDataLength = PR_UINT32_MAX);
|
| +
|
| +/**
|
| + * NS_StringCopy
|
| + *
|
| + * This function makes aDestStr have the same value as aSrcStr. It is
|
| + * provided as an optimization.
|
| + *
|
| + * @param aDestStr abstract string reference to be modified
|
| + * @param aSrcStr abstract string reference containing source string
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aDestStr after copying
|
| + * data from aSrcStr. The behavior depends on the implementation of the
|
| + * abstract string, aDestStr. If aDestStr is a reference to a
|
| + * nsStringContainer, then its data will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_StringCopy
|
| + (nsAString &aDestStr, const nsAString &aSrcStr);
|
| +
|
| +/**
|
| + * NS_StringAppendData
|
| + *
|
| + * This function appends data to the existing value of aStr.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to append (pass PR_UINT32_MAX to
|
| + * append until a null-character is encountered)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr upon completion.
|
| + * The behavior depends on the implementation of the abstract string, aStr.
|
| + * If aStr is a reference to a nsStringContainer, then its data will be null-
|
| + * terminated by this function.
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_StringAppendData(nsAString &aStr, const PRUnichar *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX)
|
| +{
|
| + return NS_StringSetDataRange(aStr, PR_UINT32_MAX, 0, aData, aDataLength);
|
| +}
|
| +
|
| +/**
|
| + * NS_StringInsertData
|
| + *
|
| + * This function inserts data into the existing value of aStr at the specified
|
| + * offset.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aOffset specifies where in the string to insert aData
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to append (pass PR_UINT32_MAX to
|
| + * append until a null-character is encountered)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr upon completion.
|
| + * The behavior depends on the implementation of the abstract string, aStr.
|
| + * If aStr is a reference to a nsStringContainer, then its data will be null-
|
| + * terminated by this function.
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_StringInsertData(nsAString &aStr, PRUint32 aOffset, const PRUnichar *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX)
|
| +{
|
| + return NS_StringSetDataRange(aStr, aOffset, 0, aData, aDataLength);
|
| +}
|
| +
|
| +/**
|
| + * NS_StringCutData
|
| + *
|
| + * This function shortens the existing value of aStr, by removing characters
|
| + * at the specified offset.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aCutOffset specifies where in the string to insert aData
|
| + * @param aCutLength number of characters to remove
|
| + * @return NS_OK if function succeeded
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_StringCutData(nsAString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength)
|
| +{
|
| + return NS_StringSetDataRange(aStr, aCutOffset, aCutLength, nsnull, 0);
|
| +}
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * nsCStringContainer
|
| + *
|
| + * This is an opaque data type that is large enough to hold the canonical
|
| + * implementation of nsACString. The binary structure of this class is an
|
| + * implementation detail.
|
| + *
|
| + * The string data stored in a string container is always single fragment
|
| + * and may be null-terminated depending on how it is initialized.
|
| + *
|
| + * @see nsStringContainer for use cases and further documentation.
|
| + */
|
| +class nsCStringContainer;
|
| +
|
| +/**
|
| + * Flags that may be OR'd together to pass to NS_StringContainerInit2:
|
| + */
|
| +enum {
|
| + /* Data passed into NS_CStringContainerInit2 is not copied; instead, the
|
| + * string references the passed in data pointer directly. The caller must
|
| + * ensure that the data is valid for the lifetime of the string container.
|
| + * This flag should not be combined with NS_CSTRING_CONTAINER_INIT_ADOPT. */
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND = (1 << 1),
|
| +
|
| + /* Data passed into NS_CStringContainerInit2 is not copied; instead, the
|
| + * string takes ownership over the data pointer. The caller must have
|
| + * allocated the data array using the XPCOM memory allocator (nsMemory).
|
| + * This flag should not be combined with NS_CSTRING_CONTAINER_INIT_DEPEND. */
|
| + NS_CSTRING_CONTAINER_INIT_ADOPT = (1 << 2),
|
| +
|
| + /* Data passed into NS_CStringContainerInit2 is a substring that is not
|
| + * null-terminated. */
|
| + NS_CSTRING_CONTAINER_INIT_SUBSTRING = (1 << 3)
|
| +};
|
| +
|
| +/**
|
| + * NS_CStringContainerInit
|
| + *
|
| + * @param aContainer string container reference
|
| + * @return NS_OK if string container successfully initialized
|
| + *
|
| + * This function may allocate additional memory for aContainer. When
|
| + * aContainer is no longer needed, NS_CStringContainerFinish should be called.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringContainerInit(nsCStringContainer &aContainer);
|
| +
|
| +/**
|
| + * NS_CStringContainerInit2
|
| + *
|
| + * @param aContainer string container reference
|
| + * @param aData character buffer (may be null)
|
| + * @param aDataLength number of characters stored at aData (may pass
|
| + * PR_UINT32_MAX if aData is null-terminated)
|
| + * @param aFlags flags affecting how the string container is
|
| + * initialized. this parameter is ignored when aData
|
| + * is null. otherwise, if this parameter is 0, then
|
| + * aData is copied into the string.
|
| + *
|
| + * This function resembles NS_CStringContainerInit but provides further
|
| + * options that permit more efficient memory usage. When aContainer is
|
| + * no longer needed, NS_CStringContainerFinish should be called.
|
| + *
|
| + * NOTE: NS_CStringContainerInit2(container, nsnull, 0, 0) is equivalent to
|
| + * NS_CStringContainerInit(container).
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringContainerInit2
|
| + (nsCStringContainer &aContainer, const char *aData = nsnull,
|
| + PRUint32 aDataLength = PR_UINT32_MAX, PRUint32 aFlags = 0);
|
| +
|
| +/**
|
| + * NS_CStringContainerFinish
|
| + *
|
| + * @param aContainer string container reference
|
| + *
|
| + * This function frees any memory owned by aContainer.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(void)
|
| +NS_CStringContainerFinish(nsCStringContainer &aContainer);
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * NS_CStringGetData
|
| + *
|
| + * This function returns a const character pointer to the string's internal
|
| + * buffer, the length of the string, and a boolean value indicating whether
|
| + * or not the buffer is null-terminated.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aData out param that will hold the address of aStr's
|
| + * internal buffer
|
| + * @param aTerminated if non-null, this out param will be set to indicate
|
| + * whether or not aStr's internal buffer is null-
|
| + * terminated
|
| + * @return length of aStr's internal buffer
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(PRUint32)
|
| +NS_CStringGetData
|
| + (const nsACString &aStr, const char **aData,
|
| + PRBool *aTerminated = nsnull);
|
| +
|
| +/**
|
| + * NS_CStringGetMutableData
|
| + *
|
| + * This function provides mutable access to a string's internal buffer. It
|
| + * returns a pointer to an array of characters that may be modified. The
|
| + * returned pointer remains valid until the string object is passed to some
|
| + * other string function.
|
| + *
|
| + * Optionally, this function may be used to resize the string's internal
|
| + * buffer. The aDataLength parameter specifies the requested length of the
|
| + * string's internal buffer. By passing some value other than PR_UINT32_MAX,
|
| + * the caller can request that the buffer be resized to the specified number of
|
| + * characters before returning. The caller is not responsible for writing a
|
| + * null-terminator.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aDataLength number of characters to resize the string's internal
|
| + * buffer to or PR_UINT32_MAX if no resizing is needed
|
| + * @param aData out param that upon return holds the address of aStr's
|
| + * internal buffer or null if the function failed
|
| + * @return number of characters or zero if the function failed
|
| + *
|
| + * This function does not necessarily null-terminate aStr after resizing its
|
| + * internal buffer. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(PRUint32)
|
| +NS_CStringGetMutableData
|
| + (nsACString &aStr, PRUint32 aDataLength, char **aData);
|
| +
|
| +/**
|
| + * NS_CStringCloneData
|
| + *
|
| + * This function returns a null-terminated copy of the string's
|
| + * internal buffer.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @return null-terminated copy of the string's internal buffer
|
| + * (it must be free'd using using nsMemory::Free)
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(char *)
|
| +NS_CStringCloneData
|
| + (const nsACString &aStr);
|
| +
|
| +/**
|
| + * NS_CStringSetData
|
| + *
|
| + * This function copies aData into aStr.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to copy from source string (pass
|
| + * PR_UINT32_MAX to copy until end of aData, designated by
|
| + * a null character)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr after copying data
|
| + * from aData. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringSetData
|
| + (nsACString &aStr, const char *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX);
|
| +
|
| +/**
|
| + * NS_CStringSetDataRange
|
| + *
|
| + * This function copies aData into a section of aStr. As a result it can be
|
| + * used to insert new characters into the string.
|
| + *
|
| + * @param aStr abstract string reference
|
| + * @param aCutOffset starting index where the string's existing data
|
| + * is to be overwritten (pass PR_UINT32_MAX to cause
|
| + * aData to be appended to the end of aStr, in which
|
| + * case the value of aCutLength is ignored).
|
| + * @param aCutLength number of characters to overwrite starting at
|
| + * aCutOffset (pass PR_UINT32_MAX to overwrite until the
|
| + * end of aStr).
|
| + * @param aData character buffer (pass null to cause this function
|
| + * to simply remove the "cut" range)
|
| + * @param aDataLength number of characters to copy from source string (pass
|
| + * PR_UINT32_MAX to copy until end of aData, designated by
|
| + * a null character)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr after copying data
|
| + * from aData. The behavior depends on the implementation of the abstract
|
| + * string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
| + * will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringSetDataRange
|
| + (nsACString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength,
|
| + const char *aData, PRUint32 aDataLength = PR_UINT32_MAX);
|
| +
|
| +/**
|
| + * NS_CStringCopy
|
| + *
|
| + * This function makes aDestStr have the same value as aSrcStr. It is
|
| + * provided as an optimization.
|
| + *
|
| + * @param aDestStr abstract string reference to be modified
|
| + * @param aSrcStr abstract string reference containing source string
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aDestStr after copying
|
| + * data from aSrcStr. The behavior depends on the implementation of the
|
| + * abstract string, aDestStr. If aDestStr is a reference to a
|
| + * nsStringContainer, then its data will be null-terminated by this function.
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringCopy
|
| + (nsACString &aDestStr, const nsACString &aSrcStr);
|
| +
|
| +/**
|
| + * NS_CStringAppendData
|
| + *
|
| + * This function appends data to the existing value of aStr.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to append (pass PR_UINT32_MAX to
|
| + * append until a null-character is encountered)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr upon completion.
|
| + * The behavior depends on the implementation of the abstract string, aStr.
|
| + * If aStr is a reference to a nsStringContainer, then its data will be null-
|
| + * terminated by this function.
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_CStringAppendData(nsACString &aStr, const char *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX)
|
| +{
|
| + return NS_CStringSetDataRange(aStr, PR_UINT32_MAX, 0, aData, aDataLength);
|
| +}
|
| +
|
| +/**
|
| + * NS_CStringInsertData
|
| + *
|
| + * This function inserts data into the existing value of aStr at the specified
|
| + * offset.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aOffset specifies where in the string to insert aData
|
| + * @param aData character buffer
|
| + * @param aDataLength number of characters to append (pass PR_UINT32_MAX to
|
| + * append until a null-character is encountered)
|
| + * @return NS_OK if function succeeded
|
| + *
|
| + * This function does not necessarily null-terminate aStr upon completion.
|
| + * The behavior depends on the implementation of the abstract string, aStr.
|
| + * If aStr is a reference to a nsStringContainer, then its data will be null-
|
| + * terminated by this function.
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_CStringInsertData(nsACString &aStr, PRUint32 aOffset, const char *aData,
|
| + PRUint32 aDataLength = PR_UINT32_MAX)
|
| +{
|
| + return NS_CStringSetDataRange(aStr, aOffset, 0, aData, aDataLength);
|
| +}
|
| +
|
| +/**
|
| + * NS_CStringCutData
|
| + *
|
| + * This function shortens the existing value of aStr, by removing characters
|
| + * at the specified offset.
|
| + *
|
| + * @param aStr abstract string reference to be modified
|
| + * @param aCutOffset specifies where in the string to insert aData
|
| + * @param aCutLength number of characters to remove
|
| + * @return NS_OK if function succeeded
|
| + */
|
| +inline NS_HIDDEN_(nsresult)
|
| +NS_CStringCutData(nsACString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength)
|
| +{
|
| + return NS_CStringSetDataRange(aStr, aCutOffset, aCutLength, nsnull, 0);
|
| +}
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * Encodings that can be used with the following conversion routines.
|
| + */
|
| +enum nsCStringEncoding {
|
| + /* Conversion between ASCII and UTF-16 assumes that all bytes in the source
|
| + * string are 7-bit ASCII and can be inflated to UTF-16 by inserting null
|
| + * bytes. Reverse conversion is done by truncating every other byte. The
|
| + * conversion may result in loss and/or corruption of information if the
|
| + * strings do not strictly contain ASCII data. */
|
| + NS_CSTRING_ENCODING_ASCII = 0,
|
| +
|
| + /* Conversion between UTF-8 and UTF-16 is non-lossy. */
|
| + NS_CSTRING_ENCODING_UTF8 = 1,
|
| +
|
| + /* Conversion from UTF-16 to the native filesystem charset may result in a
|
| + * loss of information. No attempt is made to protect against data loss in
|
| + * this case. The native filesystem charset applies to strings passed to
|
| + * the "Native" method variants on nsIFile and nsILocalFile. */
|
| + NS_CSTRING_ENCODING_NATIVE_FILESYSTEM = 2
|
| +};
|
| +
|
| +/**
|
| + * NS_CStringToUTF16
|
| + *
|
| + * This function converts the characters in a nsACString to an array of UTF-16
|
| + * characters, in the platform endianness. The result is stored in a nsAString
|
| + * object.
|
| + *
|
| + * @param aSource abstract string reference containing source string
|
| + * @param aSrcEncoding character encoding of the source string
|
| + * @param aDest abstract string reference to hold the result
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_CStringToUTF16(const nsACString &aSource, nsCStringEncoding aSrcEncoding,
|
| + nsAString &aDest);
|
| +
|
| +/**
|
| + * NS_UTF16ToCString
|
| + *
|
| + * This function converts the UTF-16 characters in a nsAString to a single-byte
|
| + * encoding. The result is stored in a nsACString object. In some cases this
|
| + * conversion may be lossy. In such cases, the conversion may succeed with a
|
| + * return code indicating loss of information. The exact behavior is not
|
| + * specified at this time.
|
| + *
|
| + * @param aSource abstract string reference containing source string
|
| + * @param aDestEncoding character encoding of the resulting string
|
| + * @param aDest abstract string reference to hold the result
|
| + *
|
| + * @status FROZEN
|
| + */
|
| +NS_STRINGAPI(nsresult)
|
| +NS_UTF16ToCString(const nsAString &aSource, nsCStringEncoding aDestEncoding,
|
| + nsACString &aDest);
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * Below we define nsAString and nsACString. The "_external" suffix is an
|
| + * implementation detail. nsAString_external is the name of the external
|
| + * representation of nsAString from the point of view of the Mozilla codebase.
|
| + * To a user of this API, nsAString_external is exactly nsAString.
|
| + *
|
| + * These classes should be treated as abstract classes with unspecified
|
| + * structure. The inline methods are provided as helper functions around the
|
| + * C-style API provided above.
|
| + *
|
| + * Do not try to mix these definitions of nsAString and nsACString with the
|
| + * internal definition of these classes from nsAString.h in the Mozilla tree.
|
| + */
|
| +
|
| +#ifndef MOZILLA_INTERNAL_API
|
| +#define nsAString_external nsAString
|
| +#define nsACString_external nsACString
|
| +#endif
|
| +
|
| +class nsAString_external
|
| +{
|
| +#ifndef MOZILLA_INTERNAL_API
|
| +
|
| +public:
|
| + typedef PRUnichar char_type;
|
| + typedef nsAString_external self_type;
|
| + typedef PRUint32 size_type;
|
| + typedef PRUint32 index_type;
|
| +
|
| + NS_HIDDEN_(const char_type*) BeginReading() const
|
| + {
|
| + const char_type *data;
|
| + NS_StringGetData(*this, &data);
|
| + return data;
|
| + }
|
| +
|
| + NS_HIDDEN_(const char_type*) EndReading() const
|
| + {
|
| + const char_type *data;
|
| + PRUint32 len = NS_StringGetData(*this, &data);
|
| + return data + len;
|
| + }
|
| +
|
| + NS_HIDDEN_(char_type*) BeginWriting()
|
| + {
|
| + char_type *data;
|
| + NS_StringGetMutableData(*this, PR_UINT32_MAX, &data);
|
| + return data;
|
| + }
|
| +
|
| + NS_HIDDEN_(PRBool) SetLength(PRUint32 aLen)
|
| + {
|
| + char_type *data;
|
| + NS_StringGetMutableData(*this, aLen, &data);
|
| + return data != nsnull;
|
| + }
|
| +
|
| + NS_HIDDEN_(size_type) Length() const
|
| + {
|
| + const char_type* data;
|
| + return NS_StringGetData(*this, &data);
|
| + }
|
| +
|
| + NS_HIDDEN_(PRBool) IsEmpty() const
|
| + {
|
| + return Length() == 0;
|
| + }
|
| +
|
| + NS_HIDDEN_(void) Assign(const self_type& aString)
|
| + {
|
| + NS_StringCopy(*this, aString);
|
| + }
|
| + NS_HIDDEN_(void) Assign(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_StringSetData(*this, aData, aLength);
|
| + }
|
| + NS_HIDDEN_(void) Assign(char_type aChar)
|
| + {
|
| + NS_StringSetData(*this, &aChar, 1);
|
| + }
|
| +
|
| + NS_HIDDEN_(self_type&) operator=(const self_type& aString) { Assign(aString); return *this; }
|
| + NS_HIDDEN_(self_type&) operator=(const char_type* aPtr) { Assign(aPtr); return *this; }
|
| + NS_HIDDEN_(self_type&) operator=(char_type aChar) { Assign(aChar); return *this; }
|
| +
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const char_type* data, size_type length = size_type(-1) )
|
| + {
|
| + NS_StringSetDataRange(*this, cutStart, cutLength, data, length);
|
| + }
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, char_type c )
|
| + {
|
| + Replace(cutStart, cutLength, &c, 1);
|
| + }
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const self_type& readable )
|
| + {
|
| + const char_type* data;
|
| + PRUint32 dataLen = NS_StringGetData(readable, &data);
|
| + NS_StringSetDataRange(*this, cutStart, cutLength, data, dataLen);
|
| + }
|
| +
|
| + NS_HIDDEN_(void) Append( char_type c ) { Replace(size_type(-1), 0, c); }
|
| + NS_HIDDEN_(void) Append( const char_type* data, size_type length = size_type(-1) ) { Replace(size_type(-1), 0, data, length); }
|
| + NS_HIDDEN_(void) Append( const self_type& readable ) { Replace(size_type(-1), 0, readable); }
|
| +
|
| + NS_HIDDEN_(self_type&) operator+=( char_type c ) { Append(c); return *this; }
|
| + NS_HIDDEN_(self_type&) operator+=( const char_type* data ) { Append(data); return *this; }
|
| + NS_HIDDEN_(self_type&) operator+=( const self_type& readable ) { Append(readable); return *this; }
|
| +
|
| + NS_HIDDEN_(void) Insert( char_type c, index_type pos ) { Replace(pos, 0, c); }
|
| + NS_HIDDEN_(void) Insert( const char_type* data, index_type pos, size_type length = size_type(-1) ) { Replace(pos, 0, data, length); }
|
| + NS_HIDDEN_(void) Insert( const self_type& readable, index_type pos ) { Replace(pos, 0, readable); }
|
| +
|
| + NS_HIDDEN_(void) Cut( index_type cutStart, size_type cutLength ) { Replace(cutStart, cutLength, nsnull, 0); }
|
| +
|
| + NS_HIDDEN_(PRBool) Equals( const self_type &other ) const {
|
| + const char_type *cself;
|
| + const char_type *cother;
|
| + PRUint32 selflen = NS_StringGetData(*this, &cself);
|
| + PRUint32 otherlen = NS_StringGetData(other, &cother);
|
| +
|
| + if (selflen != otherlen)
|
| + return PR_FALSE;
|
| +
|
| + return memcmp(cself, cother, selflen * sizeof(char_type)) == 0;
|
| + }
|
| +
|
| +#endif // MOZILLA_INTERNAL_API
|
| +
|
| +protected:
|
| + // Prevent people from allocating a nsAString directly.
|
| + ~nsAString_external() {}
|
| +
|
| +private:
|
| + void *v;
|
| +};
|
| +
|
| +class nsACString_external
|
| +{
|
| +#ifndef MOZILLA_INTERNAL_API
|
| +
|
| +public:
|
| + typedef char char_type;
|
| + typedef nsACString_external self_type;
|
| + typedef PRUint32 size_type;
|
| + typedef PRUint32 index_type;
|
| +
|
| + NS_HIDDEN_(const char_type*) BeginReading() const
|
| + {
|
| + const char_type *data;
|
| + NS_CStringGetData(*this, &data);
|
| + return data;
|
| + }
|
| +
|
| + NS_HIDDEN_(const char_type*) EndReading() const
|
| + {
|
| + const char_type *data;
|
| + PRUint32 len = NS_CStringGetData(*this, &data);
|
| + return data + len;
|
| + }
|
| +
|
| + NS_HIDDEN_(char_type*) BeginWriting()
|
| + {
|
| + char_type *data;
|
| + NS_CStringGetMutableData(*this, PR_UINT32_MAX, &data);
|
| + return data;
|
| + }
|
| +
|
| + NS_HIDDEN_(PRBool) SetLength(PRUint32 aLen)
|
| + {
|
| + char_type *data;
|
| + NS_CStringGetMutableData(*this, aLen, &data);
|
| + return data != nsnull;
|
| + }
|
| +
|
| + NS_HIDDEN_(size_type) Length() const
|
| + {
|
| + const char_type* data;
|
| + return NS_CStringGetData(*this, &data);
|
| + }
|
| +
|
| + NS_HIDDEN_(PRBool) IsEmpty() const
|
| + {
|
| + return Length() == 0;
|
| + }
|
| +
|
| + NS_HIDDEN_(void) Assign(const self_type& aString)
|
| + {
|
| + NS_CStringCopy(*this, aString);
|
| + }
|
| + NS_HIDDEN_(void) Assign(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringSetData(*this, aData, aLength);
|
| + }
|
| + NS_HIDDEN_(void) Assign(char_type aChar)
|
| + {
|
| + NS_CStringSetData(*this, &aChar, 1);
|
| + }
|
| +
|
| + NS_HIDDEN_(self_type&) operator=(const self_type& aString) { Assign(aString); return *this; }
|
| + NS_HIDDEN_(self_type&) operator=(const char_type* aPtr) { Assign(aPtr); return *this; }
|
| + NS_HIDDEN_(self_type&) operator=(char_type aChar) { Assign(aChar); return *this; }
|
| +
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const char_type* data, size_type length = size_type(-1) )
|
| + {
|
| + NS_CStringSetDataRange(*this, cutStart, cutLength, data, length);
|
| + }
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, char_type c )
|
| + {
|
| + Replace(cutStart, cutLength, &c, 1);
|
| + }
|
| + NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const self_type& readable )
|
| + {
|
| + const char_type* data;
|
| + PRUint32 dataLen = NS_CStringGetData(readable, &data);
|
| + NS_CStringSetDataRange(*this, cutStart, cutLength, data, dataLen);
|
| + }
|
| +
|
| + NS_HIDDEN_(void) Append( char_type c ) { Replace(size_type(-1), 0, c); }
|
| + NS_HIDDEN_(void) Append( const char_type* data, size_type length = size_type(-1) ) { Replace(size_type(-1), 0, data, length); }
|
| + NS_HIDDEN_(void) Append( const self_type& readable ) { Replace(size_type(-1), 0, readable); }
|
| +
|
| + NS_HIDDEN_(self_type&) operator+=( char_type c ) { Append(c); return *this; }
|
| + NS_HIDDEN_(self_type&) operator+=( const char_type* data ) { Append(data); return *this; }
|
| + NS_HIDDEN_(self_type&) operator+=( const self_type& readable ) { Append(readable); return *this; }
|
| +
|
| + NS_HIDDEN_(void) Insert( char_type c, index_type pos ) { Replace(pos, 0, c); }
|
| + NS_HIDDEN_(void) Insert( const char_type* data, index_type pos, size_type length = size_type(-1) ) { Replace(pos, 0, data, length); }
|
| + NS_HIDDEN_(void) Insert( const self_type& readable, index_type pos ) { Replace(pos, 0, readable); }
|
| +
|
| + NS_HIDDEN_(void) Cut( index_type cutStart, size_type cutLength ) { Replace(cutStart, cutLength, nsnull, 0); }
|
| +
|
| + NS_HIDDEN_(PRBool) Equals( const self_type &other ) const {
|
| + const char_type *cself;
|
| + const char_type *cother;
|
| + PRUint32 selflen = NS_CStringGetData(*this, &cself);
|
| + PRUint32 otherlen = NS_CStringGetData(other, &cother);
|
| +
|
| + if (selflen != otherlen)
|
| + return PR_FALSE;
|
| +
|
| + return memcmp(cself, cother, selflen * sizeof(char_type)) == 0;
|
| + }
|
| +
|
| +#endif // MOZILLA_INTERNAL_API
|
| +
|
| +protected:
|
| + // Prevent people from allocating a nsACString directly.
|
| + ~nsACString_external() {}
|
| +
|
| +private:
|
| + void *v;
|
| +};
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * Below we define nsStringContainer and nsCStringContainer. These classes
|
| + * have unspecified structure. In most cases, your code should use
|
| + * nsEmbedString instead of these classes; however, if you prefer C-style
|
| + * programming, then look no further...
|
| + */
|
| +
|
| +class nsStringContainer : public nsAString_external
|
| +{
|
| +private:
|
| + void *d1;
|
| + PRUint32 d2;
|
| + void *d3;
|
| +
|
| +public:
|
| + nsStringContainer() {} // MSVC6 needs this
|
| +};
|
| +
|
| +class nsCStringContainer : public nsACString_external
|
| +{
|
| +private:
|
| + void *d1;
|
| + PRUint32 d2;
|
| + void *d3;
|
| +
|
| +public:
|
| + nsCStringContainer() {} // MSVC6 needs this
|
| +};
|
| +
|
| +/* ------------------------------------------------------------------------- */
|
| +
|
| +/**
|
| + * Below we define a number of inlined helper classes that make the frozen
|
| + * string API easier to use.
|
| + */
|
| +
|
| +#ifndef MOZILLA_INTERNAL_API
|
| +#include "nsDebug.h"
|
| +
|
| +/**
|
| + * Rename symbols to avoid conflicting with internal versions.
|
| + */
|
| +#define nsString nsString_external
|
| +#define nsCString nsCString_external
|
| +#define nsDependentString nsDependentString_external
|
| +#define nsDependentCString nsDependentCString_external
|
| +#define NS_ConvertASCIItoUTF16 NS_ConvertASCIItoUTF16_external
|
| +#define NS_ConvertUTF8toUTF16 NS_ConvertUTF8toUTF16_external
|
| +#define NS_ConvertUTF16toUTF8 NS_ConvertUTF16toUTF8_external
|
| +#define NS_LossyConvertUTF16toASCII NS_LossyConvertUTF16toASCII_external
|
| +#define nsGetterCopies nsGetterCopies_external
|
| +#define nsCGetterCopies nsCGetterCopies_external
|
| +#define nsDependentSubstring nsDependentSubstring_external
|
| +#define nsDependentCSubstring nsDependentCSubstring_external
|
| +
|
| +/**
|
| + * basic strings
|
| + */
|
| +
|
| +class nsString : public nsStringContainer
|
| +{
|
| +public:
|
| + typedef nsString self_type;
|
| + typedef nsAString abstract_string_type;
|
| +
|
| + nsString()
|
| + {
|
| + NS_StringContainerInit(*this);
|
| + }
|
| +
|
| + nsString(const self_type& aString)
|
| + {
|
| + NS_StringContainerInit(*this);
|
| + NS_StringCopy(*this, aString);
|
| + }
|
| +
|
| + explicit
|
| + nsString(const abstract_string_type& aReadable)
|
| + {
|
| + NS_StringContainerInit(*this);
|
| + NS_StringCopy(*this, aReadable);
|
| + }
|
| +
|
| + explicit
|
| + nsString(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_StringContainerInit2(*this, aData, aLength, 0);
|
| + }
|
| +
|
| + ~nsString()
|
| + {
|
| + NS_StringContainerFinish(*this);
|
| + }
|
| +
|
| + const char_type* get() const
|
| + {
|
| + const char_type* data;
|
| + NS_StringGetData(*this, &data);
|
| + return data;
|
| + }
|
| +
|
| + self_type& operator=(const self_type& aString) { Assign(aString); return *this; }
|
| + self_type& operator=(const abstract_string_type& aReadable) { Assign(aReadable); return *this; }
|
| + self_type& operator=(const char_type* aPtr) { Assign(aPtr); return *this; }
|
| + self_type& operator=(char_type aChar) { Assign(aChar); return *this; }
|
| +
|
| + void Adopt(const char_type *aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_StringContainerFinish(*this);
|
| + NS_StringContainerInit2(*this, aData, aLength,
|
| + NS_STRING_CONTAINER_INIT_ADOPT);
|
| + }
|
| +
|
| +protected:
|
| +
|
| + nsString(const char_type* aData, size_type aLength, PRUint32 aFlags)
|
| + {
|
| + NS_StringContainerInit2(*this, aData, aLength, aFlags);
|
| + }
|
| +};
|
| +
|
| +class nsCString : public nsCStringContainer
|
| +{
|
| +public:
|
| + typedef nsCString self_type;
|
| + typedef nsACString abstract_string_type;
|
| +
|
| + nsCString()
|
| + {
|
| + NS_CStringContainerInit(*this);
|
| + }
|
| +
|
| + nsCString(const self_type& aString)
|
| + {
|
| + NS_CStringContainerInit(*this);
|
| + NS_CStringCopy(*this, aString);
|
| + }
|
| +
|
| + explicit
|
| + nsCString(const abstract_string_type& aReadable)
|
| + {
|
| + NS_CStringContainerInit(*this);
|
| + NS_CStringCopy(*this, aReadable);
|
| + }
|
| +
|
| + explicit
|
| + nsCString(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringContainerInit(*this);
|
| + NS_CStringSetData(*this, aData, aLength);
|
| + }
|
| +
|
| + ~nsCString()
|
| + {
|
| + NS_CStringContainerFinish(*this);
|
| + }
|
| +
|
| + const char_type* get() const
|
| + {
|
| + const char_type* data;
|
| + NS_CStringGetData(*this, &data);
|
| + return data;
|
| + }
|
| +
|
| + self_type& operator=(const self_type& aString) { Assign(aString); return *this; }
|
| + self_type& operator=(const abstract_string_type& aReadable) { Assign(aReadable); return *this; }
|
| + self_type& operator=(const char_type* aPtr) { Assign(aPtr); return *this; }
|
| + self_type& operator=(char_type aChar) { Assign(aChar); return *this; }
|
| +
|
| + void Adopt(const char_type *aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringContainerFinish(*this);
|
| + NS_CStringContainerInit2(*this, aData, aLength,
|
| + NS_CSTRING_CONTAINER_INIT_ADOPT);
|
| + }
|
| +
|
| +protected:
|
| +
|
| + nsCString(const char_type* aData, size_type aLength, PRUint32 aFlags)
|
| + {
|
| + NS_CStringContainerInit2(*this, aData, aLength, aFlags);
|
| + }
|
| +};
|
| +
|
| +
|
| +/**
|
| + * dependent strings
|
| + */
|
| +
|
| +class nsDependentString : public nsString
|
| +{
|
| +public:
|
| + typedef nsDependentString self_type;
|
| +
|
| + nsDependentString() {}
|
| +
|
| + explicit
|
| + nsDependentString(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + : nsString(aData, aLength, NS_CSTRING_CONTAINER_INIT_DEPEND)
|
| + {}
|
| +
|
| + void Rebind(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_StringContainerFinish(*this);
|
| + NS_StringContainerInit2(*this, aData, aLength,
|
| + NS_STRING_CONTAINER_INIT_DEPEND);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +class nsDependentCString : public nsCString
|
| +{
|
| +public:
|
| + typedef nsDependentCString self_type;
|
| +
|
| + nsDependentCString() {}
|
| +
|
| + explicit
|
| + nsDependentCString(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + : nsCString(aData, aLength, NS_CSTRING_CONTAINER_INIT_DEPEND)
|
| + {}
|
| +
|
| + void Rebind(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringContainerFinish(*this);
|
| + NS_CStringContainerInit2(*this, aData, aLength,
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +
|
| +/**
|
| + * conversion classes
|
| + */
|
| +
|
| +class NS_ConvertASCIItoUTF16 : public nsString
|
| +{
|
| +public:
|
| + typedef NS_ConvertASCIItoUTF16 self_type;
|
| +
|
| + explicit
|
| + NS_ConvertASCIItoUTF16(const nsACString& aStr)
|
| + {
|
| + NS_CStringToUTF16(aStr, NS_CSTRING_ENCODING_ASCII, *this);
|
| + }
|
| +
|
| + explicit
|
| + NS_ConvertASCIItoUTF16(const char* aData, PRUint32 aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringToUTF16(nsDependentCString(aData, aLength),
|
| + NS_CSTRING_ENCODING_ASCII, *this);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +class NS_ConvertUTF8toUTF16 : public nsString
|
| +{
|
| +public:
|
| + typedef NS_ConvertUTF8toUTF16 self_type;
|
| +
|
| + explicit
|
| + NS_ConvertUTF8toUTF16(const nsACString& aStr)
|
| + {
|
| + NS_CStringToUTF16(aStr, NS_CSTRING_ENCODING_UTF8, *this);
|
| + }
|
| +
|
| + explicit
|
| + NS_ConvertUTF8toUTF16(const char* aData, PRUint32 aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_CStringToUTF16(nsDependentCString(aData, aLength),
|
| + NS_CSTRING_ENCODING_UTF8, *this);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +class NS_ConvertUTF16toUTF8 : public nsCString
|
| +{
|
| +public:
|
| + typedef NS_ConvertUTF16toUTF8 self_type;
|
| +
|
| + explicit
|
| + NS_ConvertUTF16toUTF8(const nsAString& aStr)
|
| + {
|
| + NS_UTF16ToCString(aStr, NS_CSTRING_ENCODING_UTF8, *this);
|
| + }
|
| +
|
| + explicit
|
| + NS_ConvertUTF16toUTF8(const PRUnichar* aData, PRUint32 aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_UTF16ToCString(nsDependentString(aData, aLength),
|
| + NS_CSTRING_ENCODING_UTF8, *this);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +class NS_LossyConvertUTF16toASCII : public nsCString
|
| +{
|
| +public:
|
| + typedef NS_LossyConvertUTF16toASCII self_type;
|
| +
|
| + explicit
|
| + NS_LossyConvertUTF16toASCII(const nsAString& aStr)
|
| + {
|
| + NS_UTF16ToCString(aStr, NS_CSTRING_ENCODING_ASCII, *this);
|
| + }
|
| +
|
| + explicit
|
| + NS_LossyConvertUTF16toASCII(const PRUnichar* aData, PRUint32 aLength = PR_UINT32_MAX)
|
| + {
|
| + NS_UTF16ToCString(nsDependentString(aData, aLength),
|
| + NS_CSTRING_ENCODING_ASCII, *this);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +
|
| +/**
|
| + * literal strings
|
| + *
|
| + * NOTE: HAVE_CPP_2BYTE_WCHAR_T may be automatically defined for some platforms
|
| + * in nscore.h. On other platforms, it may be defined in xpcom-config.h.
|
| + * Under GCC, this define should only be set if compiling with -fshort-wchar.
|
| + */
|
| +
|
| +#ifdef HAVE_CPP_2BYTE_WCHAR_T
|
| + #define NS_LL(s) L##s
|
| + #define NS_MULTILINE_LITERAL_STRING(s) nsDependentString(NS_REINTERPRET_CAST(const nsAString::char_type*, s), PRUint32((sizeof(s)/sizeof(wchar_t))-1))
|
| + #define NS_MULTILINE_LITERAL_STRING_INIT(n,s) n(NS_REINTERPRET_CAST(const nsAString::char_type*, s), PRUint32((sizeof(s)/sizeof(wchar_t))-1))
|
| + #define NS_NAMED_MULTILINE_LITERAL_STRING(n,s) const nsDependentString n(NS_REINTERPRET_CAST(const nsAString::char_type*, s), PRUint32((sizeof(s)/sizeof(wchar_t))-1))
|
| + typedef nsDependentString nsLiteralString;
|
| +#else
|
| + #define NS_LL(s) s
|
| + #define NS_MULTILINE_LITERAL_STRING(s) NS_ConvertASCIItoUTF16(s, PRUint32(sizeof(s)-1))
|
| + #define NS_MULTILINE_LITERAL_STRING_INIT(n,s) n(s, PRUint32(sizeof(s)-1))
|
| + #define NS_NAMED_MULTILINE_LITERAL_STRING(n,s) const NS_ConvertASCIItoUTF16 n(s, PRUint32(sizeof(s)-1))
|
| + typedef NS_ConvertASCIItoUTF16 nsLiteralString;
|
| +#endif
|
| +
|
| +/*
|
| + * Macro arguments used in concatenation or stringification won't be expanded.
|
| + * Therefore, in order for |NS_L(FOO)| to work as expected (which is to expand
|
| + * |FOO| before doing whatever |NS_L| needs to do to it) a helper macro needs
|
| + * to be inserted in between to allow the macro argument to expand.
|
| + * See "3.10.6 Separate Expansion of Macro Arguments" of the CPP manual for a
|
| + * more accurate and precise explanation.
|
| + */
|
| +
|
| +#define NS_L(s) NS_LL(s)
|
| +
|
| +#define NS_LITERAL_STRING(s) NS_STATIC_CAST(const nsString&, NS_MULTILINE_LITERAL_STRING(NS_LL(s)))
|
| +#define NS_LITERAL_STRING_INIT(n,s) NS_MULTILINE_LITERAL_STRING_INIT(n, NS_LL(s))
|
| +#define NS_NAMED_LITERAL_STRING(n,s) NS_NAMED_MULTILINE_LITERAL_STRING(n, NS_LL(s))
|
| +
|
| +#define NS_LITERAL_CSTRING(s) NS_STATIC_CAST(const nsDependentCString&, nsDependentCString(s, PRUint32(sizeof(s)-1)))
|
| +#define NS_LITERAL_CSTRING_INIT(n,s) n(s, PRUint32(sizeof(s)-1))
|
| +#define NS_NAMED_LITERAL_CSTRING(n,s) const nsDependentCString n(s, PRUint32(sizeof(s)-1))
|
| +
|
| +typedef nsDependentCString nsLiteralCString;
|
| +
|
| +
|
| +/**
|
| + * getter_Copies support
|
| + *
|
| + * NS_IMETHOD GetBlah(PRUnichar**);
|
| + *
|
| + * void some_function()
|
| + * {
|
| + * nsString blah;
|
| + * GetBlah(getter_Copies(blah));
|
| + * // ...
|
| + * }
|
| + */
|
| +
|
| +class nsGetterCopies
|
| +{
|
| +public:
|
| + typedef PRUnichar char_type;
|
| +
|
| + nsGetterCopies(nsString& aStr)
|
| + : mString(aStr), mData(nsnull)
|
| + {}
|
| +
|
| + ~nsGetterCopies()
|
| + {
|
| + mString.Adopt(mData);
|
| + }
|
| +
|
| + operator char_type**()
|
| + {
|
| + return &mData;
|
| + }
|
| +
|
| +private:
|
| + nsString& mString;
|
| + char_type* mData;
|
| +};
|
| +
|
| +inline nsGetterCopies
|
| +getter_Copies(nsString& aString)
|
| +{
|
| + return nsGetterCopies(aString);
|
| +}
|
| +
|
| +class nsCGetterCopies
|
| +{
|
| +public:
|
| + typedef char char_type;
|
| +
|
| + nsCGetterCopies(nsCString& aStr)
|
| + : mString(aStr), mData(nsnull)
|
| + {}
|
| +
|
| + ~nsCGetterCopies()
|
| + {
|
| + mString.Adopt(mData);
|
| + }
|
| +
|
| + operator char_type**()
|
| + {
|
| + return &mData;
|
| + }
|
| +
|
| +private:
|
| + nsCString& mString;
|
| + char_type* mData;
|
| +};
|
| +
|
| +inline nsCGetterCopies
|
| +getter_Copies(nsCString& aString)
|
| +{
|
| + return nsCGetterCopies(aString);
|
| +}
|
| +
|
| +
|
| +/**
|
| +* substrings
|
| +*/
|
| +
|
| +class nsDependentSubstring : public nsStringContainer
|
| +{
|
| +public:
|
| + typedef nsDependentSubstring self_type;
|
| + typedef nsAString abstract_string_type;
|
| +
|
| + ~nsDependentSubstring()
|
| + {
|
| + NS_StringContainerFinish(*this);
|
| + }
|
| +
|
| + nsDependentSubstring()
|
| + {
|
| + NS_StringContainerInit(*this);
|
| + }
|
| +
|
| + nsDependentSubstring(const char_type *aStart, PRUint32 aLength)
|
| + {
|
| + NS_StringContainerInit2(*this, aStart, aLength,
|
| + NS_STRING_CONTAINER_INIT_DEPEND |
|
| + NS_STRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + nsDependentSubstring(const abstract_string_type& aStr,
|
| + PRUint32 aStartPos)
|
| + {
|
| + const PRUnichar* data;
|
| + PRUint32 len = NS_StringGetData(aStr, &data);
|
| + NS_StringContainerInit2(*this, data + aStartPos, len - aStartPos,
|
| + NS_STRING_CONTAINER_INIT_DEPEND |
|
| + NS_STRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + nsDependentSubstring(const abstract_string_type& aStr,
|
| + PRUint32 aStartPos, PRUint32 aLength)
|
| + {
|
| + const PRUnichar* data;
|
| +#ifdef DEBUG
|
| + PRUint32 len =
|
| +#endif
|
| + NS_StringGetData(aStr, &data);
|
| + NS_ASSERTION(aStartPos + aLength <= len, "bad length");
|
| + NS_StringContainerInit2(*this, data + aStartPos, aLength,
|
| + NS_STRING_CONTAINER_INIT_DEPEND |
|
| + NS_STRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + void Rebind(const char_type *aStart, PRUint32 aLength)
|
| + {
|
| + NS_StringContainerFinish(*this);
|
| + NS_StringContainerInit2(*this, aStart, aLength,
|
| + NS_STRING_CONTAINER_INIT_DEPEND |
|
| + NS_STRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +class nsDependentCSubstring : public nsCStringContainer
|
| +{
|
| +public:
|
| + typedef nsDependentCSubstring self_type;
|
| + typedef nsACString abstract_string_type;
|
| +
|
| + ~nsDependentCSubstring()
|
| + {
|
| + NS_CStringContainerFinish(*this);
|
| + }
|
| +
|
| + nsDependentCSubstring()
|
| + {
|
| + NS_CStringContainerInit(*this);
|
| + }
|
| +
|
| + nsDependentCSubstring(const char_type *aStart, PRUint32 aLength)
|
| + {
|
| + NS_CStringContainerInit2(*this, aStart, aLength,
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND |
|
| + NS_CSTRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + nsDependentCSubstring(const abstract_string_type& aStr,
|
| + PRUint32 aStartPos)
|
| + {
|
| + const char* data;
|
| + PRUint32 len = NS_CStringGetData(aStr, &data);
|
| + NS_CStringContainerInit2(*this, data + aStartPos, len - aStartPos,
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND |
|
| + NS_CSTRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + nsDependentCSubstring(const abstract_string_type& aStr,
|
| + PRUint32 aStartPos, PRUint32 aLength)
|
| + {
|
| + const char* data;
|
| +#ifdef DEBUG
|
| + PRUint32 len =
|
| +#endif
|
| + NS_CStringGetData(aStr, &data);
|
| + NS_ASSERTION(aStartPos + aLength <= len, "bad length");
|
| + NS_CStringContainerInit2(*this, data + aStartPos, aLength,
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND |
|
| + NS_CSTRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| + void Rebind(const char_type *aStart, PRUint32 aLength)
|
| + {
|
| + NS_CStringContainerFinish(*this);
|
| + NS_CStringContainerInit2(*this, aStart, aLength,
|
| + NS_CSTRING_CONTAINER_INIT_DEPEND |
|
| + NS_CSTRING_CONTAINER_INIT_SUBSTRING);
|
| + }
|
| +
|
| +private:
|
| + self_type& operator=(const self_type& aString); // NOT IMPLEMENTED
|
| +};
|
| +
|
| +
|
| +/**
|
| + * Various nsDependentC?Substring constructor functions
|
| + */
|
| +
|
| +// PRUnichar
|
| +inline
|
| +const nsDependentSubstring
|
| +Substring( const nsAString& str, PRUint32 startPos )
|
| +{
|
| + return nsDependentSubstring(str, startPos);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentSubstring
|
| +Substring( const nsAString& str, PRUint32 startPos, PRUint32 length )
|
| +{
|
| + return nsDependentSubstring(str, startPos, length);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentSubstring
|
| +Substring( const PRUnichar* start, const PRUnichar* end )
|
| +{
|
| + return nsDependentSubstring(start, end - start);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentSubstring
|
| +Substring( const PRUnichar* start, PRUint32 length )
|
| +{
|
| + return nsDependentSubstring(start, length);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentSubstring
|
| +StringHead( const nsAString& str, PRUint32 count )
|
| +{
|
| + return nsDependentSubstring(str, 0, count);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentSubstring
|
| +StringTail( const nsAString& str, PRUint32 count )
|
| +{
|
| + return nsDependentSubstring(str, str.Length() - count, count);
|
| +}
|
| +
|
| +// char
|
| +inline
|
| +const nsDependentCSubstring
|
| +Substring( const nsACString& str, PRUint32 startPos )
|
| +{
|
| + return nsDependentCSubstring(str, startPos);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentCSubstring
|
| +Substring( const nsACString& str, PRUint32 startPos, PRUint32 length )
|
| +{
|
| + return nsDependentCSubstring(str, startPos, length);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentCSubstring
|
| +Substring( const char* start, const char* end )
|
| +{
|
| + return nsDependentCSubstring(start, end - start);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentCSubstring
|
| +Substring( const char* start, PRUint32 length )
|
| +{
|
| + return nsDependentCSubstring(start, length);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentCSubstring
|
| +StringHead( const nsACString& str, PRUint32 count )
|
| +{
|
| + return nsDependentCSubstring(str, 0, count);
|
| +}
|
| +
|
| +inline
|
| +const nsDependentCSubstring
|
| +StringTail( const nsACString& str, PRUint32 count )
|
| +{
|
| + return nsDependentCSubstring(str, str.Length() - count, count);
|
| +}
|
| +
|
| +
|
| +/*
|
| + * Canonical empty strings
|
| + */
|
| +
|
| +#define EmptyCString() nsCString()
|
| +#define EmptyString() nsString()
|
| +
|
| +#endif // MOZILLA_INTERNAL_API
|
| +
|
| +#endif // nsStringAPI_h__
|
|
|
| Property changes on: gecko-sdk\include\nsStringAPI.h
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|