Initial import of the CDE 2.1.30 sources from the Open Group.
This commit is contained in:
77
cde/programs/dthelp/parser/canon1/parser/findpar.c
Normal file
77
cde/programs/dthelp/parser/canon1/parser/findpar.c
Normal file
@@ -0,0 +1,77 @@
|
||||
/* $XConsortium: findpar.c /main/3 1995/11/08 09:37:18 rswiston $ */
|
||||
/*
|
||||
Copyright 1989 Hewlett-Packard Co.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include "basic.h"
|
||||
#include "trie.h"
|
||||
#include "dtdext.h"
|
||||
#include "parser.h"
|
||||
|
||||
/* Function callable by interface designers. Returns index in parameter
|
||||
list of a specified parameter for an element (i.e., 1 for first parameter
|
||||
specified in the DTD, 2 for second, etc.). First parameter, elt, is
|
||||
the name of the element. Second parameter is the name of the parameter
|
||||
or NULL. Third parameter is used only if second parameter is NULL. In
|
||||
the latter case, function returns first keyword parameter, if any, for
|
||||
which the specified value is a legal value and otherwise first
|
||||
Returns 0 if elt is not a valid element name, if param is specified
|
||||
but is not a valid parameter name, or if param is NULL and value is
|
||||
not a valid value of any of elt's parameters. */
|
||||
#if defined(M_PROTO)
|
||||
int m_findpar( const char *elt , const char *param , const M_WCHAR *value )
|
||||
#else
|
||||
int m_findpar(elt, param, value)
|
||||
char *elt ;
|
||||
char *param ;
|
||||
M_WCHAR *value ;
|
||||
#endif /* M_PROTO */
|
||||
{
|
||||
M_ELEMENT eltid ;
|
||||
int par ;
|
||||
int i ;
|
||||
M_WCHAR *wc_elt;
|
||||
|
||||
wc_elt = MakeWideCharString(elt);
|
||||
if (! (eltid = m_packedlook(m_entree, wc_elt)))
|
||||
{
|
||||
m_free(wc_elt,"wide character string");
|
||||
return(M_NULLVAL) ;
|
||||
}
|
||||
m_free(wc_elt,"wide character string");
|
||||
|
||||
/* A parameter name specified */
|
||||
if (param)
|
||||
{
|
||||
for (par = m_element[eltid - 1].parptr, i = 1 ;
|
||||
|
||||
i <= m_element[eltid - 1].parcount ;
|
||||
par++, i++)
|
||||
if (!m_wcmbupstrcmp(&m_pname[m_parameter[par - 1].paramname], param))
|
||||
return(i) ;
|
||||
return(M_NULLVAL) ;
|
||||
}
|
||||
|
||||
/* No parameter name specified */
|
||||
|
||||
/* First check is it a valid keyword? */
|
||||
for (par = m_element[eltid - 1].parptr, i = 1 ;
|
||||
i <= m_element[eltid - 1].parcount ;
|
||||
par++, i++)
|
||||
if (m_parameter[par - 1].type == M_KEYWORD)
|
||||
if (m_partype(par, value)) return(i) ;
|
||||
|
||||
/* It wasn't a keyword. Check for valid value for some other parameter.*/
|
||||
for (par = m_element[eltid - 1].parptr, i = 1 ;
|
||||
i <= m_element[eltid - 1].parcount ;
|
||||
par++, i++)
|
||||
{
|
||||
if (m_parameter[par - 1].type == M_KEYWORD) continue ;
|
||||
if (m_partype(par, value)) return(i) ;
|
||||
}
|
||||
|
||||
/* Not a valid value for any parameter */
|
||||
return(M_NULLVAL) ;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user