<?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 => 'ja',
  ),
  'this' => 
  array (
    0 => 'yaml.callbacks.emit.php',
    1 => '発行コールバック',
    2 => '発行コールバック',
  ),
  'up' => 
  array (
    0 => 'yaml.callbacks.php',
    1 => 'コールバック',
  ),
  'prev' => 
  array (
    0 => 'yaml.callbacks.parse.php',
    1 => 'パースコールバック',
  ),
  'next' => 
  array (
    0 => 'ref.yaml.php',
    1 => 'Yaml 関数',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    '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">発行コールバック</h2>
  <p class="para">
   発行コールバックが起動するのは、登録済みのクラスのインスタンスが
   <span class="function"><a href="function.yaml-emit.php" class="function">yaml_emit()</a></span> や
   <span class="function"><a href="function.yaml-emit-file.php" class="function">yaml_emit_file()</a></span> から呼び出されたときです。
   コールバックに渡されるのは、発行対象のオブジェクトです。
   このコールバックは、二つの要素
   &quot;<code class="literal">tag</code>&quot; および &quot;<code class="literal">data</code>&quot;
   を持つ配列を返す必要があります。
   &quot;<code class="literal">tag</code>&quot; の値は文字列で、出力時の YAML タグとして用いられます。
   &quot;<code class="literal">data</code>&quot; の値は YAML 形式にエンコードされ、
   解析対象のオブジェクトの代わりに発行されます。
  </p>
  <div class="example" id="example-1">
   <p><strong>例1 Emit callback example</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">// データは 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 />   * Yaml 発行コールバック関数。yaml_emit からクラス名で参照される<br />   *<br />   * 二つの要素を持つ配列を返す。<br />   *   - 'tag': このシリアライズ用のカスタムタグ<br />   *   - 'data': yaml に変換する値 (array, string, bool, number)<br />   *<br />   * @param object $obj 発行するオブジェクト<br />   * @return array 発行するタグおよび代理データ<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>上の例の出力は、
たとえば以下のようになります。</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); ?>