2004-07-10 19:30:37 +00:00
|
|
|
<?xml version="1.0" encoding="iso-8859-1"?>
|
2004-09-19 03:49:07 +00:00
|
|
|
<!-- $Revision: 1.4 $ -->
|
2004-07-11 12:33:25 +00:00
|
|
|
<sect1 id="language.oop5.interfaces">
|
2004-07-10 19:30:37 +00:00
|
|
|
<title>Object Interfaces</title>
|
|
|
|
<para>
|
2004-07-23 18:59:30 +00:00
|
|
|
Object interfaces allow you to create code which specifies which methods
|
|
|
|
and variables a class must implement, without having to define how these
|
|
|
|
methods are handled.
|
2004-07-10 19:30:37 +00:00
|
|
|
</para>
|
2004-07-23 18:59:30 +00:00
|
|
|
<para>
|
|
|
|
Interfaces are defined using the interface keyword, in the same way as a
|
|
|
|
standard class, but without any of the methods having their contents
|
|
|
|
defined. Classes which implement an interface should do so using the
|
|
|
|
implements keyword, and must have definitions for all the methods listed
|
|
|
|
in the interface. Classes may implement more than one interface if desired
|
2004-09-05 16:16:39 +00:00
|
|
|
by listing each interface split by a comma.
|
2004-07-23 18:59:30 +00:00
|
|
|
</para>
|
2004-09-19 03:49:07 +00:00
|
|
|
<para>
|
|
|
|
All methods declared in an interface must be public, this is the nature of an
|
|
|
|
interface.
|
|
|
|
</para>
|
2004-07-23 18:59:30 +00:00
|
|
|
<para>
|
|
|
|
Stating that a class implements an interface, and then not implementing all
|
|
|
|
the methods in the interface will result in a fatal error telling you which
|
|
|
|
methods have not been implemented.
|
|
|
|
</para>
|
|
|
|
<example>
|
|
|
|
<title>Interface example</title>
|
|
|
|
<programlisting role="php">
|
|
|
|
<![CDATA[
|
|
|
|
<?php
|
2004-09-19 03:49:07 +00:00
|
|
|
// Declare the interface 'iTemplate'
|
|
|
|
interface iTemplate
|
2004-07-23 18:59:30 +00:00
|
|
|
{
|
2004-09-19 03:49:07 +00:00
|
|
|
public function setVariable($name, $var);
|
|
|
|
public function getHtml($template);
|
2004-07-23 18:59:30 +00:00
|
|
|
}
|
2004-07-10 19:30:37 +00:00
|
|
|
|
2004-09-19 03:49:07 +00:00
|
|
|
// Implement the interface
|
|
|
|
// This will work
|
|
|
|
class Template implements iTemplate
|
2004-07-23 18:59:30 +00:00
|
|
|
{
|
2004-09-19 03:49:07 +00:00
|
|
|
private $vars = array();
|
2004-07-23 18:59:30 +00:00
|
|
|
|
2004-09-19 03:49:07 +00:00
|
|
|
public function setVariable($name, $var)
|
|
|
|
{
|
|
|
|
$this->vars[$name] = $var;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getHtml($template)
|
|
|
|
{
|
|
|
|
foreach($this->vars as $name => $value) {
|
|
|
|
$template = str_replace('{' . $name . '}', $value, $template);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $template;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This will not work
|
|
|
|
// Fatal error: Class BadTemplate contains 1 abstract methods
|
|
|
|
// and must therefore be declared abstract (iTemplate::getHtml)
|
|
|
|
class BadTemplate implements iTemplate
|
|
|
|
{
|
|
|
|
private $vars = array();
|
2004-07-23 18:59:30 +00:00
|
|
|
|
2004-09-19 03:49:07 +00:00
|
|
|
public function setVariable($name, $var)
|
|
|
|
{
|
|
|
|
$this->vars[$name] = $var;
|
2004-07-23 18:59:30 +00:00
|
|
|
}
|
|
|
|
}
|
2004-09-19 03:49:07 +00:00
|
|
|
|
|
|
|
?>
|
2004-07-23 18:59:30 +00:00
|
|
|
]]>
|
|
|
|
</programlisting>
|
|
|
|
</example>
|
2004-07-10 19:30:37 +00:00
|
|
|
|
|
|
|
</sect1>
|
|
|
|
|
|
|
|
<!-- 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
|
|
|
|
-->
|