File: ed.1

package info (click to toggle)
manpages-ja 0.5.0.0.20210215%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 28,568 kB
  • sloc: perl: 161; makefile: 58
file content (713 lines) | stat: -rw-r--r-- 34,612 bytes parent folder | download | duplicates (5)
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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
.\"*******************************************************************
.\"
.\" This file was generated with po4a. Translate the source file.
.\"
.\"*******************************************************************
.TH ED 1 "3 July 2010"  
.SH 名前
ed, red \- 行指向のテキストエディタ
.SH 書式
ed [\-GVhs] [\-p \fIstring\fP] [\fIfile\fP]
.LP
red [\-GVhs] [\-p \fIstring\fP] [\fIfile\fP]
.SH 説明
\fBed\fP は、行指向のテキストエディタです。本コマンドを用いることで、
テキストファイルの生成、表示、変更その他の操作を行なうことができます。
\fBred\fP は制限付きの \fBed\fP です。 \fBred\fP では、カレントディレクトリの
ファイルのみを編集でき、シェルコマンドの実行はできません。

\fIfile\fP 引数を指定して本コマンドを起動すると、ファイル \fIfile\fP のコピー
をエディタのバッファに読み込みます。以後の変更はそのコピーに対して行な
われ、 \fIfile\fP で指定したファイル自身が直接変更されることはありません。
\fBed\fP コマンドを終了する際、\fI`w'\fP コマンドで明示的にセーブしなかった
変更点はすべて失われます。

編集は、\fIコマンド\fPモードと\fI入力\fPモードの 2 つの異なるモードを
使い分けて行ないます。 \fBed\fP を起動したら、まずコマンドモードに入ります。
本モードでは、標準入力からコマンドを読み込み、それを実行することで
エディタバッファの内容操作を行ないます。
典型的なコマンドは、以下のようなものです。
.sp
.RS
,s/\fIold\fP/\fInew\fP/g
.RE
.sp
これは、編集しているテキストファイル中に \fIold\fP という文字列があったら、
これらをすべて文字列 \fInew\fP に置き換えるコマンドです。

\fI`a'\fP (append)、\fI`i'\fP (insert)、あるいは \fI`c'\fP (change) といった
入力コマンドが入力された場合、 \fBed\fP は入力モードに移行します。
これが、ファイルにテキストを追加する主たる方法です。
このモードでは、コマンドを実行することはできません。
そのかわり、標準入力から入力されたデータは、
直接エディタバッファへと書き込まれます。
行は、改行キャラクタまでのテキストデータおよび、
最後の\fI改行\fPキャラクタを含むデータから構成されます。
ピリオド 1 つだけ (\fI.\fP) の行を入力すると、入力モードを終了します。

すべての \fBed\fP コマンドは、全ての行もしくは指定した範囲の行の操作が可能
です。例えば、 \fI`d'\fP コマンドは指定した行を削除し、 \fI`m'\fP コマンドは
指定した行を移動します。上に示した例のように、置換によってある行の一部
分のみを変更することは可能ですが、 \fI`s'\fP コマンドは、一度に全部の行に
わたって変更を行なうことも可能です。

一般的には、 \fBed\fP コマンドは、0 個以上の行番号および、
それに連なる 1 文字コマンドから成り立ちます。場合によっては追加の
パラメータをもつこともあります。
いうなれば、コマンドは以下の構造を持ちます。
.sp
.RS
\fI[address [,address]]command[parameters]\fP
.RE
.sp
アドレス (行番号) はコマンドの操作対象行あるいは対象行範囲を示します。
アドレスの指定個数が、コマンドが受け付け可能な個数よりも少ない場合には、
デフォルトのアドレスが採用されます。

.SS オプション
.TP  8
\-G
強制的に後方互換性を有効にします。コマンド \fI`G'\fP, \fI`V'\fP, \fI`f'\fP,
\fI`l'\fP, \fI`m'\fP, \fI`t'\fP, and \fI`!!'\fP に影響があります。
.TP  8
\-s
診断メッセージを抑制します。本オプションは、
\fBed\fP の入力がスクリプトによって行なわれる場合に有効です。

