view docs/ccguide/lseek.refentry @ 2798:b70d93f8d7ce lwtools-port

Updated coco1/modules/makefile and coco3/modules/makefile to help resolve issues with i(x) and s(x) descriptors. Updated level1/coco1/modules/makefile & level2/coco3/modules/makefile so that correct values would be sent to assembler when building superdesc.asm for s(x).dd and i(x).dd descriptors.
author drencor-xeen
date Mon, 28 Jan 2013 16:13:05 -0600
parents 42b2c775f05f
children
line wrap: on
line source

<refentry id="lseek">
<refnamediv>
<refname>Lseek</refname>
<refpurpose>position in file</refpurpose>
</refnamediv>

<refsynopsisdiv>
<funcsynopsis>
<funcprototype>
  <funcdef><function>lseek</function></funcdef>
  <paramdef>int <parameter>pn</parameter></paramdef>
  <paramdef>long <parameter>position</parameter></paramdef>
  <paramdef>int <parameter>type</parameter></paramdef>
</funcprototype>
</funcsynopsis>

</refsynopsisdiv>

<refsect1><title>Assembler Equivalent</title>
<para>
os9 I$SEEK
</para>
</refsect1>

<refsect1><title>Description</title>
<para>
The read or write pointer for the open file with the path
number, "pn", is positioned by lseek to the specified place in
the file. The "type" indicates from where "position" is to be
measured: if 0, from the beginning of the file, if 1, from the
current location, or if 2, from the end of the file.
</para>
<para>
Seeking to a location beyond the end of a file open for
writing and then writing to it, creates a "hole" in the file
which appears to be filled with zeros from the previous end to
the position sought.
</para>
<para>
The returned value is the resulting position in the file unless
there is an error, so to find out the current position use
<informalexample>
<para>
lseek(pn,0l,1);
</para>
</informalexample>
</para>
</refsect1>

<refsect1><title>Caveats</title>
<para>
The argument "position" <emphasis>must</emphasis> be a long integer. Constants
should be explicitly made long by appending an "l", as above,
and other types should be converted using a cast:
<informalexample>
<para>
e.g. lseek(pn,(long)pos,1);
</para>
</informalexample>
Notice also, that the return value from lseek is itself a long integer.
</para>
</refsect1>

<refsect1><title>Diagnostics</title>
<para>
-1 is returned if "pn" is a bad path number, or attempting to
seek to a position before the beginning of a file.
</para>
</refsect1>

<refsect1><title>See Also</title>
<para>
<link linkend="creat">creat()</link>,
<link linkend="open">open()</link>,
Standard Library function 
<link linkend="fseek">"fseek"</link>
</para>
</refsect1>

</refentry>