<HTML ><HEAD ><TITLE >yaz_ccl_parse</TITLE ><META NAME="GENERATOR" CONTENT="Modular DocBook HTML Stylesheet Version 1.7"><LINK REL="HOME" TITLE="Manual de PHP" HREF="index.html"><LINK REL="UP" TITLE="YAZ" HREF="ref.yaz.html"><LINK REL="PREVIOUS" TITLE="yaz_ccl_conf" HREF="function.yaz-ccl-conf.html"><LINK REL="NEXT" TITLE="yaz_close" HREF="function.yaz-close.html"><META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=ISO-8859-1"></HEAD ><BODY CLASS="refentry" BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#840084" ALINK="#0000FF" ><DIV CLASS="NAVHEADER" ><TABLE SUMMARY="Header navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TH COLSPAN="3" ALIGN="center" >Manual de PHP</TH ></TR ><TR ><TD WIDTH="10%" ALIGN="left" VALIGN="bottom" ><A HREF="function.yaz-ccl-conf.html" ACCESSKEY="P" >Anterior</A ></TD ><TD WIDTH="80%" ALIGN="center" VALIGN="bottom" ></TD ><TD WIDTH="10%" ALIGN="right" VALIGN="bottom" ><A HREF="function.yaz-close.html" ACCESSKEY="N" >Siguiente</A ></TD ></TR ></TABLE ><HR ALIGN="LEFT" WIDTH="100%"></DIV ><H1 ><A NAME="function.yaz-ccl-parse" ></A >yaz_ccl_parse</H1 ><DIV CLASS="refnamediv" ><A NAME="AEN81418" ></A ><P > (PHP 4 >= 4.0.5)</P >yaz_ccl_parse -- Invoke CCL Parser</DIV ><DIV CLASS="refsect1" ><A NAME="AEN81421" ></A ><H2 >Description</H2 >int <B CLASS="methodname" >yaz_ccl_parse</B > ( resource id, string query, array & result)<BR ></BR ><P > This function invokes a CCL parser. It converts a given CCL FIND query to an RPN query which may be passed to the <A HREF="function.yaz-search.html" ><B CLASS="function" >yaz_search()</B ></A > function to perform a search. To define a set of valid CCL fields call <A HREF="function.yaz-ccl-conf.html" ><B CLASS="function" >yaz_ccl_conf()</B ></A > prior to this function. If the supplied <TT CLASS="parameter" ><I >query</I ></TT > was successfully converted to RPN, this function returns <TT CLASS="constant" ><B >TRUE</B ></TT >, and the index <TT CLASS="literal" >rpn</TT > of the supplied array <TT CLASS="parameter" ><I >result</I ></TT > holds a valid RPN query. If the query could not be converted (because of invalid syntax, unknown field, etc.) this function returns <TT CLASS="constant" ><B >FALSE</B ></TT > and three indexes are set in the resulting array to indicate the cause of failure: <TT CLASS="literal" >errorcode</TT >CCL error code (integer), <TT CLASS="literal" >errorstring</TT >CCL error string, and <TT CLASS="literal" >errorpos</TT >approximate position in query of failure (integer is character position). </P ><TABLE WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" CLASS="EXAMPLE" ><TR ><TD ><DIV CLASS="example" ><A NAME="AEN81446" ></A ><P ><B >Ejemplo 1. CCL Parsing</B ></P ><P >We'll try to search using CCL. In the example below, <TT CLASS="literal" >$ccl</TT > is a CCL query. </P ><TABLE BORDER="0" BGCOLOR="#E0E0E0" CELLPADDING="5" ><TR ><TD ><PRE CLASS="programlisting" >yaz_ccl_conf($id,$fields); // see example for yaz_ccl_conf if (!yaz_ccl_parse($id, $ccl, &$cclresult) { echo 'Error: ' . $cclresult["errorstring"]; } else { $rpn = $cclresult["rpn"]; yaz_search($id,"rpn",$rpn); }</PRE ></TD ></TR ></TABLE ></DIV ></TD ></TR ></TABLE ></DIV ><DIV CLASS="NAVFOOTER" ><HR ALIGN="LEFT" WIDTH="100%"><TABLE SUMMARY="Footer navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" ><A HREF="function.yaz-ccl-conf.html" ACCESSKEY="P" >Anterior</A ></TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="index.html" ACCESSKEY="H" >Inicio</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" ><A HREF="function.yaz-close.html" ACCESSKEY="N" >Siguiente</A ></TD ></TR ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" >yaz_ccl_conf</TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="ref.yaz.html" ACCESSKEY="U" >Subir</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" >yaz_close</TD ></TR ></TABLE ></DIV ></BODY ></HTML >