.TP  8
\-p\fI\ string\fP
コマンドプロンプトとして表示する文字列を指定します。
コマンドプロンプトは、コマンドモードで \fI`P'\fP コマンドを実行することで、
表示する/しないを切り替えることが可能です。

.TP  8
\fIfile\fP
編集対象のファイルを指定します。ファイル名の先頭に感嘆符 (!) が付加され
ていた場合、そのファイル名はシェルコマンドとして解釈されます。この場合、
編集対象として読み込まれるテキストは、\fIsh\fP(1) が \fIfile\fP で指定した
コマンドを実行した結果、標準出力に出力されるデータです。先頭が感嘆符で
始まるファイルを編集する場合には、ファイル名の先頭にバックスラッシュ
(\e) を付加して下さい。感嘆符以外の文字で始まるファイル名については、
編集対象のファイル名は \fIfile\fP となります。

.SS 行指定
行は、バッファ内の行番号で表現されます。 \fBed\fP は \fI現在行\fP を管理して
おり、コマンドに行番号が指定されない場合は、現在行がデフォルト行として
用いられます。ファイルが最初に読み出された直後は、現在行はファイルの
最後の行となります。一般的に、現在行はコマンドが操作した最後の行と
なります。

行番号は、以下の一覧のうち 1 つおよび、補助的に付加される
相対行番号 (オフセット) から構成されます。相対行番号は、
任意の数字の組み合わせ、演算子 (\fI+\fP, \fI\-\fP)、
そして空白文字を含みます。行番号は、左から右に解釈され、
それらの演算子を含む値は、現在行からの相対行番号と解釈されます。

行番号の表現に関して上記の規則が適用される中で、
行番号 \fI0\fP (ゼロ) に関しては、例外的な扱いがされます。
これは「最初の行より前」を意味し、
それが正しい意味を持つ場合は常に利用可能です。

行範囲は、コンマもしくはセミコロンで区切られた 2 つのアドレスで
示されます。最初に指定される行番号は、2 番目に指定される行番号を
超える値を指定してはいけません。行範囲指定で行番号が 1 つしか指定
されなかった場合には、2 番目に指定されるアドレスとして最初に指定
されたアドレスが設定されます。ここで 3 個以上の行番号が指定されると、
最後の 2 つの行番号で決定される範囲がコマンド実行対象になります。
行番号の指定を 1 つだけしか想定していないコマンドの場合、
最後の 1 つの行番号の行がコマンド実行対象となります。

コンマで区切られた各行番号は、現在行からの相対行を指し示します。
セミコロンで区切られている場合は、範囲の始めの行は現在行が設定され、
範囲の終りは始めの行からの相対行で表わされます。


行番号の指定には、以下のシンボルが使用可能です。

.TP  8
\&.
バッファ中の現在行を表します。

.TP  8
$
バッファ中の最終行を表します。

.TP  8
\fIn\fP
バッファ内の \fIn\fP 番目の行を表します。
\fIn\fP は \fI[0,$]\fP の間です。

.TP  8
\-
1 行前の行です。相対行指定 \fI\-1\fP と同等であり、
複数指定することで効果を累積することが可能です。

.TP  8
^\fIn\fP
\fIn\fP 行前の行を表します。 \fIn\fP は、負でない整数です。

.TP  8
+
次の行を表します。
これは、\fI+1\fP と同様であり、 \fI\-\fP と同様の累積的指定が可能です。

.HP
\fIwhitespace n\fP
.TP  8
+\fIn\fP
\fIn\fP 行後ろの行を表します。
\fIn\fP は、負でない整数です。
\fIn\fP の前に \fIwhitespace (空白文字)\fP を付加して指定した場合も
\fI+n\fP と解釈されます。

.TP  8
,
バッファの最初から最後までを表します。
これは \fI1,$\fP と指定した場合と同等です。

.TP  8
;
バッファ中の現在行から最後の行までを表します。これは、
\&\fI.,$\fP と指定した場合と同等です。

.TP  8
/\fIre\fP/
指定された正規表現 \fIre\fP を含む、(現在行よりも後ろの) 次の行を表します。
必要であれば、文字列検索はテキスト先頭に折り返し、現在行に達するまで
検索を行ないます。 // は、最後に行なった検索を繰り返します。

.TP  8
?\fIre\fP?
指定した正規表現 \fIre\fP を含む、現在行より前の行を表します。
必要であれば、文字列検索はテキストの最後に折り返し、
現在行に達するまで検索を行ないます。
?? は、最後に行なった検索を繰り返します。

.TP  8
\&'\fIlc\fP
\fI`k'\fP (mark)  コマンドでマークをつけた行を表します。
ここで \fIlc\fP は英小文字 1 文字です。

