-
Notifications
You must be signed in to change notification settings - Fork 157
/
Copy pathdirname.xml
172 lines (164 loc) · 4.83 KB
/
dirname.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 21cd3a942724400765125b657d24f8c8c4d623e9 Maintainer: yannick Status: ready -->
<!-- Reviewed: no -->
<refentry xmlns="http://docbook.org/ns/docbook" xml:id="function.dirname">
<refnamediv>
<refname>dirname</refname>
<refpurpose>Renvoie le chemin du dossier parent</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>string</type><methodname>dirname</methodname>
<methodparam><type>string</type><parameter>path</parameter></methodparam>
<methodparam choice="opt"><type>int</type><parameter>levels</parameter><initializer>1</initializer></methodparam>
</methodsynopsis>
<para>
Renvoie le chemin parent d'un chemin représentant un fichier
ou un dossier, qui correspond à <parameter>levels</parameter> niveau(x) plus
haut que le dossier courant.
</para>
<note>
<para>
<function>dirname</function> agit naïvement sur la chaine en entrée et
n'est pas au courant du système de fichiers courant ou d'éventuels
composants comme "<literal>..</literal>".
</para>
</note>
<caution>
<para>
Sur Windows, <function>dirname</function> assume que la codepage actuellement
définie, donc pour qu'il puisse voir le nom de dossier correct avec des
caractères multioctets dans le chemin, la codepage correspondante doit
être définie.
Si <parameter>path</parameter> contient des caractères qui sont invalides
pour la codepage courante, le comportement de <function>dirname</function>
est indéfini.
</para>
<para>
Sur d'autres systèmes, <function>dirname</function> assume que <parameter>path</parameter>
est encodé dans un encodage compatible ASCII. Sinon, le comportement de la
fonction est indéfinie.
</para>
</caution>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>path</parameter></term>
<listitem>
<para>
Un chemin.
</para>
<para>
Sous Windows, les slash (<literal>/</literal>) et antislash
(<literal>\</literal>) sont utilisés comme séparateurs
de dossier. Dans les autres environnements, seul le slash
(<literal>/</literal>) est utilisé.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>levels</parameter></term>
<listitem>
<para>
Le nombre de dossiers parents plus haut.
</para>
<para>
Doit être un entier supérieur à 0.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Retourne le dossier parent du chemin. S'il n'y a pas de slash dans le chemin
<parameter>path</parameter>, un point ('<literal>.</literal>') sera
retourné, indiquant le dossier courant. Sinon, la chaîne retournée
sera le chemin <parameter>path</parameter> dont on aura supprimé tous
les <literal>/component</literal>.
</para>
<caution>
<para>
Il faut faire attention lors de l'utilisation de cette fonction dans une
boucle qui peut atteindre le dossier racine, car ceci peut produire une
boucle infinie.
<informalexample>
<programlisting role="php">
<![CDATA[
<?php
dirname('.'); // Will return '.'.
dirname('/'); // Will return `\` on Windows and '/' on *nix systems.
dirname('\\'); // Will return `\` on Windows and '.' on *nix systems.
dirname('C:\\'); // Will return 'C:\' on Windows and '.' on *nix systems.
?>
]]>
</programlisting>
</informalexample>
</para>
</caution>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Exemple avec <function>dirname</function></title>
<programlisting role="php">
<![CDATA[
<?php
echo dirname("/etc/passwd") . PHP_EOL;
echo dirname("/etc/") . PHP_EOL;
echo dirname(".") . PHP_EOL;
echo dirname("C:\\") . PHP_EOL;
echo dirname("/usr/local/lib", 2);
]]>
</programlisting>
&example.outputs.similar;
<screen>
<![CDATA[
/etc
/ (ou \ sous Windows)
.
C:\
/usr
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>basename</function></member>
<member><function>pathinfo</function></member>
<member><function>realpath</function></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- 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:"~/.phpdoc/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
-->