xref: /OK3568_Linux_fs/external/xserver/hw/xfree86/parser/Layout.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Copyright (c) 1997  Metro Link Incorporated
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * Permission is hereby granted, free of charge, to any person obtaining a
6*4882a593Smuzhiyun  * copy of this software and associated documentation files (the "Software"),
7*4882a593Smuzhiyun  * to deal in the Software without restriction, including without limitation
8*4882a593Smuzhiyun  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9*4882a593Smuzhiyun  * and/or sell copies of the Software, and to permit persons to whom the
10*4882a593Smuzhiyun  * Software is furnished to do so, subject to the following conditions:
11*4882a593Smuzhiyun  *
12*4882a593Smuzhiyun  * The above copyright notice and this permission notice shall be included in
13*4882a593Smuzhiyun  * all copies or substantial portions of the Software.
14*4882a593Smuzhiyun  *
15*4882a593Smuzhiyun  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*4882a593Smuzhiyun  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*4882a593Smuzhiyun  * THE X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
19*4882a593Smuzhiyun  * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
20*4882a593Smuzhiyun  * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*4882a593Smuzhiyun  * SOFTWARE.
22*4882a593Smuzhiyun  *
23*4882a593Smuzhiyun  * Except as contained in this notice, the name of the Metro Link shall not be
24*4882a593Smuzhiyun  * used in advertising or otherwise to promote the sale, use or other dealings
25*4882a593Smuzhiyun  * in this Software without prior written authorization from Metro Link.
26*4882a593Smuzhiyun  *
27*4882a593Smuzhiyun  */
28*4882a593Smuzhiyun /*
29*4882a593Smuzhiyun  * Copyright (c) 1997-2003 by The XFree86 Project, Inc.
30*4882a593Smuzhiyun  *
31*4882a593Smuzhiyun  * Permission is hereby granted, free of charge, to any person obtaining a
32*4882a593Smuzhiyun  * copy of this software and associated documentation files (the "Software"),
33*4882a593Smuzhiyun  * to deal in the Software without restriction, including without limitation
34*4882a593Smuzhiyun  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
35*4882a593Smuzhiyun  * and/or sell copies of the Software, and to permit persons to whom the
36*4882a593Smuzhiyun  * Software is furnished to do so, subject to the following conditions:
37*4882a593Smuzhiyun  *
38*4882a593Smuzhiyun  * The above copyright notice and this permission notice shall be included in
39*4882a593Smuzhiyun  * all copies or substantial portions of the Software.
40*4882a593Smuzhiyun  *
41*4882a593Smuzhiyun  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
42*4882a593Smuzhiyun  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
43*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
44*4882a593Smuzhiyun  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
45*4882a593Smuzhiyun  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
46*4882a593Smuzhiyun  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
47*4882a593Smuzhiyun  * OTHER DEALINGS IN THE SOFTWARE.
48*4882a593Smuzhiyun  *
49*4882a593Smuzhiyun  * Except as contained in this notice, the name of the copyright holder(s)
50*4882a593Smuzhiyun  * and author(s) shall not be used in advertising or otherwise to promote
51*4882a593Smuzhiyun  * the sale, use or other dealings in this Software without prior written
52*4882a593Smuzhiyun  * authorization from the copyright holder(s) and author(s).
53*4882a593Smuzhiyun  */
54*4882a593Smuzhiyun 
55*4882a593Smuzhiyun #ifdef HAVE_XORG_CONFIG_H
56*4882a593Smuzhiyun #include <xorg-config.h>
57*4882a593Smuzhiyun #endif
58*4882a593Smuzhiyun 
59*4882a593Smuzhiyun #include "xf86Parser.h"
60*4882a593Smuzhiyun #include "xf86tokens.h"
61*4882a593Smuzhiyun #include "Configint.h"
62*4882a593Smuzhiyun #include <string.h>
63*4882a593Smuzhiyun #include "optionstr.h"
64*4882a593Smuzhiyun 
65*4882a593Smuzhiyun /* Needed for auto server layout */
66*4882a593Smuzhiyun extern int xf86CheckBoolOption(void *optlist, const char *name, int deflt);
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun 
69*4882a593Smuzhiyun static const xf86ConfigSymTabRec LayoutTab[] = {
70*4882a593Smuzhiyun     {ENDSECTION, "endsection"},
71*4882a593Smuzhiyun     {SCREEN, "screen"},
72*4882a593Smuzhiyun     {IDENTIFIER, "identifier"},
73*4882a593Smuzhiyun     {MATCHSEAT, "matchseat"},
74*4882a593Smuzhiyun     {INACTIVE, "inactive"},
75*4882a593Smuzhiyun     {INPUTDEVICE, "inputdevice"},
76*4882a593Smuzhiyun     {OPTION, "option"},
77*4882a593Smuzhiyun     {-1, ""},
78*4882a593Smuzhiyun };
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun static const xf86ConfigSymTabRec AdjTab[] = {
81*4882a593Smuzhiyun     {RIGHTOF, "rightof"},
82*4882a593Smuzhiyun     {LEFTOF, "leftof"},
83*4882a593Smuzhiyun     {ABOVE, "above"},
84*4882a593Smuzhiyun     {BELOW, "below"},
85*4882a593Smuzhiyun     {RELATIVE, "relative"},
86*4882a593Smuzhiyun     {ABSOLUTE, "absolute"},
87*4882a593Smuzhiyun     {-1, ""},
88*4882a593Smuzhiyun };
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun #define CLEANUP xf86freeLayoutList
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun XF86ConfLayoutPtr
xf86parseLayoutSection(void)93*4882a593Smuzhiyun xf86parseLayoutSection(void)
94*4882a593Smuzhiyun {
95*4882a593Smuzhiyun     int has_ident = FALSE;
96*4882a593Smuzhiyun     int token;
97*4882a593Smuzhiyun 
98*4882a593Smuzhiyun     parsePrologue(XF86ConfLayoutPtr, XF86ConfLayoutRec)
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun         while ((token = xf86getToken(LayoutTab)) != ENDSECTION) {
101*4882a593Smuzhiyun         switch (token) {
102*4882a593Smuzhiyun         case COMMENT:
103*4882a593Smuzhiyun             ptr->lay_comment = xf86addComment(ptr->lay_comment, xf86_lex_val.str);
104*4882a593Smuzhiyun             break;
105*4882a593Smuzhiyun         case IDENTIFIER:
106*4882a593Smuzhiyun             if (xf86getSubToken(&(ptr->lay_comment)) != STRING)
107*4882a593Smuzhiyun                 Error(QUOTE_MSG, "Identifier");
108*4882a593Smuzhiyun             if (has_ident == TRUE)
109*4882a593Smuzhiyun                 Error(MULTIPLE_MSG, "Identifier");
110*4882a593Smuzhiyun             ptr->lay_identifier = xf86_lex_val.str;
111*4882a593Smuzhiyun             has_ident = TRUE;
112*4882a593Smuzhiyun             break;
113*4882a593Smuzhiyun         case MATCHSEAT:
114*4882a593Smuzhiyun             if (xf86getSubToken(&(ptr->lay_comment)) != STRING)
115*4882a593Smuzhiyun                 Error(QUOTE_MSG, "MatchSeat");
116*4882a593Smuzhiyun             ptr->match_seat = xf86_lex_val.str;
117*4882a593Smuzhiyun             break;
118*4882a593Smuzhiyun         case INACTIVE:
119*4882a593Smuzhiyun         {
120*4882a593Smuzhiyun             XF86ConfInactivePtr iptr;
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun             iptr = calloc(1, sizeof(XF86ConfInactiveRec));
123*4882a593Smuzhiyun             iptr->list.next = NULL;
124*4882a593Smuzhiyun             if (xf86getSubToken(&(ptr->lay_comment)) != STRING) {
125*4882a593Smuzhiyun                 free(iptr);
126*4882a593Smuzhiyun                 Error(INACTIVE_MSG);
127*4882a593Smuzhiyun             }
128*4882a593Smuzhiyun             iptr->inactive_device_str = xf86_lex_val.str;
129*4882a593Smuzhiyun             ptr->lay_inactive_lst = (XF86ConfInactivePtr)
130*4882a593Smuzhiyun                 xf86addListItem((glp) ptr->lay_inactive_lst, (glp) iptr);
131*4882a593Smuzhiyun         }
132*4882a593Smuzhiyun             break;
133*4882a593Smuzhiyun         case SCREEN:
134*4882a593Smuzhiyun         {
135*4882a593Smuzhiyun             XF86ConfAdjacencyPtr aptr;
136*4882a593Smuzhiyun             int absKeyword = 0;
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun             aptr = calloc(1, sizeof(XF86ConfAdjacencyRec));
139*4882a593Smuzhiyun             aptr->list.next = NULL;
140*4882a593Smuzhiyun             aptr->adj_scrnum = -1;
141*4882a593Smuzhiyun             aptr->adj_where = CONF_ADJ_OBSOLETE;
142*4882a593Smuzhiyun             aptr->adj_x = 0;
143*4882a593Smuzhiyun             aptr->adj_y = 0;
144*4882a593Smuzhiyun             aptr->adj_refscreen = NULL;
145*4882a593Smuzhiyun             if ((token = xf86getSubToken(&(ptr->lay_comment))) == NUMBER)
146*4882a593Smuzhiyun                 aptr->adj_scrnum = xf86_lex_val.num;
147*4882a593Smuzhiyun             else
148*4882a593Smuzhiyun                 xf86unGetToken(token);
149*4882a593Smuzhiyun             token = xf86getSubToken(&(ptr->lay_comment));
150*4882a593Smuzhiyun             if (token != STRING) {
151*4882a593Smuzhiyun                 free(aptr);
152*4882a593Smuzhiyun                 Error(SCREEN_MSG);
153*4882a593Smuzhiyun             }
154*4882a593Smuzhiyun             aptr->adj_screen_str = xf86_lex_val.str;
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun             token = xf86getSubTokenWithTab(&(ptr->lay_comment), AdjTab);
157*4882a593Smuzhiyun             switch (token) {
158*4882a593Smuzhiyun             case RIGHTOF:
159*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_RIGHTOF;
160*4882a593Smuzhiyun                 break;
161*4882a593Smuzhiyun             case LEFTOF:
162*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_LEFTOF;
163*4882a593Smuzhiyun                 break;
164*4882a593Smuzhiyun             case ABOVE:
165*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_ABOVE;
166*4882a593Smuzhiyun                 break;
167*4882a593Smuzhiyun             case BELOW:
168*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_BELOW;
169*4882a593Smuzhiyun                 break;
170*4882a593Smuzhiyun             case RELATIVE:
171*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_RELATIVE;
172*4882a593Smuzhiyun                 break;
173*4882a593Smuzhiyun             case ABSOLUTE:
174*4882a593Smuzhiyun                 aptr->adj_where = CONF_ADJ_ABSOLUTE;
175*4882a593Smuzhiyun                 absKeyword = 1;
176*4882a593Smuzhiyun                 break;
177*4882a593Smuzhiyun             case EOF_TOKEN:
178*4882a593Smuzhiyun                 free(aptr);
179*4882a593Smuzhiyun                 Error(UNEXPECTED_EOF_MSG);
180*4882a593Smuzhiyun                 break;
181*4882a593Smuzhiyun             default:
182*4882a593Smuzhiyun                 xf86unGetToken(token);
183*4882a593Smuzhiyun                 token = xf86getSubToken(&(ptr->lay_comment));
184*4882a593Smuzhiyun                 if (token == STRING)
185*4882a593Smuzhiyun                     aptr->adj_where = CONF_ADJ_OBSOLETE;
186*4882a593Smuzhiyun                 else
187*4882a593Smuzhiyun                     aptr->adj_where = CONF_ADJ_ABSOLUTE;
188*4882a593Smuzhiyun             }
189*4882a593Smuzhiyun             switch (aptr->adj_where) {
190*4882a593Smuzhiyun             case CONF_ADJ_ABSOLUTE:
191*4882a593Smuzhiyun                 if (absKeyword)
192*4882a593Smuzhiyun                     token = xf86getSubToken(&(ptr->lay_comment));
193*4882a593Smuzhiyun                 if (token == NUMBER) {
194*4882a593Smuzhiyun                     aptr->adj_x = xf86_lex_val.num;
195*4882a593Smuzhiyun                     token = xf86getSubToken(&(ptr->lay_comment));
196*4882a593Smuzhiyun                     if (token != NUMBER) {
197*4882a593Smuzhiyun                         free(aptr);
198*4882a593Smuzhiyun                         Error(INVALID_SCR_MSG);
199*4882a593Smuzhiyun                     }
200*4882a593Smuzhiyun                     aptr->adj_y = xf86_lex_val.num;
201*4882a593Smuzhiyun                 }
202*4882a593Smuzhiyun                 else {
203*4882a593Smuzhiyun                     if (absKeyword) {
204*4882a593Smuzhiyun                         free(aptr);
205*4882a593Smuzhiyun                         Error(INVALID_SCR_MSG);
206*4882a593Smuzhiyun                     }
207*4882a593Smuzhiyun                     else
208*4882a593Smuzhiyun                         xf86unGetToken(token);
209*4882a593Smuzhiyun                 }
210*4882a593Smuzhiyun                 break;
211*4882a593Smuzhiyun             case CONF_ADJ_RIGHTOF:
212*4882a593Smuzhiyun             case CONF_ADJ_LEFTOF:
213*4882a593Smuzhiyun             case CONF_ADJ_ABOVE:
214*4882a593Smuzhiyun             case CONF_ADJ_BELOW:
215*4882a593Smuzhiyun             case CONF_ADJ_RELATIVE:
216*4882a593Smuzhiyun                 token = xf86getSubToken(&(ptr->lay_comment));
217*4882a593Smuzhiyun                 if (token != STRING) {
218*4882a593Smuzhiyun                     free(aptr);
219*4882a593Smuzhiyun                     Error(INVALID_SCR_MSG);
220*4882a593Smuzhiyun                 }
221*4882a593Smuzhiyun                 aptr->adj_refscreen = xf86_lex_val.str;
222*4882a593Smuzhiyun                 if (aptr->adj_where == CONF_ADJ_RELATIVE) {
223*4882a593Smuzhiyun                     token = xf86getSubToken(&(ptr->lay_comment));
224*4882a593Smuzhiyun                     if (token != NUMBER) {
225*4882a593Smuzhiyun                         free(aptr);
226*4882a593Smuzhiyun                         Error(INVALID_SCR_MSG);
227*4882a593Smuzhiyun                     }
228*4882a593Smuzhiyun                     aptr->adj_x = xf86_lex_val.num;
229*4882a593Smuzhiyun                     token = xf86getSubToken(&(ptr->lay_comment));
230*4882a593Smuzhiyun                     if (token != NUMBER) {
231*4882a593Smuzhiyun                         free(aptr);
232*4882a593Smuzhiyun                         Error(INVALID_SCR_MSG);
233*4882a593Smuzhiyun                     }
234*4882a593Smuzhiyun                     aptr->adj_y = xf86_lex_val.num;
235*4882a593Smuzhiyun                 }
236*4882a593Smuzhiyun                 break;
237*4882a593Smuzhiyun             case CONF_ADJ_OBSOLETE:
238*4882a593Smuzhiyun                 /* top */
239*4882a593Smuzhiyun                 aptr->adj_top_str = xf86_lex_val.str;
240*4882a593Smuzhiyun 
241*4882a593Smuzhiyun                 /* bottom */
242*4882a593Smuzhiyun                 if (xf86getSubToken(&(ptr->lay_comment)) != STRING) {
243*4882a593Smuzhiyun                     free(aptr);
244*4882a593Smuzhiyun                     Error(SCREEN_MSG);
245*4882a593Smuzhiyun                 }
246*4882a593Smuzhiyun                 aptr->adj_bottom_str = xf86_lex_val.str;
247*4882a593Smuzhiyun 
248*4882a593Smuzhiyun                 /* left */
249*4882a593Smuzhiyun                 if (xf86getSubToken(&(ptr->lay_comment)) != STRING) {
250*4882a593Smuzhiyun                     free(aptr);
251*4882a593Smuzhiyun                     Error(SCREEN_MSG);
252*4882a593Smuzhiyun                 }
253*4882a593Smuzhiyun                 aptr->adj_left_str = xf86_lex_val.str;
254*4882a593Smuzhiyun 
255*4882a593Smuzhiyun                 /* right */
256*4882a593Smuzhiyun                 if (xf86getSubToken(&(ptr->lay_comment)) != STRING) {
257*4882a593Smuzhiyun                     free(aptr);
258*4882a593Smuzhiyun                     Error(SCREEN_MSG);
259*4882a593Smuzhiyun                 }
260*4882a593Smuzhiyun                 aptr->adj_right_str = xf86_lex_val.str;
261*4882a593Smuzhiyun 
262*4882a593Smuzhiyun             }
263*4882a593Smuzhiyun             ptr->lay_adjacency_lst = (XF86ConfAdjacencyPtr)
264*4882a593Smuzhiyun                 xf86addListItem((glp) ptr->lay_adjacency_lst, (glp) aptr);
265*4882a593Smuzhiyun         }
266*4882a593Smuzhiyun             break;
267*4882a593Smuzhiyun         case INPUTDEVICE:
268*4882a593Smuzhiyun         {
269*4882a593Smuzhiyun             XF86ConfInputrefPtr iptr;
270*4882a593Smuzhiyun 
271*4882a593Smuzhiyun             iptr = calloc(1, sizeof(XF86ConfInputrefRec));
272*4882a593Smuzhiyun             iptr->list.next = NULL;
273*4882a593Smuzhiyun             iptr->iref_option_lst = NULL;
274*4882a593Smuzhiyun             if (xf86getSubToken(&(ptr->lay_comment)) != STRING) {
275*4882a593Smuzhiyun                 free(iptr);
276*4882a593Smuzhiyun                 Error(INPUTDEV_MSG);
277*4882a593Smuzhiyun             }
278*4882a593Smuzhiyun             iptr->iref_inputdev_str = xf86_lex_val.str;
279*4882a593Smuzhiyun             while ((token = xf86getSubToken(&(ptr->lay_comment))) == STRING) {
280*4882a593Smuzhiyun                 iptr->iref_option_lst =
281*4882a593Smuzhiyun                     xf86addNewOption(iptr->iref_option_lst, xf86_lex_val.str, NULL);
282*4882a593Smuzhiyun             }
283*4882a593Smuzhiyun             xf86unGetToken(token);
284*4882a593Smuzhiyun             ptr->lay_input_lst = (XF86ConfInputrefPtr)
285*4882a593Smuzhiyun                 xf86addListItem((glp) ptr->lay_input_lst, (glp) iptr);
286*4882a593Smuzhiyun         }
287*4882a593Smuzhiyun             break;
288*4882a593Smuzhiyun         case OPTION:
289*4882a593Smuzhiyun             ptr->lay_option_lst = xf86parseOption(ptr->lay_option_lst);
290*4882a593Smuzhiyun             break;
291*4882a593Smuzhiyun         case EOF_TOKEN:
292*4882a593Smuzhiyun             Error(UNEXPECTED_EOF_MSG);
293*4882a593Smuzhiyun             break;
294*4882a593Smuzhiyun         default:
295*4882a593Smuzhiyun             Error(INVALID_KEYWORD_MSG, xf86tokenString());
296*4882a593Smuzhiyun             break;
297*4882a593Smuzhiyun         }
298*4882a593Smuzhiyun     }
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun     if (!has_ident)
301*4882a593Smuzhiyun         Error(NO_IDENT_MSG);
302*4882a593Smuzhiyun 
303*4882a593Smuzhiyun #ifdef DEBUG
304*4882a593Smuzhiyun     printf("Layout section parsed\n");
305*4882a593Smuzhiyun #endif
306*4882a593Smuzhiyun 
307*4882a593Smuzhiyun     return ptr;
308*4882a593Smuzhiyun }
309*4882a593Smuzhiyun 
310*4882a593Smuzhiyun #undef CLEANUP
311*4882a593Smuzhiyun 
312*4882a593Smuzhiyun void
xf86printLayoutSection(FILE * cf,XF86ConfLayoutPtr ptr)313*4882a593Smuzhiyun xf86printLayoutSection(FILE * cf, XF86ConfLayoutPtr ptr)
314*4882a593Smuzhiyun {
315*4882a593Smuzhiyun     XF86ConfAdjacencyPtr aptr;
316*4882a593Smuzhiyun     XF86ConfInactivePtr iptr;
317*4882a593Smuzhiyun     XF86ConfInputrefPtr inptr;
318*4882a593Smuzhiyun     XF86OptionPtr optr;
319*4882a593Smuzhiyun 
320*4882a593Smuzhiyun     while (ptr) {
321*4882a593Smuzhiyun         fprintf(cf, "Section \"ServerLayout\"\n");
322*4882a593Smuzhiyun         if (ptr->lay_comment)
323*4882a593Smuzhiyun             fprintf(cf, "%s", ptr->lay_comment);
324*4882a593Smuzhiyun         if (ptr->lay_identifier)
325*4882a593Smuzhiyun             fprintf(cf, "\tIdentifier     \"%s\"\n", ptr->lay_identifier);
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun         for (aptr = ptr->lay_adjacency_lst; aptr; aptr = aptr->list.next) {
328*4882a593Smuzhiyun             fprintf(cf, "\tScreen     ");
329*4882a593Smuzhiyun             if (aptr->adj_scrnum >= 0)
330*4882a593Smuzhiyun                 fprintf(cf, "%2d", aptr->adj_scrnum);
331*4882a593Smuzhiyun             else
332*4882a593Smuzhiyun                 fprintf(cf, "  ");
333*4882a593Smuzhiyun             fprintf(cf, "  \"%s\"", aptr->adj_screen_str);
334*4882a593Smuzhiyun             switch (aptr->adj_where) {
335*4882a593Smuzhiyun             case CONF_ADJ_OBSOLETE:
336*4882a593Smuzhiyun                 fprintf(cf, " \"%s\"", aptr->adj_top_str);
337*4882a593Smuzhiyun                 fprintf(cf, " \"%s\"", aptr->adj_bottom_str);
338*4882a593Smuzhiyun                 fprintf(cf, " \"%s\"", aptr->adj_right_str);
339*4882a593Smuzhiyun                 fprintf(cf, " \"%s\"\n", aptr->adj_left_str);
340*4882a593Smuzhiyun                 break;
341*4882a593Smuzhiyun             case CONF_ADJ_ABSOLUTE:
342*4882a593Smuzhiyun                 if (aptr->adj_x != -1)
343*4882a593Smuzhiyun                     fprintf(cf, " %d %d\n", aptr->adj_x, aptr->adj_y);
344*4882a593Smuzhiyun                 else
345*4882a593Smuzhiyun                     fprintf(cf, "\n");
346*4882a593Smuzhiyun                 break;
347*4882a593Smuzhiyun             case CONF_ADJ_RIGHTOF:
348*4882a593Smuzhiyun                 fprintf(cf, " RightOf \"%s\"\n", aptr->adj_refscreen);
349*4882a593Smuzhiyun                 break;
350*4882a593Smuzhiyun             case CONF_ADJ_LEFTOF:
351*4882a593Smuzhiyun                 fprintf(cf, " LeftOf \"%s\"\n", aptr->adj_refscreen);
352*4882a593Smuzhiyun                 break;
353*4882a593Smuzhiyun             case CONF_ADJ_ABOVE:
354*4882a593Smuzhiyun                 fprintf(cf, " Above \"%s\"\n", aptr->adj_refscreen);
355*4882a593Smuzhiyun                 break;
356*4882a593Smuzhiyun             case CONF_ADJ_BELOW:
357*4882a593Smuzhiyun                 fprintf(cf, " Below \"%s\"\n", aptr->adj_refscreen);
358*4882a593Smuzhiyun                 break;
359*4882a593Smuzhiyun             case CONF_ADJ_RELATIVE:
360*4882a593Smuzhiyun                 fprintf(cf, " Relative \"%s\" %d %d\n", aptr->adj_refscreen,
361*4882a593Smuzhiyun                         aptr->adj_x, aptr->adj_y);
362*4882a593Smuzhiyun                 break;
363*4882a593Smuzhiyun             }
364*4882a593Smuzhiyun         }
365*4882a593Smuzhiyun         for (iptr = ptr->lay_inactive_lst; iptr; iptr = iptr->list.next)
366*4882a593Smuzhiyun             fprintf(cf, "\tInactive       \"%s\"\n", iptr->inactive_device_str);
367*4882a593Smuzhiyun         for (inptr = ptr->lay_input_lst; inptr; inptr = inptr->list.next) {
368*4882a593Smuzhiyun             fprintf(cf, "\tInputDevice    \"%s\"", inptr->iref_inputdev_str);
369*4882a593Smuzhiyun             for (optr = inptr->iref_option_lst; optr; optr = optr->list.next) {
370*4882a593Smuzhiyun                 fprintf(cf, " \"%s\"", optr->opt_name);
371*4882a593Smuzhiyun             }
372*4882a593Smuzhiyun             fprintf(cf, "\n");
373*4882a593Smuzhiyun         }
374*4882a593Smuzhiyun         xf86printOptionList(cf, ptr->lay_option_lst, 1);
375*4882a593Smuzhiyun         fprintf(cf, "EndSection\n\n");
376*4882a593Smuzhiyun         ptr = ptr->list.next;
377*4882a593Smuzhiyun     }
378*4882a593Smuzhiyun }
379*4882a593Smuzhiyun 
380*4882a593Smuzhiyun static void
xf86freeAdjacencyList(XF86ConfAdjacencyPtr ptr)381*4882a593Smuzhiyun xf86freeAdjacencyList(XF86ConfAdjacencyPtr ptr)
382*4882a593Smuzhiyun {
383*4882a593Smuzhiyun     XF86ConfAdjacencyPtr prev;
384*4882a593Smuzhiyun 
385*4882a593Smuzhiyun     while (ptr) {
386*4882a593Smuzhiyun         TestFree(ptr->adj_screen_str);
387*4882a593Smuzhiyun         TestFree(ptr->adj_top_str);
388*4882a593Smuzhiyun         TestFree(ptr->adj_bottom_str);
389*4882a593Smuzhiyun         TestFree(ptr->adj_left_str);
390*4882a593Smuzhiyun         TestFree(ptr->adj_right_str);
391*4882a593Smuzhiyun 
392*4882a593Smuzhiyun         prev = ptr;
393*4882a593Smuzhiyun         ptr = ptr->list.next;
394*4882a593Smuzhiyun         free(prev);
395*4882a593Smuzhiyun     }
396*4882a593Smuzhiyun 
397*4882a593Smuzhiyun }
398*4882a593Smuzhiyun 
399*4882a593Smuzhiyun static void
xf86freeInputrefList(XF86ConfInputrefPtr ptr)400*4882a593Smuzhiyun xf86freeInputrefList(XF86ConfInputrefPtr ptr)
401*4882a593Smuzhiyun {
402*4882a593Smuzhiyun     XF86ConfInputrefPtr prev;
403*4882a593Smuzhiyun 
404*4882a593Smuzhiyun     while (ptr) {
405*4882a593Smuzhiyun         TestFree(ptr->iref_inputdev_str);
406*4882a593Smuzhiyun         xf86optionListFree(ptr->iref_option_lst);
407*4882a593Smuzhiyun         prev = ptr;
408*4882a593Smuzhiyun         ptr = ptr->list.next;
409*4882a593Smuzhiyun         free(prev);
410*4882a593Smuzhiyun     }
411*4882a593Smuzhiyun 
412*4882a593Smuzhiyun }
413*4882a593Smuzhiyun 
414*4882a593Smuzhiyun void
xf86freeLayoutList(XF86ConfLayoutPtr ptr)415*4882a593Smuzhiyun xf86freeLayoutList(XF86ConfLayoutPtr ptr)
416*4882a593Smuzhiyun {
417*4882a593Smuzhiyun     XF86ConfLayoutPtr prev;
418*4882a593Smuzhiyun 
419*4882a593Smuzhiyun     while (ptr) {
420*4882a593Smuzhiyun         TestFree(ptr->lay_identifier);
421*4882a593Smuzhiyun         TestFree(ptr->lay_comment);
422*4882a593Smuzhiyun         xf86freeAdjacencyList(ptr->lay_adjacency_lst);
423*4882a593Smuzhiyun         xf86freeInputrefList(ptr->lay_input_lst);
424*4882a593Smuzhiyun         prev = ptr;
425*4882a593Smuzhiyun         ptr = ptr->list.next;
426*4882a593Smuzhiyun         free(prev);
427*4882a593Smuzhiyun     }
428*4882a593Smuzhiyun }
429*4882a593Smuzhiyun 
430*4882a593Smuzhiyun int
xf86layoutAddInputDevices(XF86ConfigPtr config,XF86ConfLayoutPtr layout)431*4882a593Smuzhiyun xf86layoutAddInputDevices(XF86ConfigPtr config, XF86ConfLayoutPtr layout)
432*4882a593Smuzhiyun {
433*4882a593Smuzhiyun     int count = 0;
434*4882a593Smuzhiyun     XF86ConfInputPtr input = config->conf_input_lst;
435*4882a593Smuzhiyun     XF86ConfInputrefPtr inptr;
436*4882a593Smuzhiyun 
437*4882a593Smuzhiyun     /* add all AutoServerLayout devices to the server layout */
438*4882a593Smuzhiyun     while (input) {
439*4882a593Smuzhiyun         if (xf86CheckBoolOption
440*4882a593Smuzhiyun             (input->inp_option_lst, "AutoServerLayout", FALSE)) {
441*4882a593Smuzhiyun             XF86ConfInputrefPtr iref = layout->lay_input_lst;
442*4882a593Smuzhiyun 
443*4882a593Smuzhiyun             /* avoid duplicates if referenced but lists AutoServerLayout too */
444*4882a593Smuzhiyun             while (iref) {
445*4882a593Smuzhiyun                 if (strcmp(iref->iref_inputdev_str, input->inp_identifier) == 0)
446*4882a593Smuzhiyun                     break;
447*4882a593Smuzhiyun                 iref = iref->list.next;
448*4882a593Smuzhiyun             }
449*4882a593Smuzhiyun 
450*4882a593Smuzhiyun             if (!iref) {
451*4882a593Smuzhiyun                 XF86ConfInputrefPtr iptr;
452*4882a593Smuzhiyun 
453*4882a593Smuzhiyun                 iptr = calloc(1, sizeof(XF86ConfInputrefRec));
454*4882a593Smuzhiyun                 iptr->iref_inputdev_str = input->inp_identifier;
455*4882a593Smuzhiyun                 layout->lay_input_lst = (XF86ConfInputrefPtr)
456*4882a593Smuzhiyun                     xf86addListItem((glp) layout->lay_input_lst, (glp) iptr);
457*4882a593Smuzhiyun                 count++;
458*4882a593Smuzhiyun             }
459*4882a593Smuzhiyun         }
460*4882a593Smuzhiyun         input = input->list.next;
461*4882a593Smuzhiyun     }
462*4882a593Smuzhiyun 
463*4882a593Smuzhiyun     inptr = layout->lay_input_lst;
464*4882a593Smuzhiyun     while (inptr) {
465*4882a593Smuzhiyun         input = xf86findInput(inptr->iref_inputdev_str, config->conf_input_lst);
466*4882a593Smuzhiyun         if (!input) {
467*4882a593Smuzhiyun             xf86validationError(UNDEFINED_INPUT_MSG,
468*4882a593Smuzhiyun                                 inptr->iref_inputdev_str,
469*4882a593Smuzhiyun                                 layout->lay_identifier);
470*4882a593Smuzhiyun             return -1;
471*4882a593Smuzhiyun         }
472*4882a593Smuzhiyun         else
473*4882a593Smuzhiyun             inptr->iref_inputdev = input;
474*4882a593Smuzhiyun         inptr = inptr->list.next;
475*4882a593Smuzhiyun     }
476*4882a593Smuzhiyun 
477*4882a593Smuzhiyun     return count;
478*4882a593Smuzhiyun }
479*4882a593Smuzhiyun 
480*4882a593Smuzhiyun int
xf86validateLayout(XF86ConfigPtr p)481*4882a593Smuzhiyun xf86validateLayout(XF86ConfigPtr p)
482*4882a593Smuzhiyun {
483*4882a593Smuzhiyun     XF86ConfLayoutPtr layout = p->conf_layout_lst;
484*4882a593Smuzhiyun     XF86ConfAdjacencyPtr adj;
485*4882a593Smuzhiyun     XF86ConfInactivePtr iptr;
486*4882a593Smuzhiyun     XF86ConfScreenPtr screen;
487*4882a593Smuzhiyun     XF86ConfDevicePtr device;
488*4882a593Smuzhiyun 
489*4882a593Smuzhiyun     while (layout) {
490*4882a593Smuzhiyun         adj = layout->lay_adjacency_lst;
491*4882a593Smuzhiyun         while (adj) {
492*4882a593Smuzhiyun             /* the first one can't be "" but all others can */
493*4882a593Smuzhiyun             screen = xf86findScreen(adj->adj_screen_str, p->conf_screen_lst);
494*4882a593Smuzhiyun             if (!screen) {
495*4882a593Smuzhiyun                 xf86validationError(UNDEFINED_SCREEN_MSG,
496*4882a593Smuzhiyun                                     adj->adj_screen_str,
497*4882a593Smuzhiyun                                     layout->lay_identifier);
498*4882a593Smuzhiyun                 return FALSE;
499*4882a593Smuzhiyun             }
500*4882a593Smuzhiyun             else
501*4882a593Smuzhiyun                 adj->adj_screen = screen;
502*4882a593Smuzhiyun 
503*4882a593Smuzhiyun             adj = adj->list.next;
504*4882a593Smuzhiyun         }
505*4882a593Smuzhiyun         iptr = layout->lay_inactive_lst;
506*4882a593Smuzhiyun         while (iptr) {
507*4882a593Smuzhiyun             device = xf86findDevice(iptr->inactive_device_str,
508*4882a593Smuzhiyun                                     p->conf_device_lst);
509*4882a593Smuzhiyun             if (!device) {
510*4882a593Smuzhiyun                 xf86validationError(UNDEFINED_DEVICE_LAY_MSG,
511*4882a593Smuzhiyun                                     iptr->inactive_device_str,
512*4882a593Smuzhiyun                                     layout->lay_identifier);
513*4882a593Smuzhiyun                 return FALSE;
514*4882a593Smuzhiyun             }
515*4882a593Smuzhiyun             else
516*4882a593Smuzhiyun                 iptr->inactive_device = device;
517*4882a593Smuzhiyun             iptr = iptr->list.next;
518*4882a593Smuzhiyun         }
519*4882a593Smuzhiyun 
520*4882a593Smuzhiyun         if (xf86layoutAddInputDevices(p, layout) == -1)
521*4882a593Smuzhiyun             return FALSE;
522*4882a593Smuzhiyun 
523*4882a593Smuzhiyun         layout = layout->list.next;
524*4882a593Smuzhiyun     }
525*4882a593Smuzhiyun     return TRUE;
526*4882a593Smuzhiyun }
527*4882a593Smuzhiyun 
528*4882a593Smuzhiyun XF86ConfLayoutPtr
xf86findLayout(const char * name,XF86ConfLayoutPtr list)529*4882a593Smuzhiyun xf86findLayout(const char *name, XF86ConfLayoutPtr list)
530*4882a593Smuzhiyun {
531*4882a593Smuzhiyun     while (list) {
532*4882a593Smuzhiyun         if (xf86nameCompare(list->lay_identifier, name) == 0)
533*4882a593Smuzhiyun             return list;
534*4882a593Smuzhiyun         list = list->list.next;
535*4882a593Smuzhiyun     }
536*4882a593Smuzhiyun     return NULL;
537*4882a593Smuzhiyun }
538