123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737 |
- /* 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 <[email protected]>
- *
- * 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__
|