.SS 正規表現
正規表現はテキストを選択する際に用いるパターンです。
例えば次の \fBed\fP コマンド
.sp
.RS
g/\fIstring\fP/
.RE
.sp
は \fIstring\fP を含む全ての行を表示します。
正規表現は \fI`s'\fP コマンドで古いテキストを新しいテキストで
置き換える際にも用いられます。

文字リテラルを指定するのに加え、正規表現は文字列のクラスを表現すること
ができます。このようにして表現された文字列は、それに対応する正規表現に
「マッチする」と言います。ある正規表現が一つの行の中の複数の文字列に
マッチする場合、マッチする部分のうち最も左にあって最も長いものが選択
されます。

正規表現を組み立てる際には以下のシンボルが用いられます:

.TP  8
c
以下に挙げるものを除く任意の文字 \fIc\fP は、その文字自身にマッチします。
このような文字には `{', '}', `(', `)', `<', `>' が含まれます。

.TP  8
\e\fIc\fP
バックスラッシュでエスケープした文字 \fIc\fP は、その文字自身にマッチ
します。ただし `{', '}', `(', `)', `<', `>' を除きます。

.TP  8
\&.
任意の一文字にマッチします。

.TP  8
\fI[char\-class]\fP
文字クラス \fIchar\-class\fP に含まれる任意の一文字にマッチします。
文字クラス \fIchar\-class\fP に `]' を含めるには、文字 `]' を最初の文字に
指定します。文字の範囲を指定するには、範囲の両端の文字の間を `\-' で
つなぎます。例えば `a\-z' は小文字全体を表します。
以下のようなリテラル表記も、文字集合を指定するために文字クラス
\fIchar\-class\fP で使用することができます:
.sp
.nf
\ \ [:alnum:]\ \ [:cntrl:]\ \ [:lower:]\ \ [:space:]
.PD 0
\ \ [:alpha:]\ \ [:digit:]\ \ [:print:]\ \ [:upper:]
.PD 0
\ \ [:blank:]\ \ [:graph:]\ \ [:punct:]\ \ [:xdigit:]
.fi
.sp
文字クラス \fIchar\-class\fP の最初あるいは最後の文字として `\-' が用いられ
ると、それはその文字自身にマッチします。文字クラス \fIchar\-class\fP 中の
これ以外の文字は全て、それら自身にマッチします。
.sp
以下の形式の文字クラス \fIchar\-class\fP のパターン
.sp
\ \ [.\fIcol\-elm\fP.] と
.PD 0
\ \ [=\fIcol\-elm\fP=]
.sp
は \fBlocale\fP(5) に沿って解釈されます (現在のところサポートされません)。
ここで \fIcol\-elm\fP は \fIcollating element\fP です。
詳しい説明は \fBregex\fP(3) を参照して下さい。

.TP  8
[^\fIchar\-class\fP]
文字クラス \fIchar\-class\fP に含まれない、改行以外の任意の一文字に
マッチします。文字クラス \fIchar\-class\fP は上で定義しています。

.TP  8
^
\fI`^'\fP が正規表現の最初の文字である場合、その正規表現は行頭でのみ
マッチします。それ以外の場合、 \fI`^'\fP はそれ自身にマッチします。

.TP  8
$
\fI`$'\fP が正規表現の最後の文字である場合、その正規表現は行末でのみ
マッチします。それ以外の場合、 \fI`$'\fP はそれ自身にマッチします。

.TP  8
\e(\fIre\fP\e)
部分式 (subexpression) \fIre\fP を定義します。部分式はネストできます。
これ以降、 `\e\fIn\fP' の形式の後方参照は、
\fIn\fP 番目の部分式にマッチしたテキストに展開されます
(\fIn\fP は [1,9] の範囲の数)。
例えば、正規表現 `\e(a.c\e)\e1' は、
同じ文字列が隣接しているような任意の文字列にマッチします。
部分式は左側のデリミタから順に番号が振られます。

.TP  8
*
直前にある単一文字の正規表現あるいはその部分式のゼロ回以上の繰り返しに
マッチします。 \fI*\fP が正規表現あるいはその部分式の最初の文字として用い
られた場合、 \fI*\fP はその文字自身にマッチします。 \fI*\fP 演算子は時に予期
しない結果をもたらすことがあります。例えば、正規表現 `b*' は文字列
`abbb' の先頭にマッチします (部分文字列 `bbb' ではありません)。これは
ヌルへのマッチが最も左にあるマッチだからです。

