<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/yaml.callbacks.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'yaml.callbacks.emit.php',
    1 => 'Fun&ccedil;&otilde;es de retorno de emiss&atilde;o',
    2 => 'Fun&ccedil;&otilde;es de retorno de emiss&atilde;o',
  ),
  'up' => 
  array (
    0 => 'yaml.callbacks.php',
    1 => 'Fun&ccedil;&otilde;es de retorno',
  ),
  'prev' => 
  array (
    0 => 'yaml.callbacks.parse.php',
    1 => 'Fun&ccedil;&otilde;es de retorno de an&aacute;lise',
  ),
  'next' => 
  array (
    0 => 'ref.yaml.php',
    1 => 'Fun&ccedil;&otilde;es de Yaml',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    'path' => 'reference/yaml/callbacks.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="yaml.callbacks.emit" class="section">
  <h2 class="title">Funções de retorno de emissão</h2>
  <p class="para">
   Funções de emissão são chamadas quando uma instância de uma classe registrada é
   emitida pelas funções <span class="function"><a href="function.yaml-emit.php" class="function">yaml_emit()</a></span> ou
   <span class="function"><a href="function.yaml-emit-file.php" class="function">yaml_emit_file()</a></span>. A função recebe o objeto a
   ser emitido. A função deve retornar um array com duas chaves:
   &quot;<code class="literal">tag</code>&quot; e &quot;<code class="literal">data</code>&quot;.
   O valor associado à chave &quot;<code class="literal">tag</code>&quot; deve
   ser uma string a ser usada como a etiqueta YAML no resultado. O valor associado
   à chave &quot;<code class="literal">data</code>&quot; será codificado como YAML
   e emitido no lugar do objeto interceptado.
  </p>
  <div class="example" id="example-1">
   <p><strong>Exemplo #1 Exemplo de função de emissão</strong></p>
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">class </span><span style="color: #0000BB">EmitExample </span><span style="color: #007700">{<br />  public </span><span style="color: #0000BB">$data</span><span style="color: #007700">;    </span><span style="color: #FF8000">// os dados podem estar em qualquer tipo adequado de pecl/yaml<br /><br />  </span><span style="color: #007700">public function </span><span style="color: #0000BB">__construct </span><span style="color: #007700">(</span><span style="color: #0000BB">$d</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">$this</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">data </span><span style="color: #007700">= </span><span style="color: #0000BB">$d</span><span style="color: #007700">;<br />  }<br /><br />  </span><span style="color: #FF8000">/**<br />   * Função de emissão Yaml, referida na chamada a yaml_emit por nome de classe.<br />   *<br />   * Esperado retornar um array com dois valores:<br />   *   - 'tag': etiqueta personalizada para esta serialização<br />   *   - 'data': valor a ser convertido para yaml (array, string, booleano, número)<br />   *<br />   * @param object $obj Objeto a ser emitido<br />   * @return array Etiqueta e dados substitutos a serem emitidos<br />   */<br />  </span><span style="color: #007700">public static function </span><span style="color: #0000BB">yamlEmit </span><span style="color: #007700">(</span><span style="color: #0000BB">EmitExample $obj</span><span style="color: #007700">) {<br />    return array(<br />      </span><span style="color: #DD0000">'tag' </span><span style="color: #007700">=&gt; </span><span style="color: #DD0000">'!example/emit'</span><span style="color: #007700">,<br />      </span><span style="color: #DD0000">'data' </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">$obj</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">data</span><span style="color: #007700">,<br />    );<br />  }<br />}<br /><br /></span><span style="color: #0000BB">$emit_callbacks </span><span style="color: #007700">= array(<br />  </span><span style="color: #DD0000">'EmitExample' </span><span style="color: #007700">=&gt; array(</span><span style="color: #DD0000">'EmitExample'</span><span style="color: #007700">, </span><span style="color: #DD0000">'yamlEmit'</span><span style="color: #007700">)<br />);<br /><br /></span><span style="color: #0000BB">$t </span><span style="color: #007700">= new </span><span style="color: #0000BB">EmitExample</span><span style="color: #007700">(array(</span><span style="color: #DD0000">'a'</span><span style="color: #007700">,</span><span style="color: #DD0000">'b'</span><span style="color: #007700">,</span><span style="color: #DD0000">'c'</span><span style="color: #007700">));<br /></span><span style="color: #0000BB">$yaml </span><span style="color: #007700">= </span><span style="color: #0000BB">yaml_emit</span><span style="color: #007700">(<br />  array(<br />    </span><span style="color: #DD0000">'example' </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">$t</span><span style="color: #007700">,<br />  ),<br />  </span><span style="color: #0000BB">YAML_ANY_ENCODING</span><span style="color: #007700">,<br />  </span><span style="color: #0000BB">YAML_ANY_BREAK</span><span style="color: #007700">,<br />  </span><span style="color: #0000BB">$emit_callbacks<br /></span><span style="color: #007700">);<br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$yaml</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   <div class="example-contents"><p>O exemplo acima produzirá
algo semelhante a:</p></div>
   <div class="example-contents screen">
<div class="cdata"><pre>
string(43) &quot;---
example: !example/emit
- a
- b
- c
...
&quot;
</pre></div>
   </div>
  </div>
 </div><?php manual_footer($setup); ?>