File: File-Positioning.html

package info (click to toggle)
octave 7.3.0-2
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 130,464 kB
  • sloc: cpp: 332,823; ansic: 71,320; fortran: 20,963; objc: 8,562; sh: 8,115; yacc: 4,882; lex: 4,438; perl: 1,554; java: 1,366; awk: 1,257; makefile: 652; xml: 173
file content (147 lines) | stat: -rw-r--r-- 8,317 bytes parent folder | download
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
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<!-- Created by GNU Texinfo 6.8, https://www.gnu.org/software/texinfo/ -->
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>File Positioning (GNU Octave (version 7.3.0))</title>

<meta name="description" content="File Positioning (GNU Octave (version 7.3.0))">
<meta name="keywords" content="File Positioning (GNU Octave (version 7.3.0))">
<meta name="resource-type" content="document">
<meta name="distribution" content="global">
<meta name="Generator" content="makeinfo">
<meta name="viewport" content="width=device-width,initial-scale=1">

<link href="index.html" rel="start" title="Top">
<link href="Concept-Index.html" rel="index" title="Concept Index">
<link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
<link href="C_002dStyle-I_002fO-Functions.html" rel="up" title="C-Style I/O Functions">
<link href="EOF-and-Errors.html" rel="prev" title="EOF and Errors">
<style type="text/css">
<!--
a.copiable-anchor {visibility: hidden; text-decoration: none; line-height: 0em}
a.summary-letter {text-decoration: none}
blockquote.indentedblock {margin-right: 0em}
div.display {margin-left: 3.2em}
div.example {margin-left: 3.2em}
kbd {font-style: oblique}
pre.display {font-family: inherit}
pre.format {font-family: inherit}
pre.menu-comment {font-family: serif}
pre.menu-preformatted {font-family: serif}
span.nolinebreak {white-space: nowrap}
span.roman {font-family: initial; font-weight: normal}
span.sansserif {font-family: sans-serif; font-weight: normal}
span:hover a.copiable-anchor {visibility: visible}
ul.no-bullet {list-style: none}
-->
</style>
<link rel="stylesheet" type="text/css" href="octave.css">


</head>

<body lang="en">
<div class="subsection" id="File-Positioning">
<div class="header">
<p>
Previous: <a href="EOF-and-Errors.html" accesskey="p" rel="prev">End of File and Errors</a>, Up: <a href="C_002dStyle-I_002fO-Functions.html" accesskey="u" rel="up">C-Style I/O Functions</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html" title="Index" rel="index">Index</a>]</p>
</div>
<hr>
<span id="File-Positioning-1"></span><h4 class="subsection">14.2.19 File Positioning</h4>

<p>Three functions are available for setting and determining the position of
the file pointer for a given file.
</p>
<span id="XREFftell"></span><dl class="def">
<dt id="index-ftell"><span class="category">: </span><span><em><var>pos</var> =</em> <strong>ftell</strong> <em>(<var>fid</var>)</em><a href='#index-ftell' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Return the position of the file pointer as the number of characters from the
beginning of the file specified by file descriptor <var>fid</var>.
</p>
<p><strong>See also:</strong> <a href="#XREFfseek">fseek</a>, <a href="#XREFfrewind">frewind</a>, <a href="EOF-and-Errors.html#XREFfeof">feof</a>, <a href="Opening-and-Closing-Files.html#XREFfopen">fopen</a>.
</p></dd></dl>


<span id="XREFfseek"></span><dl class="def">
<dt id="index-fseek"><span class="category">: </span><span><em></em> <strong>fseek</strong> <em>(<var>fid</var>, <var>offset</var>)</em><a href='#index-fseek' class='copiable-anchor'> &para;</a></span></dt>
<dt id="index-fseek-1"><span class="category">: </span><span><em></em> <strong>fseek</strong> <em>(<var>fid</var>, <var>offset</var>, <var>origin</var>)</em><a href='#index-fseek-1' class='copiable-anchor'> &para;</a></span></dt>
<dt id="index-fseek-2"><span class="category">: </span><span><em><var>status</var> =</em> <strong>fseek</strong> <em>(&hellip;)</em><a href='#index-fseek-2' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Set the file pointer to the location <var>offset</var> within the file <var>fid</var>.
</p>
<p>The pointer is positioned <var>offset</var> characters from the <var>origin</var>, which
may be one of the predefined variables <code><span class="nolinebreak">SEEK_SET</span></code><!-- /@w --> (beginning),
<code><span class="nolinebreak">SEEK_CUR</span></code><!-- /@w --> (current position), or <code><span class="nolinebreak">SEEK_END</span></code><!-- /@w --> (end of file)
or strings <code>&quot;bof&quot;</code>, <code>&quot;cof&quot;</code>, or
<code>&quot;eof&quot;</code>.  If <var>origin</var> is omitted, <code><span class="nolinebreak">SEEK_SET</span></code><!-- /@w --> is
assumed.  <var>offset</var> may be positive, negative, or zero but not all
combinations of <var>origin</var> and <var>offset</var> can be realized.
</p>
<p><code>fseek</code> returns 0 on success and -1 on error.
</p>
<p><strong>See also:</strong> <a href="Line_002dOriented-Input.html#XREFfskipl">fskipl</a>, <a href="#XREFfrewind">frewind</a>, <a href="#XREFftell">ftell</a>, <a href="Opening-and-Closing-Files.html#XREFfopen">fopen</a>, <a href="#XREFSEEK_005fSET">SEEK_SET</a>, <a href="#XREFSEEK_005fCUR">SEEK_CUR</a>, <a href="#XREFSEEK_005fEND">SEEK_END</a>.
</p></dd></dl>