.HP
\e{\fIn,m\fP\e}
.HP
\e{\fIn,\fP\e}
.TP  8
\e{\fIn\fP\e}
直前にある単一文字の正規表現あるいはその部分式の、 \fIn\fP 回以上 \fIm\fP 回
以下の繰り返しにマッチします。\fIm\fP が省略された場合、 \fIn\fP 回以上の繰り
返しにマッチします。さらにコンマも省略された場合、ちょうど \fIn\fP 回の
繰り返しにのみマッチします。この表現が正規表現や部分式の先頭に登場した
場合は、リテラルとして解釈されます (すなわち、正規表現 `\e{2\e}' は
文字列 `{2}' などにマッチします。

.HP
\e<
.TP  8
\e>
これに続く単一文字の正規表現あるいはその部分式が、 \fIワード\fP の先頭
(\e<) や末尾 (\e>) でのみマッチするようにします。
\fIワード\fP とは ASCII で英数字文字が続く文字列で最長のものです
(アンダースコア (_) も文字列に含まれます)。


.LP
以下の拡張演算子は、以前からの \fBed\fP の書式と区別するため、
バックスラッシュ (\e) から始まります。

.HP
\e\`
.TP  8
\e\'
無条件に、行の先頭 (\e\`) や行の末尾 (\e\') にマッチします。

.TP  8
\e?
1 文字の正規表現か直前の部分式が 0 個か 1 個ある場合にマッチします。
例えば、正規表現 `a[bd]\e?c' は、文字列 `abc', `adc', `ac' に
マッチします。 \e? が正規表現か部分式の先頭に登場した場合は、
リテラル `?' にマッチします。

.TP  8
\e+
1 文字の正規表現または直前の部分式の 1 回以上の繰り返しにマッチします。
正規表現 `a\e+' は `aa*' の短い書き方です。 \e+ が正規表現や部分式の
先頭に登場した場合は、リテラル `+' にマッチします。


.TP  8
\eb
ワードの先頭や末尾にマッチします (マッチするのは空文字列です)。
正規表現 `\ebhello\eb' は `\e<hello\e>' と同じです。
但し、 `\eb\eb' は有効な正規表現ですが、
`\e<\e>' はそうではありません。

.TP  8
\eB
ワード内にマッチします (マッチするのは空文字列です)。

.TP  8
\ew
ワードを構成する任意の文字にマッチします。

.TP  8
\eW
ワードを構成する文字以外の任意の文字にマッチします。

.SS コマンド
全ての \fBed\fP コマンドは、1 文字からなりますが、追加パラメータが必要な
コマンドもあります。コマンドのパラメータが複数の行にわたる場合には、
そのパラメータを含めたコマンドの終りを含む行を除き、行末に
バックスラッシュ (\e) を付加して下さい。

一般的には、1 行ごとに 1 コマンドを入れることが許されています。
しかしながら、ほとんどのコマンドは、コマンド実行を行なった後のデータ更新
その他を確認するために、
\fI`p'\fP (print), \fI`l'\fP (list), \fI`n'\fP (enumerate)
のような表示系のコマンドを同時に指定できます。

インタラプト (一般的には ^C) を入力することで、現在実行しているコマンド
を強制終了し、コマンドモードに戻すことができます。

\fBed\fP は、以下のコマンドを使用できます。コマンド実行時に何の指定もない
場合のデフォルトの行番号もしくは行範囲が括弧内に示されています。

.TP  8
(.)a
指定した行の後にテキストを追加します。行番号 0 (ゼロ) も指定できます。
テキストは入力モードで入力されていきます。
現在行番号は、入力された最後の行に設定されます。

.TP  8
(.,.)c
バッファ内の指定した行を変更します。指定した行のデータは、バッファから
消去され、そこに対してテキストデータを入力するようになります。テキスト
は入力モードで入力されていきます。現在行番号は、入力した最後の行に設定
されます。

.TP  8
(.,.)d
指定した範囲をバッファから削除します。削除した範囲の後に行が続いている
場合、現在行番号は、その行に設定されます。そうでない場合には、現在行番
号は、削除された範囲の前の行に設定されます。

.TP  8
e\fI\ file\fP
\fIfile\fP を編集し、デフォルトのファイル名を設定します。もし \fIfile\fP が
指定されなかった場合には、デフォルトのファイル名が使用されます。
本コマンド実行時に、それまで別のファイルを編集していた場合には、
その内容はすべて消去され、新しいファイルが読み込まれます。
現在行番号は、入力された最後の行に設定されます。

.TP  8
e !\fIcommand\fP
\fI!command\fP で指定されたコマンドを実行し、その結果として標準出力へ出力
されたデータを編集します (後述する \fI!command\fP を参照して下さい)。
デフォルトのファイル名は変更されません。\fIcommand\fP の出力が読み込まれる
前に、バッファ内に存在した行はすべて消去されます。現在行番号は、入力さ
れた最後の行に設定されます。

.TP  8
E\fI\ file\fP
無条件で \fIfile\fP で指定したファイルを読み込み、編集します。
\fIe\fP コマンドと動作は似ていますが、すでにバッファ上のデータに変更が
加えられている場合でも、未書き込みの変更を警告を出さずに捨ててしまう
点が異なります。現在行番号は、入力された最後の行に設定されます。

.TP  8
f\fI\ file\fP
デフォルトファイル名を \fIfile\fP に設定します。 \fIfile\fP 名が指定されない
場合には、デフォルトファイル名が表示されます。

.TP  8
(1,$)g\fI/re/command\-list\fP
\fIcommand\-list\fP で指定されたコマンドを、指定した正規表現 \fIre\fP に一致
する各行に対して実行します。現在行番号は、 \fIcommand\-list\fP で指定された
コマンドが実行される前に、指定した正規表現に一致した行に設定されます。
\fI`g'\fP コマンドが終了した場合、現在行番号は最後に \fIcommand\-list\fP 実行
の影響を受けた行に設定されます。

\fIcommand\-list\fP で指定されるコマンドは、1 行ごとに 1 つずつ書かれる
必要があります。各コマンド行の終りには、一番最後のコマンド行を除いては
バックスラッシュ (\e) を記述する必要があります。コマンド \fI`g'\fP,
\fI`G'\fP, \fI`v'\fP, \fI`V'\fP を除くすべてのコマンドを指定可能です。
\fIcommand\-list\fP 中の空行は、 \fI`p'\fP コマンドと同等に扱われます。

.TP  8
(1,$)G\fI/re/\fP
指定した正規表現 \fIre\fP に一致した行に対して、対話編集を行ないます。
指定した正規表現に一致する文字列を含む行があると、その行を表示し、
現在行番号を設定します。そして、ユーザに \fIcommand\-list\fP の入力を
促します。 \fI`G'\fP コマンドが終了した場合、現在行番号は、
\fIcommand\-list\fP 実行の影響を受けた最後の行に設定されます。

\fIcommand\-list\fP の記述形式は、 \fIg\fP コマンドで指定するものと同じです。
改行のみの場合は、コマンド実行をしない (ヌルコマンドリストを指定した)
ものとみなされます。`&' 文字のみを入力した場合には、直前に実行した
(ヌルコマンドリストではない) コマンドを再実行します。

.TP  8
H
エラーメッセージの出力の有無を切り替えます。デフォルトでは、
エラーメッセージは出力されません。ed スクリプトを作成する場合、
スクリプトのデバッグのために、本コマンドを最初に実行することを
おすすめします。

.TP  8
h
最後に表示されたエラーメッセージを表示します。

.TP  8
(.)i
編集バッファ中の現在行の前に、テキストを挿入します。
テキストは入力モードで入力されていきます。
現在行番号は、入力された最後の行に設定されます。

.TP  8
(.,.+1)j
指定した範囲の行を 1 行に連結します。指定した行はバッファから削除され、
その行の内容を含む 1 行に置き換えられます。
現在行番号は、置き換えられた行に設定されます。

.TP  8
(.)k\fIlc\fP
行に、英小文字 \fIlc\fP で指定したマークをつけます。
その後、マークをつけられた行は、コマンド中で \fI'lc\fP (つまり、
シングルクォートと小文字 \fIlc\fP) として指定できるようになります。
マークは、その行が削除されるかもしくは変更されるかしない限り、
消えることはありません。

.TP  8
(.,.)l
指定した範囲の行の内容を見やすく表示します。
端末から起動された場合、各ページの終わりで表示を一時停止し、
改行が入力されるまで待ちます。
現在行番号は、表示された最後の行に設定されます。

.TP  8
(.,.)m(.)
指定した範囲の行をバッファ内で移動します。指定した行は、コマンドの右辺
で指定した行の後ろに移動されます。移動先の行としては、\fI0\fP (ゼロ) が
指定可能です。現在行番号は、移動された最後の行の移動後の行に設定
されます。

.TP  8
(.,.)n
指定した行の内容を、行番号つきで表示します。
現在行番号は、表示された最後の行に設定されます。

.TP  8
(.,.)p
指定した範囲の行の内容を表示します。
端末から起動された場合、 \fBed\fP は各ページの終わりで表示を一時停止し、
改行が入力されるまで待ちます。
現在行番号は、表示された最後の行に設定されます。

.TP  8
P
コマンドプロンプト表示の有無を切り替えます。コマンド起動時のオプション
\fI\-p string\fP でプロンプトが指定されていなければ、コマンドプロンプトの
表示はデフォルトでオフになっています。

.TP  8
q
\fBed\fP を終了します。

.TP  8
Q
無条件に \fBed\fP を終了します。このコマンドは \fIq\fP コマンドと似ていますが、
まだファイルに書き出されていない変更があっても警告せずに終了する点が
異なります。

.TP  8
($)r\fI\ file\fP
\fIfile\fP で指定されたファイルを、指定した行の後ろに読み込みます。
\fIfile\fP が指定されない場合、デフォルトのファイル名が読み込みに使用され
ます。このコマンドに先だってデフォルトのファイル名が設定されていない場
合、デフォルトのファイル名には、\fIfile\fP で指定されたものが設定されます。
それ以外の場合、デフォルトのファイル名は変更されません。現在行番号は、
読み込まれたファイルの最後の行に設定されます。

.TP  8
($)r !\fIcommand\fP
\fIcommand\fP で指定されたコマンドを実行し、その結果として標準出力へ出力
されたデータを指定した行の後ろに読み込みます (後述する \fI! command\fP を
参照して下さい)。デフォルトのファイル名は変更されません。現在行番号は、
読み込まれた最後の行の行番号に設定されます。

.HP
(.,.)s\fI/re/replacement/\fP
.HP
(.,.)s\fI/re/replacement/\fPg
.HP
(.,.)s\fI/re/replacement/n\fP
.br
指定した行のテキスト中の、正規表現 \fIre\fP に一致する文字列を、文字列
\fIreplacement\fP に置き換えます。デフォルトでは、それぞれの行で最初に一致
した文字列のみを置き換えます。 \fI`g'\fP (global) サフィックスが指定された
場合、一致した文字列はすべて置き換えられます。 \fI`n'\fP サフィックス
(\fI`n'\fP は正の整数) が指定された場合、 \fI`n'\fP 回目に一致した文字列だけ
を置き換えます。指定した範囲で一度も文字列の置換が起こらなかった場合、
エラーとみなされます。現在行番号は、最後に置換が発生した行に設定
されます。

\fIre\fP および \fIreplacement\fP は、スペース、改行、 下記の \fI`s'\fP コマンド
で使用されるキャラクタ以外のすべてのキャラクタを用いて区切ることが可能
です。最後のデリミタのうち 1 つか 2 つが省略された場合、最後に文字列
置換が発生した行は、 \fI`p'\fP コマンドが指定された場合と同様に表示されま
す。


\fIreplacement\fP 中のエスケープされていない `&' は、一致した文字列と置き
換えられます。キャラクタシーケンス \fI`\em'\fP (\fI`m'\fP は [1,9] の範囲の
整数です) は、一致した文字列の\fI`m'\fP 番目の後方参照で置き換えられます。
\fIreplacement\fP の中に入る文字が `%' のみだった場合、最後に行なった置換
の \fIreplacement\fP が使用されます。改行を \fIreplacement\fP に指定したい
場合は、バックスラッシュを用いてエスケープすれば可能です。

