2004-02-19 02:44:03 +00:00
|
|
|
/* 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__
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "nscore.h"
|
|
|
|
|
2004-10-25 19:34:45 +00:00
|
|
|
#if defined( XPCOM_GLUE )
|
|
|
|
#define NS_STRINGAPI(type) extern "C" 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
|
2004-02-19 02:44:03 +00:00
|
|
|
|
2004-04-01 22:39:51 +00:00
|
|
|
/* The base string types */
|
|
|
|
class nsAString;
|
|
|
|
class nsACString;
|
2004-02-19 02:44:03 +00:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* nsStringContainer
|
|
|
|
*
|
2004-07-30 16:00:59 +00:00
|
|
|
* This is an opaque data type that is large enough to hold the canonical
|
2004-02-19 02:44:03 +00:00
|
|
|
* 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
|
2004-11-16 04:44:57 +00:00
|
|
|
* and may be null-terminated depending on how it is initialized.
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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);
|
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* nsresult MyCode()
|
2004-02-19 02:44:03 +00:00
|
|
|
* {
|
2004-04-11 20:52:32 +00:00
|
|
|
* nsresult rv;
|
|
|
|
*
|
2004-02-19 02:44:03 +00:00
|
|
|
* nsStringContainer sc;
|
2004-04-11 20:52:32 +00:00
|
|
|
* rv = NS_StringContainerInit(sc);
|
|
|
|
* if (NS_FAILED(rv))
|
|
|
|
* return rv;
|
|
|
|
*
|
|
|
|
* rv = GetBlah(sc);
|
|
|
|
* if (NS_SUCCEEDED(rv))
|
2004-02-19 02:44:03 +00:00
|
|
|
* {
|
2004-04-11 20:52:32 +00:00
|
|
|
* const PRUnichar *data;
|
|
|
|
* NS_StringGetData(sc, &data);
|
|
|
|
* //
|
|
|
|
* // |data| now points to the result of the GetBlah function
|
|
|
|
* //
|
2004-02-19 02:44:03 +00:00
|
|
|
* }
|
2004-04-11 20:52:32 +00:00
|
|
|
*
|
|
|
|
* NS_StringContainerFinish(sc);
|
|
|
|
* return rv;
|
2004-02-19 02:44:03 +00:00
|
|
|
* }
|
|
|
|
*
|
|
|
|
* 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);
|
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* nsresult MyCode()
|
2004-02-19 02:44:03 +00:00
|
|
|
* {
|
2004-04-11 20:52:32 +00:00
|
|
|
* nsresult rv;
|
|
|
|
*
|
2004-02-19 02:44:03 +00:00
|
|
|
* nsStringContainer sc;
|
2004-04-11 20:52:32 +00:00
|
|
|
* rv = NS_StringContainerInit(sc);
|
|
|
|
* if (NS_FAILED(rv))
|
|
|
|
* return rv;
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* const PRUnichar kData[] = {'x','y','z','\0'};
|
|
|
|
* rv = NS_StringSetData(sc, kData, sizeof(kData)/2 - 1);
|
|
|
|
* if (NS_SUCCEEDED(rv))
|
|
|
|
* rv = SetBlah(sc);
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* NS_StringContainerFinish(sc);
|
|
|
|
* return rv;
|
2004-02-19 02:44:03 +00:00
|
|
|
* }
|
|
|
|
*/
|
2004-04-01 22:39:51 +00:00
|
|
|
class nsStringContainer;
|
2004-02-19 02:44:03 +00:00
|
|
|
|
2004-11-16 04:44:57 +00:00
|
|
|
/**
|
|
|
|
* 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)
|
|
|
|
};
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* NS_StringContainerInit
|
|
|
|
*
|
|
|
|
* @param aContainer string container reference
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if string container successfully initialized
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function may allocate additional memory for aContainer. When
|
|
|
|
* aContainer is no longer needed, NS_StringContainerFinish should be called.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_StringContainerInit(nsStringContainer &aContainer);
|
|
|
|
|
2004-11-16 04:44:57 +00:00
|
|
|
/**
|
|
|
|
* 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);
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* NS_StringContainerFinish
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-02-19 02:44:03 +00:00
|
|
|
* @param aContainer string container reference
|
|
|
|
*
|
|
|
|
* This function frees any memory owned by aContainer.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
|
|
|
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
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
|
|
|
NS_STRINGAPI(PRUint32)
|
|
|
|
NS_StringGetData
|
|
|
|
(const nsAString &aStr, const PRUnichar **aData,
|
|
|
|
PRBool *aTerminated = nsnull);
|
|
|
|
|
2004-04-20 00:21:34 +00:00
|
|
|
/**
|
2004-07-30 16:00:59 +00:00
|
|
|
* NS_StringCloneData
|
2004-04-20 00:21:34 +00:00
|
|
|
*
|
|
|
|
* 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)
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-20 00:21:34 +00:00
|
|
|
* @status FROZEN
|
|
|
|
*/
|
|
|
|
NS_STRINGAPI(PRUnichar *)
|
|
|
|
NS_StringCloneData
|
|
|
|
(const nsAString &aStr);
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* 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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function does not necessarily null-terminate aStr after copying data
|
2004-07-30 16:00:59 +00:00
|
|
|
* from aData. The behavior depends on the implementation of the abstract
|
2004-02-19 02:44:03 +00:00
|
|
|
* string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
|
|
|
* will be null-terminated by this function.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function does not necessarily null-terminate aStr after copying data
|
2004-07-30 16:00:59 +00:00
|
|
|
* from aData. The behavior depends on the implementation of the abstract
|
2004-02-19 02:44:03 +00:00
|
|
|
* string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
|
|
|
* will be null-terminated by this function.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_StringAppendData(nsAString &aStr, const PRUnichar *aData,
|
|
|
|
PRUint32 aDataLength = PR_UINT32_MAX)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_StringSetDataRange(aStr, PR_UINT32_MAX, 0, aData, aDataLength);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_StringInsertData(nsAString &aStr, PRUint32 aOffset, const PRUnichar *aData,
|
|
|
|
PRUint32 aDataLength = PR_UINT32_MAX)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_StringSetDataRange(aStr, aOffset, 0, aData, aDataLength);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
2004-07-30 16:00:59 +00:00
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* 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
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_StringCutData(nsAString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_StringSetDataRange(aStr, aCutOffset, aCutLength, nsnull, 0);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* nsCStringContainer
|
|
|
|
*
|
2004-07-30 16:00:59 +00:00
|
|
|
* This is an opaque data type that is large enough to hold the canonical
|
2004-02-19 02:44:03 +00:00
|
|
|
* 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
|
2004-11-16 04:44:57 +00:00
|
|
|
* and may be null-terminated depending on how it is initialized.
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* @see nsStringContainer for use cases and further documentation.
|
|
|
|
*/
|
2004-04-01 22:39:51 +00:00
|
|
|
class nsCStringContainer;
|
2004-02-19 02:44:03 +00:00
|
|
|
|
2004-11-16 04:44:57 +00:00
|
|
|
/**
|
|
|
|
* 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)
|
|
|
|
};
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* NS_CStringContainerInit
|
|
|
|
*
|
|
|
|
* @param aContainer string container reference
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if string container successfully initialized
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function may allocate additional memory for aContainer. When
|
|
|
|
* aContainer is no longer needed, NS_CStringContainerFinish should be called.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_CStringContainerInit(nsCStringContainer &aContainer);
|
|
|
|
|
2004-11-16 04:44:57 +00:00
|
|
|
/**
|
|
|
|
* 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);
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* NS_CStringContainerFinish
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-02-19 02:44:03 +00:00
|
|
|
* @param aContainer string container reference
|
|
|
|
*
|
|
|
|
* This function frees any memory owned by aContainer.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
|
|
|
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
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
|
|
|
NS_STRINGAPI(PRUint32)
|
|
|
|
NS_CStringGetData
|
|
|
|
(const nsACString &aStr, const char **aData,
|
|
|
|
PRBool *aTerminated = nsnull);
|
|
|
|
|
2004-04-20 00:21:34 +00:00
|
|
|
/**
|
2004-07-30 16:00:59 +00:00
|
|
|
* NS_CStringCloneData
|
2004-04-20 00:21:34 +00:00
|
|
|
*
|
|
|
|
* 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)
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-20 00:21:34 +00:00
|
|
|
* @status FROZEN
|
|
|
|
*/
|
|
|
|
NS_STRINGAPI(char *)
|
|
|
|
NS_CStringCloneData
|
|
|
|
(const nsACString &aStr);
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* 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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function does not necessarily null-terminate aStr after copying data
|
2004-07-30 16:00:59 +00:00
|
|
|
* from aData. The behavior depends on the implementation of the abstract
|
2004-02-19 02:44:03 +00:00
|
|
|
* string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
|
|
|
* will be null-terminated by this function.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* This function does not necessarily null-terminate aStr after copying data
|
2004-07-30 16:00:59 +00:00
|
|
|
* from aData. The behavior depends on the implementation of the abstract
|
2004-02-19 02:44:03 +00:00
|
|
|
* string, aStr. If aStr is a reference to a nsStringContainer, then its data
|
|
|
|
* will be null-terminated by this function.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_STRINGAPI(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_CStringAppendData(nsACString &aStr, const char *aData,
|
|
|
|
PRUint32 aDataLength = PR_UINT32_MAX)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_CStringSetDataRange(aStr, PR_UINT32_MAX, 0, aData, aDataLength);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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)
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_CStringInsertData(nsACString &aStr, PRUint32 aOffset, const char *aData,
|
|
|
|
PRUint32 aDataLength = PR_UINT32_MAX)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_CStringSetDataRange(aStr, aOffset, 0, aData, aDataLength);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
2004-07-30 16:00:59 +00:00
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
/**
|
|
|
|
* 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
|
2004-04-11 20:52:32 +00:00
|
|
|
* @return NS_OK if function succeeded
|
2004-02-19 02:44:03 +00:00
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
inline NS_HIDDEN_(nsresult)
|
2004-02-19 02:44:03 +00:00
|
|
|
NS_CStringCutData(nsACString &aStr, PRUint32 aCutOffset, PRUint32 aCutLength)
|
|
|
|
{
|
2004-04-11 20:52:32 +00:00
|
|
|
return NS_CStringSetDataRange(aStr, aCutOffset, aCutLength, nsnull, 0);
|
2004-02-19 02:44:03 +00:00
|
|
|
}
|
|
|
|
|
2004-04-01 20:47:48 +00:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encodings that can be used with the following conversion routines.
|
|
|
|
*/
|
2004-04-11 20:52:32 +00:00
|
|
|
enum nsCStringEncoding {
|
2004-04-01 20:47:48 +00:00
|
|
|
/* 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. */
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_CSTRING_ENCODING_ASCII = 0,
|
2004-04-01 20:47:48 +00:00
|
|
|
|
|
|
|
/* Conversion between UTF-8 and UTF-16 is non-lossy. */
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_CSTRING_ENCODING_UTF8 = 1,
|
2004-04-01 20:47:48 +00:00
|
|
|
|
|
|
|
/* 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. */
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_CSTRING_ENCODING_NATIVE_FILESYSTEM = 2
|
2004-04-01 20:47:48 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-04-01 20:47:48 +00:00
|
|
|
*/
|
|
|
|
NS_STRINGAPI(nsresult)
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_CStringToUTF16(const nsACString &aSource, nsCStringEncoding aSrcEncoding,
|
2004-04-01 20:47:48 +00:00
|
|
|
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
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-11 20:52:32 +00:00
|
|
|
* @status FROZEN
|
2004-04-01 20:47:48 +00:00
|
|
|
*/
|
|
|
|
NS_STRINGAPI(nsresult)
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_UTF16ToCString(const nsAString &aSource, nsCStringEncoding aDestEncoding,
|
2004-04-01 20:47:48 +00:00
|
|
|
nsACString &aDest);
|
|
|
|
|
2004-04-01 22:39:51 +00:00
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2004-07-30 16:00:59 +00:00
|
|
|
*
|
2004-04-01 22:39:51 +00:00
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2004-11-12 19:26:37 +00:00
|
|
|
#ifdef MOZILLA_STRICT_API
|
2004-04-01 22:39:51 +00:00
|
|
|
#define nsAString_external nsAString
|
|
|
|
#define nsACString_external nsACString
|
|
|
|
#endif
|
|
|
|
|
|
|
|
class nsAString_external
|
|
|
|
{
|
2004-11-12 19:26:37 +00:00
|
|
|
#ifdef MOZILLA_STRICT_API
|
2004-04-01 22:39:51 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
typedef PRUnichar char_type;
|
|
|
|
typedef nsAString_external self_type;
|
|
|
|
typedef PRUint32 size_type;
|
|
|
|
typedef PRUint32 index_type;
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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_(size_type) Length() const
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
const char_type* data;
|
|
|
|
return NS_StringGetData(*this, &data);
|
|
|
|
}
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(const self_type& aString)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_StringCopy(*this, aString);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_StringSetData(*this, aData, aLength);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(char_type aChar)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_StringSetData(*this, &aChar, 1);
|
|
|
|
}
|
2004-07-30 16:00:59 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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; }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const char_type* data, size_type length = size_type(-1) )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_StringSetDataRange(*this, cutStart, cutLength, data, length);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, char_type c )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
Replace(cutStart, cutLength, &c, 1);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const self_type& readable )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
const char_type* data;
|
|
|
|
PRUint32 dataLen = NS_StringGetData(readable, &data);
|
|
|
|
NS_StringSetDataRange(*this, cutStart, cutLength, data, dataLen);
|
|
|
|
}
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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; }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Cut( index_type cutStart, size_type cutLength ) { Replace(cutStart, cutLength, nsnull, 0); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-11-12 19:26:37 +00:00
|
|
|
#endif // MOZILLA_STRICT_API
|
2004-04-01 22:39:51 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
void *v;
|
|
|
|
};
|
|
|
|
|
|
|
|
class nsACString_external
|
|
|
|
{
|
2004-11-12 19:26:37 +00:00
|
|
|
#ifdef MOZILLA_STRICT_API
|
2004-04-01 22:39:51 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
typedef char char_type;
|
|
|
|
typedef nsACString_external self_type;
|
|
|
|
typedef PRUint32 size_type;
|
|
|
|
typedef PRUint32 index_type;
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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_(size_type) Length() const
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
const char_type* data;
|
|
|
|
return NS_CStringGetData(*this, &data);
|
|
|
|
}
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(const self_type& aString)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_CStringCopy(*this, aString);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(const char_type* aData, size_type aLength = PR_UINT32_MAX)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_CStringSetData(*this, aData, aLength);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Assign(char_type aChar)
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_CStringSetData(*this, &aChar, 1);
|
|
|
|
}
|
2004-07-30 16:00:59 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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; }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const char_type* data, size_type length = size_type(-1) )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
NS_CStringSetDataRange(*this, cutStart, cutLength, data, length);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, char_type c )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
Replace(cutStart, cutLength, &c, 1);
|
|
|
|
}
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Replace( index_type cutStart, size_type cutLength, const self_type& readable )
|
2004-04-01 22:39:51 +00:00
|
|
|
{
|
|
|
|
const char_type* data;
|
|
|
|
PRUint32 dataLen = NS_CStringGetData(readable, &data);
|
|
|
|
NS_CStringSetDataRange(*this, cutStart, cutLength, data, dataLen);
|
|
|
|
}
|
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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; }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
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); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-04-11 20:52:32 +00:00
|
|
|
NS_HIDDEN_(void) Cut( index_type cutStart, size_type cutLength ) { Replace(cutStart, cutLength, nsnull, 0); }
|
2004-04-01 22:39:51 +00:00
|
|
|
|
2004-11-12 19:26:37 +00:00
|
|
|
#endif // MOZILLA_STRICT_API
|
2004-04-01 22:39:51 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
};
|
|
|
|
|
2004-02-19 02:44:03 +00:00
|
|
|
#endif // nsStringAPI_h__
|