<span id="XREFSEEK_005fSET"></span><dl class="def">
<dt id="index-SEEK_005fSET"><span class="category">: </span><span><em></em> <strong>SEEK_SET</strong> <em>()</em><a href='#index-SEEK_005fSET' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Return the numerical value to pass to <code>fseek</code> to position the file pointer
relative to the beginning of the file.
</p>
<p><strong>See also:</strong> <a href="#XREFSEEK_005fCUR">SEEK_CUR</a>, <a href="#XREFSEEK_005fEND">SEEK_END</a>, <a href="#XREFfseek">fseek</a>.
</p></dd></dl>


<span id="XREFSEEK_005fCUR"></span><dl class="def">
<dt id="index-SEEK_005fCUR"><span class="category">: </span><span><em></em> <strong>SEEK_CUR</strong> <em>()</em><a href='#index-SEEK_005fCUR' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Return the numerical value to pass to <code>fseek</code> to position the file pointer
relative to the current position.
</p>
<p><strong>See also:</strong> <a href="#XREFSEEK_005fSET">SEEK_SET</a>, <a href="#XREFSEEK_005fEND">SEEK_END</a>, <a href="#XREFfseek">fseek</a>.
</p></dd></dl>


<span id="XREFSEEK_005fEND"></span><dl class="def">
<dt id="index-SEEK_005fEND"><span class="category">: </span><span><em></em> <strong>SEEK_END</strong> <em>()</em><a href='#index-SEEK_005fEND' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Return the numerical value to pass to <code>fseek</code> to position the file pointer
relative to the end of the file.
</p>
<p><strong>See also:</strong> <a href="#XREFSEEK_005fSET">SEEK_SET</a>, <a href="#XREFSEEK_005fCUR">SEEK_CUR</a>, <a href="#XREFfseek">fseek</a>.
</p></dd></dl>


<span id="XREFfrewind"></span><dl class="def">
<dt id="index-frewind"><span class="category">: </span><span><em></em> <strong>frewind</strong> <em>(<var>fid</var>)</em><a href='#index-frewind' class='copiable-anchor'> &para;</a></span></dt>
<dt id="index-frewind-1"><span class="category">: </span><span><em><var>status</var> =</em> <strong>frewind</strong> <em>(<var>fid</var>)</em><a href='#index-frewind-1' class='copiable-anchor'> &para;</a></span></dt>
<dd><p>Move the file pointer to the beginning of the file specified by file
descriptor <var>fid</var>.
</p>
<p><code>frewind</code> returns 0 for success, and -1 if an error is encountered.  It
is equivalent to <code>fseek (<var>fid</var>, 0, SEEK_SET)</code>.
</p>
<p><strong>See also:</strong> <a href="#XREFfseek">fseek</a>, <a href="#XREFftell">ftell</a>, <a href="Opening-and-Closing-Files.html#XREFfopen">fopen</a>.
</p></dd></dl>


<p>The following example stores the current file position in the variable
<code>marker</code>, moves the pointer to the beginning of the file, reads
four characters, and then returns to the original position.
</p>
<div class="example">
<pre class="example">marker = ftell (myfile);
frewind (myfile);
fourch = fgets (myfile, 4);
fseek (myfile, marker, SEEK_SET);
</pre></div>


</div>
<hr>
<div class="header">
<p>
Previous: <a href="EOF-and-Errors.html">End of File and Errors</a>, Up: <a href="C_002dStyle-I_002fO-Functions.html">C-Style I/O Functions</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html" title="Index" rel="index">Index</a>]</p>
</div>



</body>
</html>