.TP  8
(.,.)s
最後の置換を繰り返します。この形式の \fI`s'\fP コマンドには、回数を示す
サフィックス \fI`n'\fP と、文字 \fI`r'\fP, \fI`g'\fP, \fI`p'\fP の任意の
組み合わせを指定できます。 \fI`n'\fP が指定されると、 \fI`n'\fP 回目に一致し
た文字列だけが置換されます。 \fI`r'\fP サフィックスが指定されると、最後の
置換が発生した文字列の変わりに、最後に指定した正規表現が使用されます。
\fI`g'\fP サフィックスは、最後の置換で用いたグローバルサフィックスの使用の
有効/無効を切り替えます。\fI`p'\fP サフィックスは、最後の置換に指定された
プリントサフィックスを反転します。現在行番号は、最後に置換が発生した行
に設定されます。

.TP  8
(.,.)t(.)
指定した範囲の行を、コマンド文字の右辺に指定した行番号の後に
コピー (つまり転送) します。コピー先の行番号としては、
\fI`0'\fP (ゼロ) の指定が許されています。
現在行番号は、コピーした一番最後の行の行番号に設定されます。

.TP  8
u
最後に実行したコマンドの実行結果を取り消し、現在行番号を、取り消したい
コマンドが実行される前のものに戻します。グローバルコマンドである
\fI`g'\fP, \fI`G'\fP, \fI`v'\fP, \fI`V'\fP については、その改変は 1 コマンドで
行なわれたとして扱います。\fI`u'\fP は自分自身の動作を取り消すことも
できます。

