/* * CDE - Common Desktop Environment * * Copyright (c) 1993-2012, The Open Group. All rights reserved. * * These libraries and programs are free software; you can * redistribute them and/or modify them under the terms of the GNU * Lesser General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) * any later version. * * These libraries and programs are distributed in the hope that * they will be useful, but WITHOUT ANY WARRANTY; without even the * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU Lesser General Public License for more * details. * * You should have received a copy of the GNU Lesser General Public * License along with these librararies and programs; if not, write * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth * Floor, Boston, MA 02110-1301 USA */ /* $XConsortium: TokenMessageArg.C /main/1 1996/07/29 17:06:18 cde-hp $ */ // Copyright (c) 1994 James Clark // See the file COPYING for copying permission. #ifdef __GNUG__ #pragma implementation #endif #include "splib.h" #include "TokenMessageArg.h" #include "MessageBuilder.h" #include "token.h" #include "ParserMessages.h" #include "Mode.h" #include "ModeInfo.h" #include "macros.h" #ifdef SP_NAMESPACE namespace SP_NAMESPACE { #endif TokenMessageArg::TokenMessageArg(Token token, Mode mode, const ConstPtr &syntax, const ConstPtr &sd) : token_(token), mode_(mode), syntax_(syntax), sd_(sd) { } MessageArg *TokenMessageArg::copy() const { return new TokenMessageArg(*this); } void TokenMessageArg::append(MessageBuilder &builder) const { // FIXME translate function characters in delimiters into // &#NAME; form. if (token_ >= tokenFirstShortref) { builder.appendFragment(ParserMessages::shortrefDelim); return; } if (token_ == tokenEe) { builder.appendFragment(ParserMessages::entityEnd); return; } ModeInfo iter(mode_, *sd_); TokenInfo info; const MessageFragment *fragment = 0; while (iter.nextToken(&info)) if (info.token == token_) { switch (info.type) { case TokenInfo::delimType: case TokenInfo::delimDelimType: case TokenInfo::delimSetType: { const StringC &delim = syntax_->delimGeneral(info.delim1); builder.appendFragment(ParserMessages::delimStart); builder.appendChars(delim.data(), delim.size()); fragment = &ParserMessages::delimEnd; } break; case TokenInfo::setType: switch (info.set) { case Syntax::digit: fragment = &ParserMessages::digit; break; case Syntax::nameStart: fragment = &ParserMessages::nameStartCharacter; break; case Syntax::sepchar: fragment = &ParserMessages::sepchar; break; case Syntax::s: fragment = &ParserMessages::separator; break; case Syntax::nmchar: fragment = &ParserMessages::nameCharacter; break; case Syntax::sgmlChar: fragment = &ParserMessages::dataCharacter; break; case Syntax::minimumData: fragment = &ParserMessages::minimumDataCharacter; break; case Syntax::significant: fragment = &ParserMessages::significantCharacter; break; default: CANNOT_HAPPEN(); } break; case TokenInfo::functionType: switch (info.function) { case Syntax::fRE: fragment = &ParserMessages::recordEnd; break; case Syntax::fRS: fragment = &ParserMessages::recordStart; break; case Syntax::fSPACE: fragment = &ParserMessages::space; break; } break; } break; } if (fragment) builder.appendFragment(*fragment); } #ifdef SP_NAMESPACE } #endif