Add GNU LGPL headers to all .c .C and .h files
[oweals/cde.git] / cde / programs / nsgmls / TokenMessageArg.C
1 /*
2  * CDE - Common Desktop Environment
3  *
4  * Copyright (c) 1993-2012, The Open Group. All rights reserved.
5  *
6  * These libraries and programs are free software; you can
7  * redistribute them and/or modify them under the terms of the GNU
8  * Lesser General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option)
10  * any later version.
11  *
12  * These libraries and programs are distributed in the hope that
13  * they will be useful, but WITHOUT ANY WARRANTY; without even the
14  * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15  * PURPOSE. See the GNU Lesser General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with these librararies and programs; if not, write
20  * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21  * Floor, Boston, MA 02110-1301 USA
22  */
23 /* $XConsortium: TokenMessageArg.C /main/1 1996/07/29 17:06:18 cde-hp $ */
24 // Copyright (c) 1994 James Clark
25 // See the file COPYING for copying permission.
26
27 #ifdef __GNUG__
28 #pragma implementation
29 #endif
30 #include "splib.h"
31 #include "TokenMessageArg.h"
32 #include "MessageBuilder.h"
33 #include "token.h"
34 #include "ParserMessages.h"
35 #include "Mode.h"
36 #include "ModeInfo.h"
37 #include "macros.h"
38
39 #ifdef SP_NAMESPACE
40 namespace SP_NAMESPACE {
41 #endif
42
43 TokenMessageArg::TokenMessageArg(Token token, Mode mode,
44                                  const ConstPtr<Syntax> &syntax,
45                                  const ConstPtr<Sd> &sd)
46 : token_(token), mode_(mode), syntax_(syntax), sd_(sd)
47 {
48 }
49
50 MessageArg *TokenMessageArg::copy() const
51 {
52   return new TokenMessageArg(*this);
53 }
54
55 void TokenMessageArg::append(MessageBuilder &builder) const
56 {
57   // FIXME translate function characters in delimiters into
58   // &#NAME; form.
59   if (token_ >= tokenFirstShortref) {
60     builder.appendFragment(ParserMessages::shortrefDelim);
61     return;
62   }
63   if (token_ == tokenEe) {
64     builder.appendFragment(ParserMessages::entityEnd);
65     return;
66   }
67   ModeInfo iter(mode_, *sd_);
68   TokenInfo info;
69   const MessageFragment *fragment = 0;
70   while (iter.nextToken(&info))
71     if (info.token == token_) {
72       switch (info.type) {
73       case TokenInfo::delimType:
74       case TokenInfo::delimDelimType:
75       case TokenInfo::delimSetType:
76         {
77           const StringC &delim = syntax_->delimGeneral(info.delim1);
78           builder.appendFragment(ParserMessages::delimStart);
79           builder.appendChars(delim.data(), delim.size());
80           fragment = &ParserMessages::delimEnd;
81         }
82         break;
83       case TokenInfo::setType:
84         switch (info.set) {
85         case Syntax::digit:
86           fragment = &ParserMessages::digit;
87           break;
88         case Syntax::nameStart:
89           fragment = &ParserMessages::nameStartCharacter;
90           break;
91         case Syntax::sepchar:
92           fragment = &ParserMessages::sepchar;
93           break;
94         case Syntax::s:
95           fragment = &ParserMessages::separator;
96           break;
97         case Syntax::nmchar:
98           fragment = &ParserMessages::nameCharacter;
99           break;
100         case Syntax::sgmlChar:
101           fragment = &ParserMessages::dataCharacter;
102           break;
103         case Syntax::minimumData:
104           fragment = &ParserMessages::minimumDataCharacter;
105           break;
106         case Syntax::significant:
107           fragment = &ParserMessages::significantCharacter;
108           break;
109         default:
110           CANNOT_HAPPEN();
111         }
112         break;
113       case TokenInfo::functionType:
114         switch (info.function) {
115         case Syntax::fRE:
116           fragment = &ParserMessages::recordEnd;
117           break;
118         case Syntax::fRS:
119           fragment = &ParserMessages::recordStart;
120           break;
121         case Syntax::fSPACE:
122           fragment = &ParserMessages::space;
123           break;
124         }
125         break;
126       }
127       break;
128     }
129   if (fragment)
130     builder.appendFragment(*fragment);
131 }
132
133 #ifdef SP_NAMESPACE
134 }
135 #endif