.TP  8
(1,$)v\fI/re/command\-list\fP
指定した範囲の行のうち、指定した正規表現 \fIre\fP と一致する文字列が含まれ
ていない行について、 \fIcommand\-list\fP で指定したコマンドを実行します。
これは \fI`g'\fP コマンドに動作が似ています。

.TP  8
(1,$)V\fI/re/\fP
指定した範囲の行のうち、指定した正規表現 \fIre\fP に一致する文字列が
含まれていない行について、対話編集を行ないます。これは \fI`G'\fP コマンド
に動作が似ています。

.TP  8
(1,$)w\fI\ file\fP
指定した範囲の行を、 \fIfile\fP で指定したファイルに書き出します。それまで
\fIfile\fP に格納されていた内容は、警告なしに消去されます。デフォルトファ
イル名が設定されていない場合、デフォルトファイル名は \fIfile\fP に設定され
ます。それ以外の場合では、デフォルトファイル名は変更されません。ファイ
ル名が指定されなかった場合には、デフォルトファイル名が使用されます。
現在行番号は変更されません。

.TP  8
(1,$)wq\fI\ file\fP
指定した範囲の行を \fIfile\fP で指定したファイルに書き出し、
\fI`q'\fP コマンドを実行します。

.TP  8
(1,$)w !\fIcommand\fP
指定した範囲の行の内容を \fI!command\fP の標準入力に書き出します
(\fI`!command'\fP については、以下の説明を参照して下さい)。
デフォルトファイル名および現在行番号は変更されません。

