<?xml version="1.0" encoding="utf-8"?> <!-- $Revision$ --> <refentry xmlns="http://docbook.org/ns/docbook" xml:id="function.fseek"> <refnamediv> <refname>fseek</refname> <refpurpose>Seeks on a file pointer</refpurpose> </refnamediv> <refsect1 role="description"> &reftitle.description; <methodsynopsis> <type>int</type><methodname>fseek</methodname> <methodparam><type>resource</type><parameter>handle</parameter></methodparam> <methodparam><type>int</type><parameter>offset</parameter></methodparam> <methodparam choice="opt"><type>int</type><parameter>whence</parameter><initializer>SEEK_SET</initializer></methodparam> </methodsynopsis> <para> Sets the file position indicator for the file referenced by <parameter>handle</parameter>. The new position, measured in bytes from the beginning of the file, is obtained by adding <parameter>offset</parameter> to the position specified by <parameter>whence</parameter>. </para> </refsect1> <refsect1 role="parameters"> &reftitle.parameters; <para> <variablelist> <varlistentry> <term><parameter>handle</parameter></term> <listitem> &fs.file.pointer; </listitem> </varlistentry> <varlistentry> <term><parameter>offset</parameter></term> <listitem> <para> The offset. </para> <para> To move to a position before the end-of-file, you need to pass a negative value in <parameter>offset</parameter> and set <parameter>whence</parameter> to <constant>SEEK_END</constant>. </para> </listitem> </varlistentry> <varlistentry> <term><parameter>whence</parameter></term> <listitem> <para> <parameter>whence</parameter> values are: <simplelist> <member><constant>SEEK_SET</constant> - Set position equal to <parameter>offset</parameter> bytes.</member> <member><constant>SEEK_CUR</constant> - Set position to current location plus <parameter>offset</parameter>.</member> <member><constant>SEEK_END</constant> - Set position to end-of-file plus <parameter>offset</parameter>.</member> </simplelist> </para> </listitem> </varlistentry> </variablelist> </para> </refsect1> <refsect1 role="returnvalues"> &reftitle.returnvalues; <para> Upon success, returns 0; otherwise, returns -1. Note that seeking past EOF is not considered an error. </para> </refsect1> <refsect1 role="examples"> &reftitle.examples; <para> <example> <title><function>fseek</function> example</title> <programlisting role="php"> <![CDATA[ <?php $fp = fopen('somefile.txt', 'r'); // read some data $data = fgets($fp, 4096); // move back to the beginning of the file // same as rewind($fp); fseek($fp, 0); ?> ]]> </programlisting> </example> </para> </refsect1> <refsect1 role="notes"> &reftitle.notes; <note> <para> If you have opened the file in append ("a" or "a+") mode, any data you write to the file will always be appended, regardless of the file position. </para> </note> <note> <para> May not be used on file pointers returned by <function>fopen</function> if they use the "http://" or "ftp://" formats. <function>fseek</function> gives also undefined results for append-only streams (opened with "a" flag). </para> </note> </refsect1> <refsect1 role="seealso"> &reftitle.seealso; <para> <simplelist> <member><function>ftell</function></member> <member><function>rewind</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 -->