/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* * The contents of this file are subject to the Netscape 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/NPL/ * * 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.org code. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1998 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): */ #include "nsToken.h" #include "nsScanner.h" MOZ_DECL_CTOR_COUNTER(CToken); static int TokenCount=0; static int DelTokenCount=0; int CToken::GetTokenCount(){return TokenCount-DelTokenCount;} /************************************************************** And now for the CToken... **************************************************************/ /** * Default constructor * * @update gess 7/21/98 */ CToken::CToken(PRInt32 aTag) : mTextValue() { MOZ_COUNT_CTOR(CToken); mTypeID=aTag; mAttrCount=0; TokenCount++; mOrigin=eSource; mUseCount=0; mNewlineCount=0; } /** * Constructor with string for tagname assignment * * @update gess 3/25/98 * @param nsString--name of token */ CToken::CToken(const nsString& aName) : mTextValue(aName) { MOZ_COUNT_CTOR(CToken); mTypeID=0; mAttrCount=0; TokenCount++; mOrigin=eSource; mUseCount=0; mNewlineCount=0; } /** * constructor from char* * * @update gess 3/25/98 * @param aName--char* containing name of token */ CToken::CToken(const char* aName) : mTextValue(aName) { MOZ_COUNT_CTOR(CToken); mTypeID=0; mAttrCount=0; TokenCount++; mOrigin=eSource; mUseCount=0; mNewlineCount=0; } /** * Decstructor * * @update gess 3/25/98 */ CToken::~CToken() { MOZ_COUNT_DTOR(CToken); DelTokenCount++; } /** * This method gets called when a token is about to be reused * for some other purpose. The token should initialize itself * to some reasonable default values. * @update gess7/25/98 * @param aTag * @param aString */ void CToken::Reinitialize(PRInt32 aTag, const nsString& aString){ if(0==aString.Length()) mTextValue.Truncate(0); else mTextValue=aString; mAttrCount=0; mTypeID=aTag; mAttrCount=0; mOrigin=eSource; mUseCount=0; mNewlineCount=0; } /** * Virtual method used to tell this toke to consume his * valid chars. * * @update gess 3/25/98 * @param aChar -- first char in sequence * @param aScanner -- object to retrieve data from * @return int error code */ nsresult CToken::Consume(PRUnichar aChar,nsScanner& aScanner,PRInt32 aMode) { nsresult result=NS_OK; return result; } /** * This debug method causes the token to dump its content * to the given stream (formated for debugging). * * @update gess 3/25/98 * @param ostream -- output stream to accept output data */ void CToken::DebugDumpToken(nsOutputStream& anOutputStream) { anOutputStream << "[" << GetClassName() << "] "; int i=0; for(i=0;i