.TP  8
(1,$)W\fI\ file\fP
指定した範囲の行の内容を \fIfile\fP で指定したファイルの後ろに追加書き込み
します。 \fI`w'\fP コマンドと似ていますが、指定したファイルにそれまで格納
されていた内容がなくなることはありません。現在行番号は変更されません。

.TP  8
(.)x
カットバッファの内容を指定された行の後ろにコピー (挿入) します。
現在行番号は最後にコピーが行われた行になります。

.TP  8
(.,.)y
指定した範囲の行の内容をカットバッファにコピー (yank) します。
カットバッファの内容は、これ以降にコマンド \fI`y'\fP, \fI`s'\fP, \fI`j'\fP,
\fI`d'\fP, \fI`c'\fP を実行すると上書きされます。
現在行番号は変更されません。

.TP  8
(.+1)z\fIn\fP
指定した行から一度に \fIn\fP 行だけスクロールします。 \fIn\fP が指定されない
場合には、現在のウィンドウサイズだけスクロールします。現在行番号は、
最後に表示した行の行番号に設定されます。

.TP  8
!\fIcommand\fP
\fIcommand\fP で指定したコマンドを、 \fBsh\fP(1) を用いて実行します。
\fIcommand\fP の最初の文字が `!'の場合には、その文字は直前に \fI!command\fP
で実行したコマンド文字列が格納されます。 \fIcommand\fP 文字列をバックスラッ
シュ (\e) でエスケープした場合には、\fBed\fP は処理を行ないません。しかし、
エスケープされない \fI`%'\fP 文字があった場合には、その文字列はデフォルト
ファイル名に置き換えられます。シェルがコマンド実行から戻ってきた場合に
は、`!' が標準出力に出力されます。現在行番号は変更されません。

.TP  8
(.,.)#
コメントを開始します。改行までの残りの行は無視されます。
行番号とその直後にセミコロンを指定した場合、
現在行番号は指定された行番号に設定されます。
それ以外の場合、現在行番号は変更されません。

.TP  8
($)=
指定された行の行番号を表示します。

.TP  8
(.+1)newline
指定した行を表示します。そして、現在行番号を表示した行のものに
設定します。

.SH ファイル
.TP  8
ed.hup
端末が回線切断した場合に、 \fBed\fP がバッファ内容を書き出すファイル。

.SH 関連項目

\fIvi\fP(1), \fIsed\fP(1), \fIregex\fP(3), \fIsh\fP(1).

USD:12\-13

B. W. Kernighan and P. J. Plauger, \fISoftware Tools in Pascal ,\fP
Addison\-Wesley, 1981.

.SH 制限
\fBed\fP は \fIfile\fP 引数に対してバックスラッシュエスケープ処理を施します。
つまり、ファイル名中でバックスラッシュ (\e) を前につけた文字は、
リテラルとして解釈されます。

(バイナリではない) テキストファイルの最後が改行文字で終っていない場合、
\fBed\fP はそれを読み書きする際に改行文字を追加します。バイナリファイルの
場合は、 \fBed\fP はこのような改行文字追加は行いません。

1 行あたりのオーバヘッドは、ポインタ 2 つ、long int 1 つ、 int 1 つです。

.SH 診断
エラーが発生すると、 \fBed\fP は `?' を表示し、コマンドモードに戻るか、
スクリプトによる実行のエラーの場合にはプログラムを終了します。最後の
エラーメッセージについての説明は、\fI`h'\fP (help) コマンドを用いることで
表示可能です。

変更されたバッファ内のデータを書き出さずに、\fBed\fP を終了しようとしたり、
他のファイルを編集しようとしたりすると、エラーになります。その場合でも、
同一のコマンドを 2 回入力すると、コマンドは成功します。しかし、それまで
の未保存の編集結果は、すべて失われます。

\fBed\fP はエラーが発生しなかった場合 0 で終了します。
それ以外の場合は >0 で終了します。