mirror of
https://github.com/sigmasternchen/php-doc-en
synced 2025-03-16 00:48:54 +00:00
MFB: Upgrade to the new-reference-structure
- Moved the intro from reference.xml to book.xml - Change the intro ID to intro.<extname> - Moved examples into its own <appendix> git-svn-id: https://svn.php.net/repository/phpdoc/en/trunk@248001 c90b9560-bf6c-de11-be94-00142212c4b1
This commit is contained in:
parent
fe62f879b0
commit
09799fcd64
5 changed files with 310 additions and 200 deletions
48
reference/classobj/book.xml
Normal file
48
reference/classobj/book.xml
Normal file
|
@ -0,0 +1,48 @@
|
|||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<!-- $Revision: 1.2 $ -->
|
||||
<!-- Purpose: basic.vartype -->
|
||||
<!-- Membership: core -->
|
||||
|
||||
<book xml:id="book.classobj" xmlns="http://docbook.org/ns/docbook">
|
||||
<title>Class/Object Functions</title>
|
||||
<titleabbrev>Classes/Objects</titleabbrev>
|
||||
|
||||
<preface xml:id="intro.classobj">
|
||||
&reftitle.intro;
|
||||
<para>
|
||||
These functions allow you to obtain information about classes
|
||||
and instance objects. You can obtain the name of the class to
|
||||
which an object belongs, as well as its member properties and
|
||||
methods. Using these functions, you can find out not only the
|
||||
class membership of an object, but also its parentage (i.e.
|
||||
what class is the object class extending).
|
||||
</para>
|
||||
</preface>
|
||||
|
||||
&reference.classobj.setup;
|
||||
&reference.classobj.constants;
|
||||
&reference.classobj.examples;
|
||||
&reference.classobj.reference;
|
||||
|
||||
</book>
|
||||
<!-- Keep this comment at the end of the file
|
||||
Local variables:
|
||||
mode: sgml
|
||||
sgml-omittag:t
|
||||
sgml-shorttag:t
|
||||
sgml-minimize-attributes:nil
|
||||
sgml-always-quote-attributes:t
|
||||
sgml-indent-step:1
|
||||
sgml-indent-data:t
|
||||
indent-tabs-mode:nil
|
||||
sgml-parent-document:nil
|
||||
sgml-default-dtd-file:"../../../manual.ced"
|
||||
sgml-exposed-tags:nil
|
||||
sgml-local-catalogs:nil
|
||||
sgml-local-ecat-files:nil
|
||||
End:
|
||||
vim600: syn=xml fen fdm=syntax fdl=2 si
|
||||
vim: et tw=78 syn=sgml
|
||||
vi: ts=1 sw=1
|
||||
-->
|
||||
|
29
reference/classobj/constants.xml
Normal file
29
reference/classobj/constants.xml
Normal file
|
@ -0,0 +1,29 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<!-- $Revision: 1.2 $ -->
|
||||
|
||||
<appendix xml:id="classobj.constants" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
&reftitle.constants;
|
||||
&no.constants;
|
||||
</appendix>
|
||||
|
||||
<!-- Keep this comment at the end of the file
|
||||
Local variables:
|
||||
mode: sgml
|
||||
sgml-omittag:t
|
||||
sgml-shorttag:t
|
||||
sgml-minimize-attributes:nil
|
||||
sgml-always-quote-attributes:t
|
||||
sgml-indent-step:1
|
||||
sgml-indent-data:t
|
||||
indent-tabs-mode:nil
|
||||
sgml-parent-document:nil
|
||||
sgml-default-dtd-file:"../../../manual.ced"
|
||||
sgml-exposed-tags:nil
|
||||
sgml-local-catalogs:nil
|
||||
sgml-local-ecat-files:nil
|
||||
End:
|
||||
vim600: syn=xml fen fdm=syntax fdl=2 si
|
||||
vim: et tw=78 syn=sgml
|
||||
vi: ts=1 sw=1
|
||||
-->
|
||||
|
179
reference/classobj/examples.xml
Normal file
179
reference/classobj/examples.xml
Normal file
|
@ -0,0 +1,179 @@
|
|||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<!-- $Revision: 1.2 $ -->
|
||||
|
||||
|
||||
<appendix xml:id="classobj.examples">
|
||||
&reftitle.examples;
|
||||
<para>
|
||||
In this example, we first define a base class and an extension
|
||||
of the class. The base class describes a general vegetable,
|
||||
whether it is edible or not and what is its color. The subclass
|
||||
<varname>Spinach</varname> adds a method to cook it and another to
|
||||
find out if it is cooked.
|
||||
</para>
|
||||
<para>
|
||||
<example>
|
||||
<title>classes.inc</title>
|
||||
<programlisting role="php">
|
||||
<![CDATA[
|
||||
<?php
|
||||
|
||||
// base class with member properties and methods
|
||||
class Vegetable {
|
||||
|
||||
var $edible;
|
||||
var $color;
|
||||
|
||||
function Vegetable($edible, $color="green")
|
||||
{
|
||||
$this->edible = $edible;
|
||||
$this->color = $color;
|
||||
}
|
||||
|
||||
function is_edible()
|
||||
{
|
||||
return $this->edible;
|
||||
}
|
||||
|
||||
function what_color()
|
||||
{
|
||||
return $this->color;
|
||||
}
|
||||
|
||||
} // end of class Vegetable
|
||||
|
||||
// extends the base class
|
||||
class Spinach extends Vegetable {
|
||||
|
||||
var $cooked = false;
|
||||
|
||||
function Spinach()
|
||||
{
|
||||
$this->Vegetable(true, "green");
|
||||
}
|
||||
|
||||
function cook_it()
|
||||
{
|
||||
$this->cooked = true;
|
||||
}
|
||||
|
||||
function is_cooked()
|
||||
{
|
||||
return $this->cooked;
|
||||
}
|
||||
|
||||
} // end of class Spinach
|
||||
|
||||
?>
|
||||
]]>
|
||||
</programlisting>
|
||||
</example>
|
||||
</para>
|
||||
<para>
|
||||
We then instantiate 2 objects from these classes and print out
|
||||
information about them, including their class parentage.
|
||||
We also define some utility functions, mainly to have a nice printout
|
||||
of the variables.
|
||||
</para>
|
||||
<para>
|
||||
<example>
|
||||
<title>test_script.php</title>
|
||||
<programlisting role="php">
|
||||
<![CDATA[
|
||||
<pre>
|
||||
<?php
|
||||
|
||||
include "classes.inc";
|
||||
|
||||
// utility functions
|
||||
|
||||
function print_vars($obj)
|
||||
{
|
||||
foreach (get_object_vars($obj) as $prop => $val) {
|
||||
echo "\t$prop = $val\n";
|
||||
}
|
||||
}
|
||||
|
||||
function print_methods($obj)
|
||||
{
|
||||
$arr = get_class_methods(get_class($obj));
|
||||
foreach ($arr as $method) {
|
||||
echo "\tfunction $method()\n";
|
||||
}
|
||||
}
|
||||
|
||||
function class_parentage($obj, $class)
|
||||
{
|
||||
if (is_subclass_of($GLOBALS[$obj], $class)) {
|
||||
echo "Object $obj belongs to class " . get_class($$obj);
|
||||
echo " a subclass of $class\n";
|
||||
} else {
|
||||
echo "Object $obj does not belong to a subclass of $class\n";
|
||||
}
|
||||
}
|
||||
|
||||
// instantiate 2 objects
|
||||
|
||||
$veggie = new Vegetable(true, "blue");
|
||||
$leafy = new Spinach();
|
||||
|
||||
// print out information about objects
|
||||
echo "veggie: CLASS " . get_class($veggie) . "\n";
|
||||
echo "leafy: CLASS " . get_class($leafy);
|
||||
echo ", PARENT " . get_parent_class($leafy) . "\n";
|
||||
|
||||
// show veggie properties
|
||||
echo "\nveggie: Properties\n";
|
||||
print_vars($veggie);
|
||||
|
||||
// and leafy methods
|
||||
echo "\nleafy: Methods\n";
|
||||
print_methods($leafy);
|
||||
|
||||
echo "\nParentage:\n";
|
||||
class_parentage("leafy", "Spinach");
|
||||
class_parentage("leafy", "Vegetable");
|
||||
?>
|
||||
</pre>
|
||||
]]>
|
||||
</programlisting>
|
||||
<para>
|
||||
One important thing to note in the example above is that
|
||||
the object <varname>$leafy</varname> is an instance of the class
|
||||
<classname>Spinach</classname> which is a subclass of
|
||||
<classname>Vegetable</classname>,
|
||||
therefore the last part of the script above will output:
|
||||
</para>
|
||||
<screen>
|
||||
<![CDATA[
|
||||
[...]
|
||||
Parentage:
|
||||
Object leafy does not belong to a subclass of Spinach
|
||||
Object leafy belongs to class spinach a subclass of Vegetable
|
||||
]]>
|
||||
</screen>
|
||||
</example>
|
||||
</para>
|
||||
</appendix>
|
||||
|
||||
<!-- Keep this comment at the end of the file
|
||||
Local variables:
|
||||
mode: sgml
|
||||
sgml-omittag:t
|
||||
sgml-shorttag:t
|
||||
sgml-minimize-attributes:nil
|
||||
sgml-always-quote-attributes:t
|
||||
sgml-indent-step:1
|
||||
sgml-indent-data:t
|
||||
indent-tabs-mode:nil
|
||||
sgml-parent-document:nil
|
||||
sgml-default-dtd-file:"../../../manual.ced"
|
||||
sgml-exposed-tags:nil
|
||||
sgml-local-catalogs:nil
|
||||
sgml-local-ecat-files:nil
|
||||
End:
|
||||
vim600: syn=xml fen fdm=syntax fdl=2 si
|
||||
vim: et tw=78 syn=sgml
|
||||
vi: ts=1 sw=1
|
||||
-->
|
||||
|
|
@ -1,208 +1,13 @@
|
|||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<!-- $Revision: 1.17 $ -->
|
||||
<!-- Purpose: basic.vartype -->
|
||||
<!-- Membership: core -->
|
||||
<!-- $Revision: 1.18 $ -->
|
||||
|
||||
<reference xml:id="ref.classobj" xmlns="http://docbook.org/ns/docbook">
|
||||
<title>Class/Object Functions</title>
|
||||
<titleabbrev>Classes/Objects</titleabbrev>
|
||||
<reference xml:id="ref.classobj" xmlns="http://docbook.org/ns/docbook">
|
||||
<title>Class/Object Functions</title>
|
||||
|
||||
<partintro>
|
||||
<section xml:id="classobj.intro">
|
||||
&reftitle.intro;
|
||||
<para>
|
||||
These functions allow you to obtain information about classes
|
||||
and instance objects. You can obtain the name of the class to
|
||||
which an object belongs, as well as its member properties and
|
||||
methods. Using these functions, you can find out not only the
|
||||
class membership of an object, but also its parentage (i.e.
|
||||
what class is the object class extending).
|
||||
</para>
|
||||
</section>
|
||||
&reference.classobj.entities.functions;
|
||||
|
||||
<section xml:id="classobj.requirements">
|
||||
&reftitle.required;
|
||||
&no.requirement;
|
||||
</section>
|
||||
</reference>
|
||||
|
||||
<section xml:id="classobj.installation">
|
||||
&reftitle.install;
|
||||
&no.install;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.configuration">
|
||||
&reftitle.runtime;
|
||||
&no.config;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.resources">
|
||||
&reftitle.resources;
|
||||
&no.resource;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.constants">
|
||||
&reftitle.constants;
|
||||
&no.constants;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.examples">
|
||||
&reftitle.examples;
|
||||
<para>
|
||||
In this example, we first define a base class and an extension
|
||||
of the class. The base class describes a general vegetable,
|
||||
whether it is edible or not and what is its color. The subclass
|
||||
<varname>Spinach</varname> adds a method to cook it and another to
|
||||
find out if it is cooked.
|
||||
</para>
|
||||
<para>
|
||||
<example>
|
||||
<title>classes.inc</title>
|
||||
<programlisting role="php">
|
||||
<![CDATA[
|
||||
<?php
|
||||
|
||||
// base class with member properties and methods
|
||||
class Vegetable {
|
||||
|
||||
var $edible;
|
||||
var $color;
|
||||
|
||||
function Vegetable($edible, $color="green")
|
||||
{
|
||||
$this->edible = $edible;
|
||||
$this->color = $color;
|
||||
}
|
||||
|
||||
function is_edible()
|
||||
{
|
||||
return $this->edible;
|
||||
}
|
||||
|
||||
function what_color()
|
||||
{
|
||||
return $this->color;
|
||||
}
|
||||
|
||||
} // end of class Vegetable
|
||||
|
||||
// extends the base class
|
||||
class Spinach extends Vegetable {
|
||||
|
||||
var $cooked = false;
|
||||
|
||||
function Spinach()
|
||||
{
|
||||
$this->Vegetable(true, "green");
|
||||
}
|
||||
|
||||
function cook_it()
|
||||
{
|
||||
$this->cooked = true;
|
||||
}
|
||||
|
||||
function is_cooked()
|
||||
{
|
||||
return $this->cooked;
|
||||
}
|
||||
|
||||
} // end of class Spinach
|
||||
|
||||
?>
|
||||
]]>
|
||||
</programlisting>
|
||||
</example>
|
||||
</para>
|
||||
<para>
|
||||
We then instantiate 2 objects from these classes and print out
|
||||
information about them, including their class parentage.
|
||||
We also define some utility functions, mainly to have a nice printout
|
||||
of the variables.
|
||||
</para>
|
||||
<para>
|
||||
<example>
|
||||
<title>test_script.php</title>
|
||||
<programlisting role="php">
|
||||
<![CDATA[
|
||||
<pre>
|
||||
<?php
|
||||
|
||||
include "classes.inc";
|
||||
|
||||
// utility functions
|
||||
|
||||
function print_vars($obj)
|
||||
{
|
||||
foreach (get_object_vars($obj) as $prop => $val) {
|
||||
echo "\t$prop = $val\n";
|
||||
}
|
||||
}
|
||||
|
||||
function print_methods($obj)
|
||||
{
|
||||
$arr = get_class_methods(get_class($obj));
|
||||
foreach ($arr as $method) {
|
||||
echo "\tfunction $method()\n";
|
||||
}
|
||||
}
|
||||
|
||||
function class_parentage($obj, $class)
|
||||
{
|
||||
if (is_subclass_of($GLOBALS[$obj], $class)) {
|
||||
echo "Object $obj belongs to class " . get_class($$obj);
|
||||
echo " a subclass of $class\n";
|
||||
} else {
|
||||
echo "Object $obj does not belong to a subclass of $class\n";
|
||||
}
|
||||
}
|
||||
|
||||
// instantiate 2 objects
|
||||
|
||||
$veggie = new Vegetable(true, "blue");
|
||||
$leafy = new Spinach();
|
||||
|
||||
// print out information about objects
|
||||
echo "veggie: CLASS " . get_class($veggie) . "\n";
|
||||
echo "leafy: CLASS " . get_class($leafy);
|
||||
echo ", PARENT " . get_parent_class($leafy) . "\n";
|
||||
|
||||
// show veggie properties
|
||||
echo "\nveggie: Properties\n";
|
||||
print_vars($veggie);
|
||||
|
||||
// and leafy methods
|
||||
echo "\nleafy: Methods\n";
|
||||
print_methods($leafy);
|
||||
|
||||
echo "\nParentage:\n";
|
||||
class_parentage("leafy", "Spinach");
|
||||
class_parentage("leafy", "Vegetable");
|
||||
?>
|
||||
</pre>
|
||||
]]>
|
||||
</programlisting>
|
||||
<para>
|
||||
One important thing to note in the example above is that
|
||||
the object <varname>$leafy</varname> is an instance of the class
|
||||
<classname>Spinach</classname> which is a subclass of
|
||||
<classname>Vegetable</classname>,
|
||||
therefore the last part of the script above will output:
|
||||
</para>
|
||||
<screen>
|
||||
<![CDATA[
|
||||
[...]
|
||||
Parentage:
|
||||
Object leafy does not belong to a subclass of Spinach
|
||||
Object leafy belongs to class spinach a subclass of Vegetable
|
||||
]]>
|
||||
</screen>
|
||||
</example>
|
||||
</para>
|
||||
</section>
|
||||
</partintro>
|
||||
|
||||
&reference.classobj.entities.functions;
|
||||
|
||||
</reference>
|
||||
<!-- Keep this comment at the end of the file
|
||||
Local variables:
|
||||
mode: sgml
|
||||
|
|
49
reference/classobj/setup.xml
Normal file
49
reference/classobj/setup.xml
Normal file
|
@ -0,0 +1,49 @@
|
|||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<!-- $Revision: 1.2 $ -->
|
||||
|
||||
<chapter xml:id="classobj.setup">
|
||||
&reftitle.setup;
|
||||
|
||||
<section xml:id="classobj.requirements">
|
||||
&reftitle.required;
|
||||
&no.requirement;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.installation">
|
||||
&reftitle.install;
|
||||
&no.install;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.configuration">
|
||||
&reftitle.runtime;
|
||||
&no.config;
|
||||
</section>
|
||||
|
||||
<section xml:id="classobj.resources">
|
||||
&reftitle.resources;
|
||||
&no.resource;
|
||||
</section>
|
||||
|
||||
</chapter>
|
||||
|
||||
<!-- Keep this comment at the end of the file
|
||||
Local variables:
|
||||
mode: sgml
|
||||
sgml-omittag:t
|
||||
sgml-shorttag:t
|
||||
sgml-minimize-attributes:nil
|
||||
sgml-always-quote-attributes:t
|
||||
sgml-indent-step:1
|
||||
sgml-indent-data:t
|
||||
indent-tabs-mode:nil
|
||||
sgml-parent-document:nil
|
||||
sgml-default-dtd-file:"../../../manual.ced"
|
||||
sgml-exposed-tags:nil
|
||||
sgml-local-catalogs:nil
|
||||
sgml-local-ecat-files:nil
|
||||
End:
|
||||
vim600: syn=xml fen fdm=syntax fdl=2 si
|
||||
vim: et tw=78 syn=sgml
|
||||
vi: ts=1 sw=1
|
||||
-->
|
||||
|
Loading…
Reference in a new issue