aboutsummaryrefslogtreecommitdiff
path: root/ja_JP.eucJP/man/man2/truncate.2
blob: 7f696af23fa275a04cc0c9f9d6385512e2ed41e7 (plain) (blame)
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
.\" Copyright (c) 1983, 1991, 1993
.\"	The Regents of the University of California.  All rights reserved.
.\"
.\" Redistribution and use in source and binary forms, with or without
.\" modification, are permitted provided that the following conditions
.\" are met:
.\" 1. Redistributions of source code must retain the above copyright
.\"    notice, this list of conditions and the following disclaimer.
.\" 2. Redistributions in binary form must reproduce the above copyright
.\"    notice, this list of conditions and the following disclaimer in the
.\"    documentation and/or other materials provided with the distribution.
.\" 3. All advertising materials mentioning features or use of this software
.\"    must display the following acknowledgement:
.\"	This product includes software developed by the University of
.\"	California, Berkeley and its contributors.
.\" 4. Neither the name of the University nor the names of its contributors
.\"    may be used to endorse or promote products derived from this software
.\"    without specific prior written permission.
.\"
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE.
.\"
.\"     @(#)truncate.2	8.1 (Berkeley) 6/4/93
.\" %FreeBSD: src/lib/libc/sys/truncate.2,v 1.15 2002/12/19 09:40:25 ru Exp %
.\"
.\" $FreeBSD$
.Dd June 4, 1993
.Dt TRUNCATE 2
.Os
.Sh 名称
.Nm truncate ,
.Nm ftruncate
.Nd 指定した長さにファイルを切り捨てたり拡張したりする
.Sh ライブラリ
.Lb libc
.Sh 書式
.In unistd.h
.Ft int
.Fn truncate "const char *path" "off_t length"
.Ft int
.Fn ftruncate "int fd" "off_t length"
.Sh 解説
.Fn truncate
システムコールは、
.Fa path
で指定されるファイルか
.Fa fd
で参照されるファイルのサイズが、
.Fa length
バイトになるように切り捨てたり拡張します。
ファイルがこのサイズより大きい場合は、余分なデータが失われます。
ファイルがこのサイズより小さい場合は、0 が書き込まれたように拡張されます。
.Fn ftruncate
では、ファイルが書込み用に開いている必要があります。
.Sh 戻り値
.Rv -std
.Sh エラー
.Fn truncate
システムコールは、以下のような場合に処理を失敗します:
.Bl -tag -width Er
.It Bq Er ENOTDIR
パスの構成要素中にディレクトリ以外のものが含まれています。
.It Bq Er ENAMETOOLONG
パス名の構成要素が 255 文字を越えているか、
またはパス名全体が 1023 文字を越えています。
.It Bq Er ENOENT
指定されたファイルが存在しません。
.It Bq Er EACCES
前置パス名の構成要素について検索許可が拒否されています。
.It Bq Er EACCES
指定されたファイルにユーザが書き込めません。
.It Bq Er ELOOP
パス名を変換するときに検出されたシンボリックリンクが多すぎます。
.It Bq Er EISDIR
指定されたファイルがディレクトリになっています。
.It Bq Er EROFS
指定されたファイルは読取り専用ファイルシステム上にあります。
.It Bq Er ETXTBSY
ファイルが、実行中のピュアプロシージャ (共有テキスト) ファイルです。
.It Bq Er EIO
inode の更新をしている間に入出力エラーが発生しました。
.It Bq Er EFAULT
.Fa path
引数が、プロセスに割り当てられたアドレス空間の範囲外を指しています。
.El
.Pp
.Fn ftruncate
システムコールは、以下のような場合に処理を失敗します:
.Bl -tag -width Er
.It Bq Er EBADF
.Fa fd
引数が有効な記述子ではありません。
.It Bq Er EINVAL
.Fa fd
引数はファイルではなくソケットを参照しています。
.It Bq Er EINVAL
.Fa fd
引数が書込み用に開いていません。
.El
.Sh 関連項目
.Xr open 2
.Sh バグ
この呼出しは、ファイルのある範囲を放棄できるように一般化する
必要があります。
.Pp
.Fn truncate
を使用してファイルを拡張すると、移植性が失われます。
.Sh 歴史
.Fn truncate
システムコールは、
.Bx 4.2
で登場しました。