Sophie

Sophie

distrib > Fedora > 14 > x86_64 > media > updates > by-pkgid > 0b420d0fce195cf4115dc6a3be5c2da2 > files > 256

sphinxbase-devel-0.7-1.fc14.i686.rpm

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<title>SphinxBase: src/libsphinxbase/lm/jsgf.c File Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<!-- Generated by Doxygen 1.7.3 -->
<div id="top">
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">SphinxBase&#160;<span id="projectnumber">0.6</span></div>
  </td>
 </tr>
 </tbody>
</table>
</div>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
      <li class="current"><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="files.html"><span>File&#160;List</span></a></li>
      <li><a href="globals.html"><span>Globals</span></a></li>
    </ul>
  </div>
</div>
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
  initNavTree('jsgf_8c.html','');
</script>
<div id="doc-content">
<div class="header">
  <div class="summary">
<a href="#func-members">Functions</a>  </div>
  <div class="headertitle">
<h1>src/libsphinxbase/lm/jsgf.c File Reference</h1>  </div>
</div>
<div class="contents">

<p>This file implements the data structures for parsing JSGF grammars into Sphinx finite-state grammars.  
<a href="#_details">More...</a></p>
<div class="textblock"><code>#include &lt;string.h&gt;</code><br/>
<code>#include &lt;assert.h&gt;</code><br/>
<code>#include &quot;sphinxbase/ckd_alloc.h&quot;</code><br/>
<code>#include &quot;sphinxbase/strfuncs.h&quot;</code><br/>
<code>#include &quot;sphinxbase/hash_table.h&quot;</code><br/>
<code>#include &quot;sphinxbase/err.h&quot;</code><br/>
<code>#include &quot;<a class="el" href="jsgf__internal_8h_source.html">jsgf_internal.h</a>&quot;</code><br/>
<code>#include &quot;jsgf_parser.h&quot;</code><br/>
<code>#include &quot;jsgf_scanner.h&quot;</code><br/>
</div>
<p><a href="jsgf_8c_source.html">Go to the source code of this file.</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="func-members"></a>
Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a75c2c883229f33d81c1a9531e6e75f16"></a><!-- doxytag: member="jsgf.c::yyparse" ref="a75c2c883229f33d81c1a9531e6e75f16" args="(yyscan_t yyscanner, jsgf_t *jsgf)" -->
int&#160;</td><td class="memItemRight" valign="bottom"><b>yyparse</b> (yyscan_t yyscanner, <a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0e59b63784fa8761358bb2bdf568bec1"></a><!-- doxytag: member="jsgf.c::jsgf_atom_new" ref="a0e59b63784fa8761358bb2bdf568bec1" args="(char *name, float weight)" -->
<a class="el" href="structjsgf__atom__s.html">jsgf_atom_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_atom_new</b> (char *name, float weight)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a289d683bf62d1a5aaac6917fa64f54f2"></a><!-- doxytag: member="jsgf.c::jsgf_atom_free" ref="a289d683bf62d1a5aaac6917fa64f54f2" args="(jsgf_atom_t *atom)" -->
int&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_atom_free</b> (<a class="el" href="structjsgf__atom__s.html">jsgf_atom_t</a> *atom)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a2f4a4ef97090210de6c73361de1d9561">jsgf_grammar_new</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *parent)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Create a new JSGF grammar.  <a href="#a2f4a4ef97090210de6c73361de1d9561"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a0a5185af0b0f1c19d85ae553c5ecc51b"></a><!-- doxytag: member="jsgf.c::jsgf_grammar_free" ref="a0a5185af0b0f1c19d85ae553c5ecc51b" args="(jsgf_t *jsgf)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a0a5185af0b0f1c19d85ae553c5ecc51b">jsgf_grammar_free</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Free a JSGF grammar. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ab9dc2ab39224cda76c43822150cf7e67"></a><!-- doxytag: member="jsgf.c::jsgf_kleene_new" ref="ab9dc2ab39224cda76c43822150cf7e67" args="(jsgf_t *jsgf, jsgf_atom_t *atom, int plus)" -->
<a class="el" href="structjsgf__atom__s.html">jsgf_atom_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_kleene_new</b> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf, <a class="el" href="structjsgf__atom__s.html">jsgf_atom_t</a> *atom, int plus)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a4a07cb0721add8783f0ea24dfacd6c0f"></a><!-- doxytag: member="jsgf.c::jsgf_optional_new" ref="a4a07cb0721add8783f0ea24dfacd6c0f" args="(jsgf_t *jsgf, jsgf_rhs_t *exp)" -->
<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_optional_new</b> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf, <a class="el" href="structjsgf__rhs__s.html">jsgf_rhs_t</a> *exp)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="acb5af4a04abc56a8584eba9b937f8154"></a><!-- doxytag: member="jsgf.c::jsgf_add_link" ref="acb5af4a04abc56a8584eba9b937f8154" args="(jsgf_t *grammar, jsgf_atom_t *atom, int from, int to)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_add_link</b> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar, <a class="el" href="structjsgf__atom__s.html">jsgf_atom_t</a> *atom, int from, int to)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afd426d7e3799f54b4d5c0acff7684233"></a><!-- doxytag: member="jsgf.c::jsgf_rule_iter" ref="afd426d7e3799f54b4d5c0acff7684233" args="(jsgf_t *grammar)" -->
<a class="el" href="structhash__iter__s.html">jsgf_rule_iter_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#afd426d7e3799f54b4d5c0acff7684233">jsgf_rule_iter</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Get an iterator over all rules in a grammar. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a18fc91b6b6e79fb183147502df372b5e"></a><!-- doxytag: member="jsgf.c::jsgf_get_rule" ref="a18fc91b6b6e79fb183147502df372b5e" args="(jsgf_t *grammar, char const *name)" -->
<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a18fc91b6b6e79fb183147502df372b5e">jsgf_get_rule</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar, char const *name)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Get a rule by name from a grammar. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a94a20b28b8bb3a179e567caec972d002"></a><!-- doxytag: member="jsgf.c::jsgf_rule_name" ref="a94a20b28b8bb3a179e567caec972d002" args="(jsgf_rule_t *rule)" -->
char const *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a94a20b28b8bb3a179e567caec972d002">jsgf_rule_name</a> (<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the rule name from a rule. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a49d5d9f6c1edda3bb087545ecfa21809"></a><!-- doxytag: member="jsgf.c::jsgf_rule_public" ref="a49d5d9f6c1edda3bb087545ecfa21809" args="(jsgf_rule_t *rule)" -->
int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a49d5d9f6c1edda3bb087545ecfa21809">jsgf_rule_public</a> (<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Test if a rule is public or not. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a2a3f3ade56bed13c58059a6ede5fd1dc"></a><!-- doxytag: member="jsgf.c::jsgf_build_fsg" ref="a2a3f3ade56bed13c58059a6ede5fd1dc" args="(jsgf_t *grammar, jsgf_rule_t *rule, logmath_t *lmath, float32 lw)" -->
<a class="el" href="structfsg__model__s.html">fsg_model_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a2a3f3ade56bed13c58059a6ede5fd1dc">jsgf_build_fsg</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar, <a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule, <a class="el" href="structlogmath__s.html">logmath_t</a> *lmath, float32 lw)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Build a Sphinx FSG object from a JSGF rule. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="structfsg__model__s.html">fsg_model_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a68e2c50712a3d1da5d9d6cb25a7198ee">jsgf_build_fsg_raw</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar, <a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule, <a class="el" href="structlogmath__s.html">logmath_t</a> *lmath, float32 lw)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Build a Sphinx FSG object from a JSGF rule.  <a href="#a68e2c50712a3d1da5d9d6cb25a7198ee"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#ab9454daf3cdf0c857b0f4780b600632c">jsgf_write_fsg</a> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *grammar, <a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule, FILE *outfh)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert a JSGF rule to Sphinx FSG text form.  <a href="#ab9454daf3cdf0c857b0f4780b600632c"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a91539f6bf30f85af4b90b5a85598f53f"></a><!-- doxytag: member="jsgf.c::jsgf_define_rule" ref="a91539f6bf30f85af4b90b5a85598f53f" args="(jsgf_t *jsgf, char *name, jsgf_rhs_t *rhs, int public)" -->
<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_define_rule</b> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf, char *name, <a class="el" href="structjsgf__rhs__s.html">jsgf_rhs_t</a> *rhs, int public)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad152a23eb0f0d9af8417919fc93074fd"></a><!-- doxytag: member="jsgf.c::jsgf_rule_retain" ref="ad152a23eb0f0d9af8417919fc93074fd" args="(jsgf_rule_t *rule)" -->
<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_rule_retain</b> (<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af2faf6fb74ad1e4d43cf990c1bcec672"></a><!-- doxytag: member="jsgf.c::jsgf_rule_free" ref="af2faf6fb74ad1e4d43cf990c1bcec672" args="(jsgf_rule_t *rule)" -->
int&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_rule_free</b> (<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *rule)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afe1e47584e4dd80929552ffed77373f2"></a><!-- doxytag: member="jsgf.c::jsgf_import_rule" ref="afe1e47584e4dd80929552ffed77373f2" args="(jsgf_t *jsgf, char *name)" -->
<a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>jsgf_import_rule</b> (<a class="el" href="structjsgf__s.html">jsgf_t</a> *jsgf, char *name)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="jsgf_8c.html#a322da18b1c115f1b3a1b7c766cf9e778">jsgf_parse_file</a> (const char *filename, <a class="el" href="structjsgf__s.html">jsgf_t</a> *parent)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Parse a JSGF grammar from a file.  <a href="#a322da18b1c115f1b3a1b7c766cf9e778"></a><br/></td></tr>
</table>
<hr/><a name="_details"></a><h2>Detailed Description</h2>
<div class="textblock"><p>This file implements the data structures for parsing JSGF grammars into Sphinx finite-state grammars. </p>

<p>Definition in file <a class="el" href="jsgf_8c_source.html">jsgf.c</a>.</p>
</div><hr/><h2>Function Documentation</h2>
<a class="anchor" id="a68e2c50712a3d1da5d9d6cb25a7198ee"></a><!-- doxytag: member="jsgf.c::jsgf_build_fsg_raw" ref="a68e2c50712a3d1da5d9d6cb25a7198ee" args="(jsgf_t *grammar, jsgf_rule_t *rule, logmath_t *lmath, float32 lw)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="structfsg__model__s.html">fsg_model_t</a>* jsgf_build_fsg_raw </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td>
          <td class="paramname"><em>grammar</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td>
          <td class="paramname"><em>rule</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structlogmath__s.html">logmath_t</a> *&#160;</td>
          <td class="paramname"><em>lmath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">float32&#160;</td>
          <td class="paramname"><em>lw</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Build a Sphinx FSG object from a JSGF rule. </p>
<p>This differs from <a class="el" href="jsgf_8h.html#ac355893a25aa071eba6874fae1d51ad2" title="Build a Sphinx FSG object from a JSGF rule.">jsgf_build_fsg()</a> in that it does not do closure on epsilon transitions or any other postprocessing. For the time being this is necessary in order to write it to a file - the FSG code will be fixed soon. </p>

<p>Definition at line <a class="el" href="jsgf_8c_source.html#l00500">500</a> of file <a class="el" href="jsgf_8c_source.html">jsgf.c</a>.</p>

<p>Referenced by <a class="el" href="jsgf_8c_source.html#l00507">jsgf_write_fsg()</a>.</p>

</div>
</div>
<a class="anchor" id="a2f4a4ef97090210de6c73361de1d9561"></a><!-- doxytag: member="jsgf.c::jsgf_grammar_new" ref="a2f4a4ef97090210de6c73361de1d9561" args="(jsgf_t *parent)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="structjsgf__s.html">jsgf_t</a>* jsgf_grammar_new </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td>
          <td class="paramname"><em>parent</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Create a new JSGF grammar. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">parent</td><td>optional parent grammar for this one (NULL, usually). </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>new JSGF grammar object, or NULL on failure. </dd></dl>

<p>Definition at line <a class="el" href="jsgf_8c_source.html#l00081">81</a> of file <a class="el" href="jsgf_8c_source.html">jsgf.c</a>.</p>

<p>References <a class="el" href="ckd__alloc_8h_source.html#l00248">ckd_calloc</a>, <a class="el" href="ckd__alloc_8h_source.html#l00264">ckd_salloc</a>, <a class="el" href="glist_8c_source.html#l00074">glist_add_ptr()</a>, <a class="el" href="glist_8c_source.html#l00169">glist_reverse()</a>, <a class="el" href="hash__table_8c_source.html#l00158">hash_table_new()</a>, <a class="el" href="jsgf__internal_8h_source.html#l00076">jsgf_s::imports</a>, <a class="el" href="jsgf__internal_8h_source.html#l00077">jsgf_s::parent</a>, <a class="el" href="jsgf__internal_8h_source.html#l00075">jsgf_s::rules</a>, and <a class="el" href="jsgf__internal_8h_source.html#l00078">jsgf_s::searchpath</a>.</p>

<p>Referenced by <a class="el" href="jsgf_8c_source.html#l00699">jsgf_parse_file()</a>.</p>

</div>
</div>
<a class="anchor" id="a322da18b1c115f1b3a1b7c766cf9e778"></a><!-- doxytag: member="jsgf.c::jsgf_parse_file" ref="a322da18b1c115f1b3a1b7c766cf9e778" args="(const char *filename, jsgf_t *parent)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="structjsgf__s.html">jsgf_t</a>* jsgf_parse_file </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>filename</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td>
          <td class="paramname"><em>parent</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Parse a JSGF grammar from a file. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">filename</td><td>the name of the file to parse. </td></tr>
    <tr><td class="paramname">parent</td><td>optional parent grammar for this one (NULL, usually). </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>new JSGF grammar object, or NULL on failure. </dd></dl>

<p>Definition at line <a class="el" href="jsgf_8c_source.html#l00699">699</a> of file <a class="el" href="jsgf_8c_source.html">jsgf.c</a>.</p>

<p>References <a class="el" href="jsgf_8c_source.html#l00127">jsgf_grammar_free()</a>, and <a class="el" href="jsgf_8c_source.html#l00081">jsgf_grammar_new()</a>.</p>

</div>
</div>
<a class="anchor" id="ab9454daf3cdf0c857b0f4780b600632c"></a><!-- doxytag: member="jsgf.c::jsgf_write_fsg" ref="ab9454daf3cdf0c857b0f4780b600632c" args="(jsgf_t *grammar, jsgf_rule_t *rule, FILE *outfh)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int jsgf_write_fsg </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="structjsgf__s.html">jsgf_t</a> *&#160;</td>
          <td class="paramname"><em>grammar</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="structjsgf__rule__s.html">jsgf_rule_t</a> *&#160;</td>
          <td class="paramname"><em>rule</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">FILE *&#160;</td>
          <td class="paramname"><em>outfh</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Convert a JSGF rule to Sphinx FSG text form. </p>
<p>This does a direct conversion without doing transitive closure on null transitions and so forth. </p>

<p>Definition at line <a class="el" href="jsgf_8c_source.html#l00507">507</a> of file <a class="el" href="jsgf_8c_source.html">jsgf.c</a>.</p>

<p>References <a class="el" href="jsgf_8c_source.html#l00500">jsgf_build_fsg_raw()</a>, <a class="el" href="logmath_8c_source.html#l00342">logmath_free()</a>, and <a class="el" href="logmath_8c_source.html#l00062">logmath_init()</a>.</p>

</div>
</div>
</div>
</div>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="jsgf_8c.html">jsgf.c</a>      </li>
      <li class="footer">Generated on Tue Apr 19 2011 for SphinxBase by&#160;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.3 </li>
    </ul>
  </div>

</body>
</html>