# SOME DESCRIPTIVE TITLE # Copyright (C) YEAR Free Software Foundation, Inc. # This file is distributed under the same license as the PACKAGE package. # FIRST AUTHOR , YEAR. # msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "POT-Creation-Date: 2012-05-01 04:22+0900\n" "PO-Revision-Date: 2012-05-01 04:51+0900\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" "Language: \n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" #. type: TH #: build/C/man3/fnmatch.3:26 #, no-wrap msgid "FNMATCH" msgstr "FNMATCH" #. type: TH #: build/C/man3/fnmatch.3:26 #, no-wrap msgid "2000-10-15" msgstr "2000-10-15" #. type: TH #: build/C/man3/fnmatch.3:26 build/C/man3/glob.3:32 build/C/man3/re_comp.3:25 #: build/C/man3/regex.3:32 #, no-wrap msgid "GNU" msgstr "GNU" #. type: TH #: build/C/man3/fnmatch.3:26 build/C/man3/glob.3:32 build/C/man7/glob.7:25 #: build/C/man3/re_comp.3:25 build/C/man3/regex.3:32 build/C/man7/regex.7:35 #: build/C/man3/wordexp.3:23 #, no-wrap msgid "Linux Programmer's Manual" msgstr "Linux Programmer's Manual" #. type: SH #: build/C/man3/fnmatch.3:27 build/C/man3/glob.3:33 build/C/man7/glob.7:26 #: build/C/man3/re_comp.3:26 build/C/man3/regex.3:33 build/C/man7/regex.7:36 #: build/C/man3/wordexp.3:24 #, no-wrap msgid "NAME" msgstr "名前" #. type: Plain text #: build/C/man3/fnmatch.3:29 msgid "fnmatch - match filename or pathname" msgstr "fnmatch - ファイル名またはパス名へのマッチを行う" #. type: SH #: build/C/man3/fnmatch.3:29 build/C/man3/glob.3:35 build/C/man3/re_comp.3:28 #: build/C/man3/regex.3:35 build/C/man3/wordexp.3:26 #, no-wrap msgid "SYNOPSIS" msgstr "書式" #. type: Plain text #: build/C/man3/fnmatch.3:32 #, no-wrap msgid "B<#include Efnmatch.hE>\n" msgstr "B<#include Efnmatch.hE>\n" #. type: Plain text #: build/C/man3/fnmatch.3:34 #, no-wrap msgid "BIB<, const char *>IB<, int >IB<);>\n" msgstr "BIB<, const char *>IB<, int >IB<);>\n" #. type: SH #: build/C/man3/fnmatch.3:35 build/C/man3/glob.3:47 build/C/man7/glob.7:28 #: build/C/man3/re_comp.3:38 build/C/man3/regex.3:51 build/C/man7/regex.7:38 #: build/C/man3/wordexp.3:41 #, no-wrap msgid "DESCRIPTION" msgstr "説明" #. type: Plain text #: build/C/man3/fnmatch.3:43 msgid "" "The B() function checks whether the I argument matches the " "I argument, which is a shell wildcard pattern." msgstr "" "B() 関数は I 引き数が I 引き数にマッチするかを" "チェックする。 I にはシェルのワイルドカードパターンを与える。" #. type: Plain text #: build/C/man3/fnmatch.3:48 msgid "" "The I argument modifies the behavior; it is the bitwise OR of zero or " "more of the following flags:" msgstr "" "I 引き数により動作を変更できる。 I は以下のフラグのビット毎の " "OR で指定する。" #. type: TP #: build/C/man3/fnmatch.3:48 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:52 msgid "" "If this flag is set, treat backslash as an ordinary character, instead of an " "escape character." msgstr "" "このフラグがセットされていると、バックスラッシュ (\\e) をエスケープ文字 では" "なく通常の文字として扱う。" #. type: TP #: build/C/man3/fnmatch.3:52 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:60 msgid "" "If this flag is set, match a slash in I only with a slash in " "I and not by an asterisk (*) or a question mark (?) metacharacter, " "nor by a bracket expression ([]) containing a slash." msgstr "" "このフラグがセットされていると、 I 中のスラッシュ (/) を I " "にあるスラッシュそのものにだけマッチさせ、 アスタリスク (*) や疑問符 (?) のメ" "タキャラクタや、 スラッシュを含むブラケット表現 ([]) にはマッチさせない。" #. type: TP #: build/C/man3/fnmatch.3:60 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:71 msgid "" "If this flag is set, a leading period in I has to be matched exactly " "by a period in I. A period is considered to be leading if it is " "the first character in I, or if both B is set and the " "period immediately follows a slash." msgstr "" "このフラグがセットされていると、 I の先頭ピリオド (leading period) " "は I 中のピリオドそのものにしかマッチしない。先頭ピリオドとは、 " "I の最初の文字位置にあるピリオドのことである。ただし B " "フラグが同時にセットされている場合には、スラッシュの直後に続くピリオド も先頭" "ピリオドとみなされる。" #. type: TP #: build/C/man3/fnmatch.3:71 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:74 msgid "This is a GNU synonym for B." msgstr "これは B に対する GNU での同義語である." #. type: TP #: build/C/man3/fnmatch.3:74 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:82 msgid "" "If this flag (a GNU extension) is set, the pattern is considered to be " "matched if it matches an initial segment of I which is followed by a " "slash. This flag is mainly for the internal use of glibc and is only " "implemented in certain cases." msgstr "" "このフラグは GNU での拡張である。これがセットされている場合には、 パターンが " "I の最初の部分 (にスラッシュを付けたもの) にマッチすれば、 マッチした" "ものとみなされる。 このフラグは主として glibc で内部的に使用し、そのためのみ" "実装されている。" #. type: TP #: build/C/man3/fnmatch.3:82 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/fnmatch.3:86 msgid "" "If this flag (a GNU extension) is set, the pattern is matched case-" "insensitively." msgstr "" "このフラグは GNU での拡張である。これがセットされている場合には、 パターンの" "マッチに大文字小文字が区別されない。" #. type: SH #: build/C/man3/fnmatch.3:86 build/C/man3/glob.3:257 build/C/man3/re_comp.3:56 #: build/C/man3/regex.3:237 build/C/man3/wordexp.3:156 #, no-wrap msgid "RETURN VALUE" msgstr "返り値" #. type: Plain text #: build/C/man3/fnmatch.3:93 msgid "" "Zero if I matches I, B if there is no match or " "another nonzero value if there is an error." msgstr "" "I が I にマッチすれば 0 を返す。マッチしなかった場合には " "B を返す。エラーの場合にはそれ以外の非ゼロ値を返す。" #. type: SH #: build/C/man3/fnmatch.3:93 build/C/man3/glob.3:271 build/C/man3/re_comp.3:64 #: build/C/man3/regex.3:294 build/C/man3/wordexp.3:186 #, no-wrap msgid "CONFORMING TO" msgstr "準拠" #. type: Plain text #: build/C/man3/fnmatch.3:98 msgid "" "POSIX.2. The B, B, and B " "flags are GNU extensions." msgstr "" "POSIX.2. B, B, B フラグは GNU " "の拡張である。" #. type: SH #: build/C/man3/fnmatch.3:98 build/C/man3/glob.3:314 build/C/man7/glob.7:204 #: build/C/man3/re_comp.3:70 build/C/man3/regex.3:296 build/C/man7/regex.7:284 #: build/C/man3/wordexp.3:212 #, no-wrap msgid "SEE ALSO" msgstr "関連項目" #. type: Plain text #: build/C/man3/fnmatch.3:104 msgid "B(1), B(3), B(3), B(3), B(7)" msgstr "B(1), B(3), B(3), B(3), B(7)" #. type: SH #: build/C/man3/fnmatch.3:104 build/C/man3/glob.3:325 build/C/man7/glob.7:210 #: build/C/man3/re_comp.3:74 build/C/man3/regex.3:300 build/C/man7/regex.7:289 #: build/C/man3/wordexp.3:215 #, no-wrap msgid "COLOPHON" msgstr "この文書について" #. type: Plain text #: build/C/man3/fnmatch.3:111 build/C/man3/glob.3:332 build/C/man7/glob.7:217 #: build/C/man3/re_comp.3:81 build/C/man3/regex.3:307 build/C/man7/regex.7:296 #: build/C/man3/wordexp.3:222 msgid "" "This page is part of release 3.40 of the Linux I project. A " "description of the project, and information about reporting bugs, can be " "found at http://www.kernel.org/doc/man-pages/." msgstr "" "この man ページは Linux I プロジェクトのリリース 3.40 の一部\n" "である。プロジェクトの説明とバグ報告に関する情報は\n" "http://www.kernel.org/doc/man-pages/ に書かれている。" #. type: TH #: build/C/man3/glob.3:32 build/C/man7/glob.7:25 #, no-wrap msgid "GLOB" msgstr "GLOB" #. type: TH #: build/C/man3/glob.3:32 #, no-wrap msgid "2007-10-10" msgstr "2007-10-10" #. type: Plain text #: build/C/man3/glob.3:35 msgid "" "glob, globfree - find pathnames matching a pattern, free memory from glob()" msgstr "" "glob, globfree - パターンにマッチするパス名を見付ける。glob() によっ て確保さ" "れたメモリ領域を解放する。" #. type: Plain text #: build/C/man3/glob.3:38 #, no-wrap msgid "B<#include Eglob.hE>\n" msgstr "B<#include Eglob.hE>\n" #. type: Plain text #: build/C/man3/glob.3:40 #, no-wrap msgid "BIB<, int >IB<,>\n" msgstr "BIB<, int >IB<,>\n" #. type: Plain text #: build/C/man3/glob.3:42 #, no-wrap msgid "B< int (*>IB<) (const char *>IB<, int >IB<),>\n" msgstr "B< int (*>IB<) (const char *>IB<, int >IB<),>\n" #. type: Plain text #: build/C/man3/glob.3:44 #, no-wrap msgid "B< glob_t *>IB<);>\n" msgstr "B< glob_t *>IB<);>\n" #. type: Plain text #: build/C/man3/glob.3:46 #, no-wrap msgid "BIB<);>\n" msgstr "BIB<);>\n" #. type: Plain text #: build/C/man3/glob.3:57 msgid "" "The B() function searches for all the pathnames matching I " "according to the rules used by the shell (see B(7)). No tilde " "expansion or parameter substitution is done; if you want these, use " "B(3)." msgstr "" "B() 関数はシェルが用いているルール (B(7) 参照) に基づいてパター" "ン I にマッチするすべてのパス名を検索する。 チルダ (~) の展開やパラ" "メータ置換は行われない。それらを行いたい場合は B(3) を使うとよい。" #. type: Plain text #: build/C/man3/glob.3:63 msgid "" "The B() function frees the dynamically allocated storage from an " "earlier call to B()." msgstr "" "B() 関数は前に呼ばれた B() により動的に確保された記憶領域を" "解放する。" #. type: Plain text #: build/C/man3/glob.3:74 msgid "" "The results of a B() call are stored in the structure pointed to by " "I. This structure is of type I (declared in Iglob." "hE>) and includes the following elements defined by POSIX.2 (more may " "be present as an extension):" msgstr "" "B() の結果は I がポイントする構造体に返される。 I は " "I 型の構造体である。 I 型は Iglob.hE> 内で宣言され" "ており、以下の要素を含んでいる。これらの要素は POSIX.2 で定義 されている (さ" "らに多くの要素が拡張として入っているかもしれない)。" #. type: Plain text #: build/C/man3/glob.3:83 #, no-wrap msgid "" "typedef struct {\n" " size_t gl_pathc; /* Count of paths matched so far */\n" " char **gl_pathv; /* List of matched pathnames. */\n" " size_t gl_offs; /* Slots to reserve in I. */\n" "} glob_t;\n" msgstr "" "typedef struct {\n" " size_t gl_pathc; /* 今までにマッチしたパスの数 */\n" " char **gl_pathv; /* マッチしたパス名のリスト */\n" " size_t gl_offs; /* I 内に確保するスロット数 */\n" "} glob_t;\n" #. type: Plain text #: build/C/man3/glob.3:87 msgid "Results are stored in dynamically allocated storage." msgstr "結果は動的に確保された記憶領域に入れられる。" #. type: Plain text #: build/C/man3/glob.3:93 msgid "" "The argument I is made up of the bitwise OR of zero or more the " "following symbolic constants, which modify the behavior of B():" msgstr "" "パラメータ I には以下の示す定数のうち、指定したいものをビットごとの " "OR で与える (一つも 指定しなくてもよい)。これによって B() の動作を変更" "できる。" #. type: TP #: build/C/man3/glob.3:93 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:101 msgid "" "Return upon a read error (because a directory does not have read permission, " "for example). By default, B() attempts carry on despite errors, " "reading all of the directories that it can." msgstr "" "(例えば、ディレクトリに読み取り許可属性が無い場合などで) 読み取りエラーが発" "生した際に関数から戻る。 デフォルトでは、エラーに関わらず 読み取り可能なディ" "レクトリを全てについて読み取りを実行しようとする。" #. type: TP #: build/C/man3/glob.3:101 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:104 msgid "Append a slash to each path which corresponds to a directory." msgstr "ディレクトリに対応する各々のパスにスラッシュを付加する。" #. type: TP #: build/C/man3/glob.3:104 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:109 msgid "" "Don't sort the returned pathnames. The only reason to do this is to save " "processing time. By default, the returned pathnames are sorted." msgstr "" "返されるパス名のソートを行わない。 ソートを行わない理由は、処理時間を節約する" "ためだけである。 デフォルトでは、返されるパス名はソートされる。" #. type: TP #: build/C/man3/glob.3:109 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:116 msgid "" "Reserve Igl_offs> slots at the beginning of the list of strings " "in Ipathv>. The reserved slots contain NULL pointers." msgstr "" "Ipathv> の文字列リストの先頭に Igl_offs> スロット分の" "領域を予約する。 予約されたスロットには NULL ポインタが入る。" #. type: TP #: build/C/man3/glob.3:116 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:124 msgid "" "If no pattern matches, return the original pattern. By default, B() " "returns B if there are no matches." msgstr "" "マッチするパターンがなければ、元のパターンを返す。 デフォルトでは、 B" "() はマッチするパターンがなければ B を返す。" #. type: TP #: build/C/man3/glob.3:124 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:131 msgid "" "Append the results of this call to the vector of results returned by a " "previous call to B(). Do not set this flag on the first invocation of " "B()." msgstr "" "この呼び出しでの結果を直前の B() の呼び出しで返された結果のベクトルに" "追加する。最初の B() の呼び出しの際にはこのフラグを設定してはいけな" "い。" #. type: TP #: build/C/man3/glob.3:131 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:138 msgid "" "Don't allow backslash (\\(aq\\e\\(aq) to be used as an escape character. " "Normally, a backslash can be used to quote the following character, " "providing a mechanism to turn off the special meaning metacharacters." msgstr "" "バックスラッシュ (\\(aq\\e\\(aq) をエスケープ用文字として使用できない。 通常" "は、バックスラッシュを使って、次に続く文字をクォートすることで、 特別な意味を" "持つメタキャラクタを無効することができる。" #. type: Plain text #: build/C/man3/glob.3:142 msgid "" "I may also include any of the following, which are GNU extensions and " "not defined by POSIX.2:" msgstr "" "I には以下に示すものも指定できる。 これらは GNU で拡張されたもので、" "POSIX.2 では定義されていない。" #. type: TP #: build/C/man3/glob.3:142 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:146 msgid "" "Allow a leading period to be matched by metacharacters. By default, " "metacharacters can't match a leading period." msgstr "" "先頭のピリオドがメタキャラクタにマッチできるようにする。 デフォルトでは、メタ" "キャラクタは先頭のピリオドにはマッチできない。" #. type: TP #: build/C/man3/glob.3:146 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:156 msgid "" "Use alternative functions Igl_closedir>, Igl_readdir>, Igl_opendir>, Igl_lstat>, and " "Igl_stat> for file system access instead of the normal library " "functions." msgstr "" "ファイルシステムにアクセスする際に、通常のライブラリ関数の代わりに 代替関数 " "Igl_closedir>, Igl_readdir>, Igl_opendir>, Igl_lstat>, Igl_stat> が用いられ" "る。" #. type: TP #: build/C/man3/glob.3:156 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:171 msgid "" "Expand B(1) style brace expressions of the form B<{a,b}>. Brace " "expressions can be nested. Thus, for example, specifying the pattern \"{foo/" "{,cat,dog},bar}\" would return the same results as four separate B() " "calls using the strings: \"foo/\", \"foo/cat\", \"foo/dog\", and \"bar\"." msgstr "" "B<{a,b}> という形式の B(1) スタイルの括弧表現を展開する。 括弧表現は入" "れ子にすることができる。 したがって、例えば、\"{foo/{,cat,dog},bar}\" という" "パターンを 指定した場合に得られる結果は、 4つの文字列 \"foo/\", \"foo/cat\", " "\"foo/dog\", \"bar\" のそれぞれについて B() を呼び出した場合と同じにな" "る。" #. type: TP #: build/C/man3/glob.3:171 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:176 msgid "" "If the pattern contains no metacharacters then it should be returned as the " "sole matching word, even if there is no file with that name." msgstr "" "パターンにメタキャラクタが含まれていない場合、 マッチ結果として指定されたパ" "ターンだけを返す。 パターンで指定された名前のファイルが存在しない場合であって" "も、 そのパターンが返される。" #. type: TP #: build/C/man3/glob.3:176 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:188 msgid "" "Carry out tilde expansion. If a tilde (\\(aq~\\(aq) is the only character " "in the pattern, or an initial tilde is followed immediately by a slash " "(\\(aq/\\(aq), then the home directory of the caller is substituted for the " "tilde. If an initial tilde is followed by a username (e.g., \"~andrea/bin" "\"), then the tilde and username are substituted by the home directory of " "that user. If the username is invalid, or the home directory cannot be " "determined, then no substitution is performed." msgstr "" "チルダの展開を行う。 チルダ (\\(aq~\\(aq) がパターン内の唯一の文字の場合か、" "先頭のチルダの直後の文字が スラッシュ (\\(aq/\\(aq) の場合、チルダを呼び出し" "者のホームディレクトリで置換する。 先頭のチルダにユーザ名が続く場合 (例えば " "\"~andrea/bin\")、 チルダとユーザ名をそのユーザのホームディレクトリで置換す" "る。 ユーザ名が無効な場合やホームディレクトリが決定できない場合は、 置換は実" "行されない。" #. type: TP #: build/C/man3/glob.3:188 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:199 msgid "" "This provides behavior similar to that of B. The difference is " "that if the username is invalid, or the home directory cannot be determined, " "then instead of using the pattern itself as the name, B() returns " "B to indicate an error." msgstr "" "このフラグを指定すると B と同様の振舞いをする。 B と" "の違いは、ユーザ名が無効だった場合や ホームディレクトリが決定できなかった場合" "に、 パターン自身を使用するのではなく、 B() がエラーを示す " "B を返すことである。" #. type: TP #: build/C/man3/glob.3:199 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:212 msgid "" "This is a I to B() that the caller is interested only in " "directories that match the pattern. If the implementation can easily " "determine file-type information, then nondirectory files are not returned to " "the caller. However, the caller must still check that returned files are " "directories. (The purpose of this flag is merely to optimize performance " "when the caller is interested only in directories.)" msgstr "" "このフラグは、 B() に対する「ヒント」であり、 呼び出し側がパターンに" "マッチするディレクトリにしか興味がないことを知らせる。 実装においてファイルの" "種別情報を簡単に決定できる場合は、ディレクトリでない ファイルは呼び出し側に返" "されない。しかしながら、呼び出し側では、返された ファイルリストがディレクトリ" "かどうかを確認しなければならない。 (このフラグが存在するのは、呼び出し側が" "ディレクトリにしか興味がない際に 性能を最適化する目的のためだけである。)" #. type: Plain text #: build/C/man3/glob.3:235 msgid "" "If I is not NULL, it will be called in case of an error with the " "arguments I, a pointer to the path which failed, and I, the " "value of I as returned from one of the calls to B(3), " "B(3), or B(2). If I returns nonzero, or if " "B is set, B() will terminate after the call to I." msgstr "" "I が NULL でなければ、 エラーが起こった場合には関数 I が呼" "び出される。関数の引数には、失敗したパス名 I と I (B" "(3), B(3), B(2). のいずれかによってセットされた値) が与えられ" "る。 I が 0 以外の値を返すかもしくは B がセットされた場合 " "B() は I の呼び出し後に終了する。" #. type: Plain text #: build/C/man3/glob.3:242 msgid "" "Upon successful return, Igl_pathc> contains the number of " "matched pathnames and Igl_pathv> contains a pointer to the list " "of pointers to matched pathnames. The list of pointers is terminated by a " "NULL pointer." msgstr "" "呼び出しが成功して戻った場合 Igl_pathc> にはマッチしたパス名が含" "まれ、 Igl_pathv> はマッチしたパス名へのポインタのリストへのポイ" "ンタとなる。 ポインタのリストは NULL ポインタで終端される。" #. type: Plain text #: build/C/man3/glob.3:251 msgid "" "It is possible to call B() several times. In that case, the " "B flag has to be set in I on the second and later " "invocations." msgstr "" "B() を何度か続けて呼び出すことができる。その際2回目以降の呼び出しでは " "B フラグが I に設定されていなければならない。" #. type: Plain text #: build/C/man3/glob.3:257 msgid "" "As a GNU extension, Igl_flags> is set to the flags specified, " "Bed with B if any metacharacters were found." msgstr "" "GNU の拡張として、 Igl_flags> には指定したフラグがセットされる。" "もし一つでもメタキャラクタが見付かれば このフラグと B との " "B を取った結果がセットされる。" #. type: Plain text #: build/C/man3/glob.3:262 msgid "" "On successful completion, B() returns zero. Other possible returns " "are:" msgstr "" "呼び出しが成功して完了すると B() は 0 を返す。 それ以外の返り値は以下" "の通り:" #. type: TP #: build/C/man3/glob.3:262 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:265 msgid "for running out of memory," msgstr "メモリを使い果たした" #. type: TP #: build/C/man3/glob.3:265 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:268 msgid "for a read error, and" msgstr "読み取りエラー" #. type: TP #: build/C/man3/glob.3:268 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/glob.3:271 msgid "for no found matches." msgstr "一つもマッチしなかった" #. type: Plain text #: build/C/man3/glob.3:273 msgid "POSIX.2, POSIX.1-2001." msgstr "POSIX.2, POSIX.1-2001." #. type: SH #: build/C/man3/glob.3:273 build/C/man7/glob.7:136 build/C/man3/re_comp.3:66 #, no-wrap msgid "NOTES" msgstr "注意" #. type: Plain text #: build/C/man3/glob.3:284 msgid "" "The structure elements I and I are declared as I " "in glibc 2.1, as they should be according to POSIX.2, but are declared as " "I in libc4, libc5 and glibc 2.0." msgstr "" "glibc 2.1 では、 I と I は POSIX.2 で指定されているように " "I として宣言されている。 libc4, libc5, glibc 2.0 では、 I として" "宣言されている。" #. type: SH #: build/C/man3/glob.3:284 build/C/man7/regex.7:257 #, no-wrap msgid "BUGS" msgstr "バグ" #. type: Plain text #: build/C/man3/glob.3:293 msgid "" "The B() function may fail due to failure of underlying function " "calls, such as B(3) or B(3). These will store their error " "code in I." msgstr "" "B() 関数はその中で呼び出している B(3) や B(3) など" "の関数の呼び出しで失敗が起こると失敗する。 これにより I にそのエラー" "コードが入る。" #. type: SH #: build/C/man3/glob.3:293 build/C/man3/wordexp.3:188 #, no-wrap msgid "EXAMPLE" msgstr "例" #. type: Plain text #: build/C/man3/glob.3:295 msgid "One example of use is the following code, which simulates typing" msgstr "使用法の一例を以下に示す。以下はシェルで" #. type: Plain text #: build/C/man3/glob.3:298 msgid "ls -l *.c ../*.c" msgstr "ls -l *.c ../*.c" #. type: Plain text #: build/C/man3/glob.3:301 msgid "in the shell:" msgstr "をタイプした場合をシミュレートしている。" #. type: Plain text #: build/C/man3/glob.3:305 #, no-wrap msgid "glob_t globbuf;\n" msgstr "glob_t globbuf;\n" #. type: Plain text #: build/C/man3/glob.3:312 #, no-wrap msgid "" "globbuf.gl_offs = 2;\n" "glob(\"*.c\", GLOB_DOOFFS, NULL, &globbuf);\n" "glob(\"../*.c\", GLOB_DOOFFS | GLOB_APPEND, NULL, &globbuf);\n" "globbuf.gl_pathv[0] = \"ls\";\n" "globbuf.gl_pathv[1] = \"-l\";\n" "execvp(\"ls\", &globbuf.gl_pathv[0]);\n" msgstr "" "globbuf.gl_offs = 2;\n" "glob(\"*.c\", GLOB_DOOFFS, NULL, &globbuf);\n" "glob(\"../*.c\", GLOB_DOOFFS | GLOB_APPEND, NULL, &globbuf);\n" "globbuf.gl_pathv[0] = \"ls\";\n" "globbuf.gl_pathv[1] = \"-l\";\n" "execvp(\"ls\", &globbuf.gl_pathv[0]);\n" #. type: Plain text #: build/C/man3/glob.3:325 msgid "" "B(1), B(1), B(2), B(3), B(3), B(3), " "B(3), B(3), B(3), B(7)" msgstr "" "B(1), B(1), B(2), B(3), B(3), B(3), " "B(3), B(3), B(3), B(7)" #. type: TH #: build/C/man7/glob.7:25 #, no-wrap msgid "2003-08-24" msgstr "2003-08-24" #. type: TH #: build/C/man7/glob.7:25 #, no-wrap msgid "Linux" msgstr "Linux" #. type: Plain text #: build/C/man7/glob.7:28 msgid "glob - Globbing pathnames" msgstr "glob - パス名を glob する" #. type: Plain text #: build/C/man7/glob.7:33 msgid "" "Long ago, in UNIX V6, there was a program I that would expand " "wildcard patterns. Soon afterward this became a shell built-in." msgstr "" "昔々 UNIX V6 では、ワイルドカードパターンを展開する I と言うプログ" "ラムがあった。その後すぐに、 この機能はシェルに組み込まれるようになった。" #. type: Plain text #: build/C/man7/glob.7:37 msgid "" "These days there is also a library routine B(3) that will perform " "this function for a user program." msgstr "" "今日では、この機能をユーザープログラムからも実行できるよう、 B(3) とい" "うライブラリルーチンも存在している。" #. type: Plain text #: build/C/man7/glob.7:39 msgid "The rules are as follows (POSIX.2, 3.13)." msgstr "glob の規則を以下に述べる (POSIX.2 3.13)。" #. type: SS #: build/C/man7/glob.7:39 #, no-wrap msgid "Wildcard Matching" msgstr "ワイルドカードマッチ" #. type: Plain text #: build/C/man7/glob.7:46 msgid "" "A string is a wildcard pattern if it contains one of the characters \\(aq?" "\\(aq, \\(aq*\\(aq or \\(aq[\\(aq. Globbing is the operation that expands a " "wildcard pattern into the list of pathnames matching the pattern. Matching " "is defined by:" msgstr "" "文字列に \\(aq?\\(aq, \\(aq*\\(aq, \\(aq[\\(aq が含まれていると、 それはワイ" "ルドカードパターンとみなされる。 「glob する」というのは、ワイルドカードパ" "ターンを展開して、 そのパターンにマッチするパス名のリストを得ることである。 " "マッチは以下のように定義される。" #. type: Plain text #: build/C/man7/glob.7:48 msgid "A \\(aq?\\(aq (not between brackets) matches any single character." msgstr "(ブラケット外部の) \\(aq?\\(aq はあらゆる単一の文字にマッチする。" #. type: Plain text #: build/C/man7/glob.7:51 msgid "" "A \\(aq*\\(aq (not between brackets) matches any string, including the empty " "string." msgstr "" "(ブラケット外部の) \\(aq*\\(aq はあらゆる文字列にマッチする。 空文字列 " "(empty string) にもマッチする。" #. type: Plain text #: build/C/man7/glob.7:53 msgid "B" msgstr "B<文字クラス (character class)>" #. type: Plain text #: build/C/man7/glob.7:62 msgid "" "An expression \"I<[...]>\" where the first character after the leading \\(aq" "[\\(aq is not an \\(aq!\\(aq matches a single character, namely any of the " "characters enclosed by the brackets. The string enclosed by the brackets " "cannot be empty; therefore \\(aq]\\(aq can be allowed between the brackets, " "provided that it is the first character. (Thus, \"I<[][!]>\" matches the " "three characters \\(aq[\\(aq, \\(aq]\\(aq and \\(aq!\\(aq.)" msgstr "" "\"I<[...]>\" と言う表記は、先頭の \\(aq[\\(aq に続く最初の文字が \\(aq!\\(aq " "で なければ、ブラケットの中に含まれている文字のどれか一つにマッチする。 ブラ" "ケットの内部に含まれる文字列は空であってはならない。 したがって \\(aq]\\(aq " "も最初の文字に指定すればブラケットの内部に含めることが できる (つまり \"I<[]" "[!]>\" は \\(aq[\\(aq, \\(aq]\\(aq, \\(aq!\\(aq の 3 文字のどれかにマッチす" "る)。" #. type: Plain text #: build/C/man7/glob.7:64 msgid "B" msgstr "B<領域指定 (range)>" #. type: Plain text #: build/C/man7/glob.7:75 msgid "" "There is one special convention: two characters separated by \\(aq-\\(aq " "denote a range. (Thus, \"I<[A-Fa-f0-9]>\" is equivalent to \"I<" "[ABCDEFabcdef0123456789]>\".) One may include \\(aq-\\(aq in its literal " "meaning by making it the first or last character between the brackets. " "(Thus, \"I<[]-]>\" matches just the two characters \\(aq]\\(aq and \\(aq-" "\\(aq, and \"I<[--0]>\" matches the three characters \\(aq-\\(aq, \\(aq." "\\(aq, \\(aq0\\(aq, since \\(aq/\\(aq cannot be matched.)" msgstr "" "特殊な表記法が一つ存在する。\\(aq-\\(aq を挟む二つの文字は領域指定となる。 " "(つまり \"I<[A-Fa-f0-9]>\" は \"I<[ABCDEFabcdef0123456789]>\" と等価とな" "る。) \\(aq-\\(aq 文字そのものを入れたい場合は、 ブラケットの先頭または最後の" "文字に指定すればよい。 (つまり \"I<[]-]>\" は二つの文字 \\(aq]\\(aq と \\(aq-" "\\(aq にマッチし、\"I<[--0]>\" は \\(aq-\\(aq, \\(aq.\\(aq, \\(aq0\\(aq の 3 " "文字にマッチする。この間の \\(aq/\\(aq にはマッチしない。後述を参照。)" #. type: Plain text #: build/C/man7/glob.7:77 msgid "B" msgstr "B<補集合 (complementation)>" #. type: Plain text #: build/C/man7/glob.7:83 msgid "" "An expression \"I<[!...]>\" matches a single character, namely any character " "that is not matched by the expression obtained by removing the first \\(aq!" "\\(aq from it. (Thus, \"I<[!]a-]>\" matches any single character except " "\\(aq]\\(aq, \\(aqa\\(aq and \\(aq-\\(aq.)" msgstr "" "\"I<[!...]>\" と言う表記は、ブラケットの内部に含まれない単一の文字にマッチす" "る (ただし先頭にある \\(aq!\\(aq は除外)。 (つまり \"I<[!]a-]>\" は " "\\(aq]\\(aq, \\(aqa\\(aq, \\(aq-\\(aq 以外のすべての文字の、どれか一つにマッ" "チする。)" #. type: Plain text #: build/C/man7/glob.7:90 msgid "" "One can remove the special meaning of \\(aq?\\(aq, \\(aq*\\(aq and \\(aq" "[\\(aq by preceding them by a backslash, or, in case this is part of a shell " "command line, enclosing them in quotes. Between brackets these characters " "stand for themselves. Thus, \"I<[[?*\\e]>\" matches the four characters " "\\(aq[\\(aq, \\(aq?\\(aq, \\(aq*\\(aq and \\(aq\\e\\(aq." msgstr "" "バックスラッシュ \\(aq\\e\\(aq を前置すれば、 \\(aq?\\(aq, \\(aq*\\(aq, \\(aq" "[\\(aq は通常の文字として扱われる。 またはシェルのコマンドラインの一部に指定" "する場合は、 クォートで囲っても同じ効果が得られる。ブラケットの内部では、 こ" "れらの文字はその文字自身だけを意味する。 すなわち \"I<[[?*\\e]>\" は \\(aq" "[\\(aq, \\(aq?\\(aq, \\(aq*\\(aq, \\(aq\\e\\(aq のどれか一文字にマッチする。" #. type: SS #: build/C/man7/glob.7:90 #, no-wrap msgid "Pathnames" msgstr "パス名 (pathname)" #. type: Plain text #: build/C/man7/glob.7:97 msgid "" "Globbing is applied on each of the components of a pathname separately. A " "\\(aq/\\(aq in a pathname cannot be matched by a \\(aq?\\(aq or \\(aq*\\(aq " "wildcard, or by a range like \"I<[.-0]>\". A range cannot contain an " "explicit \\(aq/\\(aq character; this would lead to a syntax error." msgstr "" "glob 動作は、パス名のそれぞれの部分に独立に適用される。 パス名に存在する " "\\(aq/\\(aq は \\(aq?\\(aq や \\(aq*\\(aq ワイルドカードにはマッチしない。 ま" "た \"I<[.-0]>\" のような領域指定にもマッチしない。 領域指定は陽に \\(aq/" "\\(aq 文字を含むことはできない。これは文法エラーとなる。" #. type: Plain text #: build/C/man7/glob.7:102 msgid "" "If a filename starts with a \\(aq.\\(aq, this character must be matched " "explicitly. (Thus, I will not remove .profile, and I " "will not archive all your files; I is better.)" msgstr "" "\\(aq.\\(aq で始まるパス名では、この文字は陽にマッチさせなければならない。 " "(つまり I は .profile を削除しない。また I ではすべての" "ファイルはアーカイブされない。 I の方が良い。)" #. type: SS #: build/C/man7/glob.7:102 #, no-wrap msgid "Empty Lists" msgstr "空のリスト" #. type: Plain text #: build/C/man7/glob.7:108 msgid "" "The nice and simple rule given above: \"expand a wildcard pattern into the " "list of matching pathnames\" was the original UNIX definition. It allowed " "one to have patterns that expand into an empty list, as in" msgstr "" "先に与えた、わかりやすく簡単なルール、 「ワイルドカードパターンをマッチしたパ" "ス名のリストに展開する」と言うのは、 オリジナルの UNIX における定義であっ" "た。 これはパターンが空のリストに展開されることも許可されていた。 例えば" #. type: Plain text #: build/C/man7/glob.7:111 #, no-wrap msgid " xv -wait 0 *.gif *.jpg\n" msgstr " xv -wait 0 *.gif *.jpg\n" #. type: Plain text #: build/C/man7/glob.7:121 msgid "" "where perhaps no *.gif files are present (and this is not an error). " "However, POSIX requires that a wildcard pattern is left unchanged when it is " "syntactically incorrect, or the list of matching pathnames is empty. With " "I one can force the classical behavior by setting " "I." msgstr "" "において、*.gif ファイルが全くない場合でも、 これは空のリストに展開されるた" "め、エラーにならない。 しかし POSIX では、文法的に正しくないパターンや、 マッ" "チがなかったパターンは、 そのまま変更されずに残されることになっている。 " "I では I を指定することで、以前の振る舞" "いに設定することができる。" #. type: Plain text #: build/C/man7/glob.7:124 msgid "(Similar problems occur elsewhere. E.g., where old scripts have" msgstr "" "(同様の問題は別のところでも起こっている。例えば、古いスクリプトにおける" #. type: Plain text #: build/C/man7/glob.7:127 #, no-wrap msgid " rm \\`find . -name \"*~\"\\`\n" msgstr " rm \\`find . -name \"*~\"\\`\n" #. type: Plain text #: build/C/man7/glob.7:129 msgid "new scripts require" msgstr "のような記述は、新しいスクリプトでは" #. type: Plain text #: build/C/man7/glob.7:132 #, no-wrap msgid " rm -f nosuchfile \\`find . -name \"*~\"\\`\n" msgstr " rm -f nosuchfile \\`find . -name \"*~\"\\`\n" #. type: Plain text #: build/C/man7/glob.7:136 msgid "to avoid error messages from I called with an empty argument list.)" msgstr "" "のようにしなければならない。さもないと I を引き数リストなしで呼び出す可能" "性があり、 エラーメッセージが出てしまう。)" #. type: SS #: build/C/man7/glob.7:137 #, no-wrap msgid "Regular expressions" msgstr "正規表現" #. type: Plain text #: build/C/man7/glob.7:144 msgid "" "Note that wildcard patterns are not regular expressions, although they are a " "bit similar. First of all, they match filenames, rather than text, and " "secondly, the conventions are not the same: for example, in a regular " "expression \\(aq*\\(aq means zero or more copies of the preceding thing." msgstr "" "ワイルドカードパターンは正規表現と多少似ているが、しかしこの両者は異なる。 ま" "ず第一に、前者がファイル名にマッチするのに対して、 後者はテキストにマッチす" "る。第二に、ルールも同じではない。 例えば正規表現における \\(aq*\\(aq は、 前" "置された文字の 0 以上の繰り返しを表す。" #. type: Plain text #: build/C/man7/glob.7:148 msgid "" "Now that regular expressions have bracket expressions where the negation is " "indicated by a \\(aq^\\(aq, POSIX has declared the effect of a wildcard " "pattern \"I<[^...]>\" to be undefined." msgstr "" "正規表現にもブラケット表現はあるが、否定は \\(aq^\\(aq でなされる。 POSIX で" "はワイルドカードパターンにおける \"I<[^...]>\" を未定義であるとしている。" #. type: SS #: build/C/man7/glob.7:148 #, no-wrap msgid "Character classes and Internationalization" msgstr "文字クラスと国際化" #. type: Plain text #: build/C/man7/glob.7:166 msgid "" "Of course ranges were originally meant to be ASCII ranges, so that \"I<[\\ -" "%]>\" stands for \"I<[\\ !\"#$%]>\" and \"I<[a-z]>\" stands for \"any " "lowercase letter\". Some UNIX implementations generalized this so that a " "range X-Y stands for the set of characters with code between the codes for X " "and for Y. However, this requires the user to know the character coding in " "use on the local system, and moreover, is not convenient if the collating " "sequence for the local alphabet differs from the ordering of the character " "codes. Therefore, POSIX extended the bracket notation greatly, both for " "wildcard patterns and for regular expressions. In the above we saw three " "types of items that can occur in a bracket expression: namely (i) the " "negation, (ii) explicit single characters, and (iii) ranges. POSIX " "specifies ranges in an internationally more useful way and adds three more " "types:" msgstr "" "領域指定は、もともとはもちろん ASCII における順序並びを意味していた。 した" "がって \"I<[\\ -%]>\" は \"I<[\\ !\"#$%]>\" の意味であり、 \"I<[a-z]>\" は" "「すべての小文字」の意味であった。 UNIX の実装の中には、これを拡張したものが" "存在し、 そこでは X-Y という領域指定は、X のコードと Y のコードに挟まれたコー" "ドを持つ文字すべてを表すようになっていた。 しかし、これにはユーザーがローカル" "なシステムにおける 文字コードを知らなければならず、 さらにローカルなアルファ" "ベットに対する照合順序 (collating sequence) が文字コードの順序と異なっている" "場合には不便であった。 (訳注: collating sequence に関しては B(7) を参" "照して下さい。) したがって POSIX では、ワイルドカードパターンと正規表現の双" "方において、 ブラケット表記を大幅に拡張している。 これまで我々は、ブラケット" "表記には三つの要素が含まれうることを見てきた。 すなわち (i) 否定、(ii) 単一の" "文字、(iii) 領域指定、の三つである。 POSIX では、領域指定をより国際化に便利な" "ように定義しており、 また三つのタイプをブラケット表記の要素として追加してい" "る。" #. type: Plain text #: build/C/man7/glob.7:172 msgid "" "(iii) Ranges X-Y comprise all characters that fall between X and Y " "(inclusive) in the current collating sequence as defined by the " "B category in the current locale." msgstr "" "(iii) 領域指定 X-Y は X と Y に挟まれた (両端含む) すべての文字を意味する。 " "このとき、カレントロケール (current locale) の B カテゴリで定義さ" "れている照合順序が用いられる。" #. type: Plain text #: build/C/man7/glob.7:174 msgid "(iv) Named character classes, like" msgstr "(iv) 名前付き文字クラス: 以下のようなものである。" #. type: Plain text #: build/C/man7/glob.7:179 #, no-wrap msgid "" "[:alnum:] [:alpha:] [:blank:] [:cntrl:]\n" "[:digit:] [:graph:] [:lower:] [:print:]\n" "[:punct:] [:space:] [:upper:] [:xdigit:]\n" msgstr "" "[:alnum:] [:alpha:] [:blank:] [:cntrl:]\n" "[:digit:] [:graph:] [:lower:] [:print:]\n" "[:punct:] [:space:] [:upper:] [:xdigit:]\n" #. type: Plain text #: build/C/man7/glob.7:188 msgid "" "so that one can say \"I<[[:lower:]]>\" instead of \"I<[a-z]>\", and have " "things work in Denmark, too, where there are three letters past \\(aqz\\(aq " "in the alphabet. These character classes are defined by the B " "category in the current locale." msgstr "" "これを用いれば \"I<[a-z]>\" の代わりに \"I<[[:lower:]]>\" のような指定ができ" "る。 またデンマークのように、アルファベットの \\(aqz\\(aq 以降に 3 つの文字が" "存在するような場合でも、同じような動作が期待できる。 これらの文字クラスはカレ" "ントロケールの B カテゴリで定義されている。" #. type: Plain text #: build/C/man7/glob.7:194 msgid "" "(v) Collating symbols, like \"I<[.ch.]>\" or \"I<[.a-acute.]>\", where the " "string between \"I<[.>\" and \"I<.]>\" is a collating element defined for " "the current locale. Note that this may be a multicharacter element." msgstr "" "(v) 照合順序におけるシンボル: \"I<[.ch.]>\" や \"I<[.a-acute.]>\" のように " "\"I<[.>\" と \"I<.]>\" で挟まれた文字列は、カレントロケールで定義された照合順" "序の要素となる。 ある一つの要素が複数の文字からなる場合もありうることに注意。" #. FIXME . the accented 'a' characters are not rendering properly #. mtk May 2007 #. type: Plain text #: build/C/man7/glob.7:204 msgid "" "(vi) Equivalence class expressions, like \"I<[=a=]>\", where the string " "between \"I<[=>\" and \"I<=]>\" is any collating element from its " "equivalence class, as defined for the current locale. For example, \"I<" "[[=a=]]>\" might be equivalent to \"I<[aáàäâ]>\" (warning: Latin-1 here), " "that is, to \"I<[a[.a-acute.][.a-grave.][.a-umlaut.][.a-circumflex.]]>\"." msgstr "" "(vi) 等価クラス表現 (equivalence class expressions):\n" "\"I<[=a=]>\" のように \"I<[=>\" と \"I<=]>\" とで挟まれた文字列であり、\n" "カレントロケールで定義された等価クラスのメンバーである照合要素のいずれかを表" "す。\n" "例えば、\"I<[[=a=]]>\" は \"I<[aáàäâ]>\" (注意: これは Latin-1 表記)、つま" "り\n" "\"I<[a[.a-acute.][.a-grave.][.a-umlaut.][.a-circumflex.]]>\" と等価になる。" #. type: Plain text #: build/C/man7/glob.7:210 msgid "B(1), B(3), B(3), B(7), B(7)" msgstr "B(1), B(3), B(3), B(7), B(7)" #. type: TH #: build/C/man3/re_comp.3:25 #, no-wrap msgid "RE_COMP" msgstr "RE_COMP" #. type: TH #: build/C/man3/re_comp.3:25 #, no-wrap msgid "1995-07-14" msgstr "1995-07-14" #. type: Plain text #: build/C/man3/re_comp.3:28 msgid "re_comp, re_exec - BSD regex functions" msgstr "re_comp, re_exec - BSD の正規表現関数" #. type: Plain text #: build/C/man3/re_comp.3:30 msgid "B<#define _REGEX_RE_COMP>" msgstr "B<#define _REGEX_RE_COMP>" #. type: Plain text #: build/C/man3/re_comp.3:32 msgid "B<#include Esys/types.hE>" msgstr "B<#include Esys/types.hE>" #. type: Plain text #: build/C/man3/re_comp.3:34 msgid "B<#include Eregex.hE>" msgstr "B<#include Eregex.hE>" #. type: Plain text #: build/C/man3/re_comp.3:36 msgid "BIB<);>" msgstr "BIB<);>" #. type: Plain text #: build/C/man3/re_comp.3:38 msgid "BIB<);>" msgstr "BIB<);>" #. type: Plain text #: build/C/man3/re_comp.3:50 msgid "" "B() is used to compile the null-terminated regular expression " "pointed to by I. The compiled pattern occupies a static area, the " "pattern buffer, which is overwritten by subsequent use of B(). If " "I is NULL, no operation is performed and the pattern buffer's " "contents are not altered." msgstr "" "B() は、 I で示される NULL で終端された正規表現をコンパイル" "するために使用される。 コンパイルされたパターンは静的な領域を使用しており、そ" "のパターンバッファ は以降の B() の使用によって上書きされる。 もし " "I が NULL ならば何の操作も行われず、パターンバッファの内容は 置き換え" "られない。" #. type: Plain text #: build/C/man3/re_comp.3:56 msgid "" "B() is used to assess whether the null-terminated string pointed " "to by I matches the previously compiled I." msgstr "" "B() は、 I が指す NULL で終端された文字列が前回コンパイルさ" "れた I にマッチするかどうかを評価するために使用される。" #. type: Plain text #: build/C/man3/re_comp.3:61 msgid "" "B() returns NULL on successful compilation of I otherwise " "it returns a pointer to an appropriate error message." msgstr "" "B() は、 I のコンパイルに成功した場合 NULL を返し、 それ以外" "の場合は適切なエラーメッセージへのポインタを返す。" #. type: Plain text #: build/C/man3/re_comp.3:64 msgid "B() returns 1 for a successful match, zero for failure." msgstr "B() は、一致した場合 1 を、失敗した場合 0 を返す。" #. type: Plain text #: build/C/man3/re_comp.3:66 msgid "4.3BSD." msgstr "4.3BSD." #. type: Plain text #: build/C/man3/re_comp.3:70 msgid "" "These functions are obsolete; the functions documented in B(3) " "should be used instead." msgstr "" "これらの関数は廃止予定である。代わりに B(3) に書かれている関数を使" "用すべきである。" #. type: Plain text #: build/C/man3/re_comp.3:74 msgid "B(3), B(7), GNU regex manual" msgstr "B(3), B(7), GNU regex manual" #. type: TH #: build/C/man3/regex.3:32 build/C/man7/regex.7:35 #, no-wrap msgid "REGEX" msgstr "REGEX" #. type: TH #: build/C/man3/regex.3:32 #, no-wrap msgid "2011-09-27" msgstr "2011-09-27" #. type: Plain text #: build/C/man3/regex.3:35 msgid "regcomp, regexec, regerror, regfree - POSIX regex functions" msgstr "regcomp, regexec, regerror, regfree - POSIX regex 関数" #. type: Plain text #: build/C/man3/regex.3:39 #, no-wrap msgid "" "B<#include Esys/types.hE>\n" "B<#include Eregex.hE>\n" msgstr "" "B<#include Esys/types.hE>\n" "B<#include Eregex.hE>\n" #. type: Plain text #: build/C/man3/regex.3:41 #, no-wrap msgid "BIB<, const char *>IB<, int >IB<);>\n" msgstr "BIB<, const char *>IB<, int >IB<);>\n" #. type: Plain text #: build/C/man3/regex.3:45 #, no-wrap msgid "" "BIB<, const char *>IB<, size_t >IB<,>\n" "B< regmatch_t >IB<, int >IB<);>\n" msgstr "" "BIB<, const char *>IB<, size_t >IB<,>\n" "B< regmatch_t >IB<, int >IB<);>\n" #. type: Plain text #: build/C/man3/regex.3:48 #, no-wrap msgid "" "BIB<, const regex_t *>IB<, char *>IB<,>\n" "B< size_t >IB<);>\n" msgstr "" "BIB<, const regex_t *>IB<, char *>IB<,>\n" "B< size_t >IB<);>\n" #. type: Plain text #: build/C/man3/regex.3:50 #, no-wrap msgid "BIB<);>\n" msgstr "BIB<);>\n" #. type: SS #: build/C/man3/regex.3:52 #, no-wrap msgid "POSIX Regex Compiling" msgstr "POSIX regex コンパイル" #. type: Plain text #: build/C/man3/regex.3:58 msgid "" "B() is used to compile a regular expression into a form that is " "suitable for subsequent B() searches." msgstr "" "B() は、正規表現をコンパイルして、 B() での検索処理に適合" "する形態にする。" #. type: Plain text #: build/C/man3/regex.3:67 msgid "" "B() is supplied with I, a pointer to a pattern buffer " "storage area; I, a pointer to the null-terminated string and " "I, flags used to determine the type of compilation." msgstr "" "B() はパターンを記憶するバッファへのポインタ I、 ヌル文字で終" "端された文字列 I、 そしてコンパイルの形式を決めるためのフラグ " "I を引数に伴う。" #. type: Plain text #: build/C/man3/regex.3:74 msgid "" "All regular expression searching must be done via a compiled pattern buffer, " "thus B() must always be supplied with the address of a B" "() initialized pattern buffer." msgstr "" "全ての正規表現検索は、コンパイルされたパターンによって行わなければならない。 " "よって、 B() に指定するのは、必ず (B() によってコンパイル" "された) パターンバッファへのアドレスでなければならない。" #. type: Plain text #: build/C/man3/regex.3:79 msgid "I may be the bitwise-B of one or more of the following:" msgstr "" "I には以下に示す定数一つ以上のビットごとの OR (bitwise-or) を指定す" "る。" #. type: TP #: build/C/man3/regex.3:79 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:88 msgid "" "Use B Extended Regular Expression syntax when interpreting I. " "If not set, B Basic Regular Expression syntax is used." msgstr "" "I に B 拡張正規表現を使用する。もしこのフラグが設定されない場" "合、 B 標準正規表現が使われる。" #. type: TP #: build/C/man3/regex.3:88 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:94 msgid "" "Do not differentiate case. Subsequent B() searches using this " "pattern buffer will be case insensitive." msgstr "" "大文字小文字の違いを無視する。このフラグを指定してコンパイルされた パターン" "バッファを用いて B() 関数を呼び出すと、大文字小文字の区別を付けずに" "検索が行われる。" #. type: TP #: build/C/man3/regex.3:94 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:104 msgid "" "Support for substring addressing of matches is not required. The I " "and I arguments to B() are ignored if the pattern buffer " "supplied was compiled with this flag set." msgstr "" "このフラグを設定してコンパイルされたパターンバッファが B() の引数に" "指定されると、引き数 I, I が無視される。" #. type: TP #: build/C/man3/regex.3:104 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:107 msgid "Match-any-character operators don't match a newline." msgstr "全ての文字にマッチするオペレータに改行をマッチさせない。" #. type: Plain text #: build/C/man3/regex.3:111 msgid "" "A nonmatching list (B<[^...]>) not containing a newline does not match a " "newline." msgstr "" "改行を含まない非マッチング文字リスト (B<[^...]>) に改行をマッチさせない。" #. type: Plain text #: build/C/man3/regex.3:121 msgid "" "Match-beginning-of-line operator (B<^>) matches the empty string " "immediately after a newline, regardless of whether I, the execution " "flags of B(), contains B." msgstr "" "B() の実行時に指定するフラグ I に B を含むかど" "うかにかかわらず、行頭にマッチするオペレータ (B<^>) を改行直後の空文字列に" "マッチさせる。" #. type: Plain text #: build/C/man3/regex.3:129 msgid "" "Match-end-of-line operator (B<$>) matches the empty string immediately " "before a newline, regardless of whether I contains B." msgstr "" "I に B を含むかどうかにかかわらず、行末にマッチするオペ" "レータ (B<$>) を改行直前の空文字列にマッチさせる。" #. type: SS #: build/C/man3/regex.3:129 #, no-wrap msgid "POSIX Regex Matching" msgstr "POSIX regex マッチング" #. type: Plain text #: build/C/man3/regex.3:146 msgid "" "B() is used to match a null-terminated string against the " "precompiled pattern buffer, I. I and I are used to " "provide information regarding the location of any matches. I may be " "the bitwise-B of one or both of B and B which " "cause changes in matching behavior described below." msgstr "" "B() は、 プリコンパイルされたパターンバッファ I をヌル文字で" "終端された文字列にマッチさせる。 I と I はマッチングの位置に" "関する情報を取得するのに用いられる。 I には B と " "B のどちらか、もしくは両方のビットごとの B (bitwise-B) " "を指定し、以下で説明するようにマッチング動作を変化させる。" #. type: TP #: build/C/man3/regex.3:146 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:156 msgid "" "The match-beginning-of-line operator always fails to match (but see the " "compilation flag B above) This flag may be used when different " "portions of a string are passed to B() and the beginning of the " "string should not be interpreted as the beginning of the line." msgstr "" "行頭にマッチするオペレータは、必ずマッチに失敗する (コンパイル時のフラグ " "B の項目も参照)。 このフラグは、複数行にまたがる文字列を " "B() で検索する際に、文字列の先頭を行の先頭として解釈させない場合に" "用いる。" #. type: TP #: build/C/man3/regex.3:156 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:162 msgid "" "The match-end-of-line operator always fails to match (but see the " "compilation flag B above)" msgstr "" "行末にマッチするオペレータは、必ずマッチに失敗する (コンパイル時のフラグ " "B の項目も参照)。" #. type: SS #: build/C/man3/regex.3:162 #, no-wrap msgid "Byte Offsets" msgstr "バイトオフセット" #. type: Plain text #: build/C/man3/regex.3:175 msgid "" "Unless B was set for the compilation of the pattern buffer, it is " "possible to obtain substring match addressing information. I must " "be dimensioned to have at least I elements. These are filled in by " "B() with substring match addresses. Any unused structure elements " "will contain the value -1." msgstr "" "パターンバッファのコンパイル時に B が設定されない場合は、部分文字" "列のマッチング位置情報を得ることができる。 I は、少なくとも " "I の大きさを持つように指定しなければならない。 B() の実行に" "よって、それらに部分文字列マッチング位置情報が代入される。 未使用の構造体要素" "には -1 が値として代入される。" #. type: Plain text #: build/C/man3/regex.3:182 msgid "" "The I structure which is the type of I is defined in " "Iregex.hE>." msgstr "" "I の型である I 構造体は、 Iregex.hE> 内で定義さ" "れる。" #. type: Plain text #: build/C/man3/regex.3:189 #, no-wrap msgid "" "typedef struct {\n" " regoff_t rm_so;\n" " regoff_t rm_eo;\n" "} regmatch_t;\n" msgstr "" "typedef struct {\n" " regoff_t rm_so;\n" " regoff_t rm_eo;\n" "} regmatch_t;\n" #. type: Plain text #: build/C/man3/regex.3:200 msgid "" "Each I element that is not -1 indicates the start offset of the next " "largest substring match within the string. The relative I element " "indicates the end offset of the match, which is the offset of the first " "character after the matching text." msgstr "" "構造体要素 I の値が -1 でない場合、それは文字列内での次の最大のマッチ" "ング部分の開始 オフセット位置を示す。それに対し、構造体要素 I はマッチ" "ング部分の終了オフセット位置を示し、 マッチング部分の直後の文字のオフセット位" "置が使用される。" #. type: SS #: build/C/man3/regex.3:200 #, no-wrap msgid "Posix Error Reporting" msgstr "POSIX エラーレポート" #. type: Plain text #: build/C/man3/regex.3:207 msgid "" "B() is used to turn the error codes that can be returned by both " "B() and B() into error message strings." msgstr "" "B() は、 B() と B() の実行によって得られるエ" "ラーコードから、エラーメッセージ文字列を 得るのに用いられる。" #. type: Plain text #: build/C/man3/regex.3:229 msgid "" "B() is passed the error code, I, the pattern buffer, " "I, a pointer to a character string buffer, I, and the size of " "the string buffer, I. It returns the size of the I " "required to contain the null-terminated error message string. If both " "I and I are nonzero, I is filled in with the " "first I characters of the error message and a terminating " "null byte (\\(aq\\e0\\(aq)." msgstr "" "B() はエラーコード I、 パターンバッファ I、 文字列" "バッファへのポインタ I、 文字列バッファのサイズ I を引数" "にとる。 この関数は、ヌル文字で終端されたエラーメッセージ文字列を格納するのに" "必要な I のサイズを返す。もし I と I の両方が非 " "0 値であれば、 I には最初の I 文字分にエラーメッセー" "ジと終端の NULL バイト (\\(aq\\e0\\(aq) が収まるように代入される。" #. type: SS #: build/C/man3/regex.3:229 #, no-wrap msgid "POSIX Pattern Buffer Freeing" msgstr "POSIX パターンバッファ解放" #. type: Plain text #: build/C/man3/regex.3:237 msgid "" "Supplying B() with a precompiled pattern buffer, I will free " "the memory allocated to the pattern buffer by the compiling process, " "B()." msgstr "" "引数にコンパイルされたパターンバッファ I を与えて B() を呼び" "出すと、 B() によるコンパイル時にパターンバッファに割り当てられたメ" "モリが解放される。" #. type: Plain text #: build/C/man3/regex.3:240 msgid "" "B() returns zero for a successful compilation or an error code for " "failure." msgstr "" "B() は、コンパイルの成功時には 0 を返し、失敗時にはエラーコードを返" "す。" #. type: Plain text #: build/C/man3/regex.3:245 msgid "" "B() returns zero for a successful match or B for " "failure." msgstr "" "B() は、マッチングの成功時には 0 を返し、失敗時には B " "を返す。" #. type: SH #: build/C/man3/regex.3:245 #, no-wrap msgid "ERRORS" msgstr "エラー" #. type: Plain text #: build/C/man3/regex.3:248 msgid "The following errors can be returned by B():" msgstr "B() は以下のエラーを返す。" #. type: TP #: build/C/man3/regex.3:248 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:251 msgid "Invalid use of back reference operator." msgstr "無効な後方参照オペレータの使用。" #. type: TP #: build/C/man3/regex.3:251 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:254 msgid "Invalid use of pattern operators such as group or list." msgstr "グループやリストなどの、パターンオペレータの無効な使用。" #. type: TP #: build/C/man3/regex.3:254 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:258 msgid "" "Invalid use of repetition operators such as using \\(aq*\\(aq as the first " "character." msgstr "" "\\(aq*\\(aq が最初の文字としてくるような、無効な繰り返しオペレータの使用。" #. type: TP #: build/C/man3/regex.3:258 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:261 msgid "Un-matched brace interval operators." msgstr "" "インターバルオペレータ B<{}> (brace interval operators) が閉じていない。" #. type: TP #: build/C/man3/regex.3:261 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:264 msgid "Un-matched bracket list operators." msgstr "リストオペレータ B<[]> (bracket list operators) が閉じていない。" #. type: TP #: build/C/man3/regex.3:264 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:267 msgid "Invalid collating element." msgstr "" "照合順序の要素 (collating element) として有効ではない。 (訳注) 詳細は " "B(7) を参照。" #. type: TP #: build/C/man3/regex.3:267 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:270 msgid "Unknown character class name." msgstr "未知のキャラクタクラス名。" #. type: TP #: build/C/man3/regex.3:270 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:274 msgid "Non specific error. This is not defined by POSIX.2." msgstr "未定義エラー。これは POSIX.2 には定義されていない。" #. type: TP #: build/C/man3/regex.3:274 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:277 msgid "Trailing backslash." msgstr "正規表現がバックスラッシュで終っている。" #. type: TP #: build/C/man3/regex.3:277 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:280 msgid "Un-matched parenthesis group operators." msgstr "" "グループオペレータ B<()> (parenthesis group operators) が閉じていない。" #. type: TP #: build/C/man3/regex.3:280 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:284 msgid "" "Invalid use of the range operator, e.g., the ending point of the range " "occurs prior to the starting point." msgstr "" "無効な範囲オペレータの使用。 例えば、範囲の終了位置が開始位置よりも前にあるよ" "うな場合。" #. type: TP #: build/C/man3/regex.3:284 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:288 msgid "" "Compiled regular expression requires a pattern buffer larger than 64Kb. " "This is not defined by POSIX.2." msgstr "" "正規表現のコンパイルに、64Kb 以上のパターンバッファが必要。 これは POSIX.2 に" "は定義されていない。" #. type: TP #: build/C/man3/regex.3:288 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:291 msgid "The regex routines ran out of memory." msgstr "regex ルーチンがメモリを使いはたしている。" #. type: TP #: build/C/man3/regex.3:291 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/regex.3:294 msgid "Invalid back reference to a subexpression." msgstr "" "サブエクスプレッション \\eB<(...\\e>) (subexpression) への無効な後方参照。" #. type: Plain text #: build/C/man3/regex.3:296 build/C/man3/wordexp.3:188 msgid "POSIX.1-2001." msgstr "POSIX.1-2001." #. type: Plain text #: build/C/man3/regex.3:300 msgid "B(1), B(7), GNU regex manual" msgstr "B(1), B(7), GNU regex マニュアル" #. type: TH #: build/C/man7/regex.7:35 #, no-wrap msgid "2009-01-12" msgstr "2009-01-12" #. type: Plain text #: build/C/man7/regex.7:38 msgid "regex - POSIX.2 regular expressions" msgstr "regex - POSIX.2 正規表現" #. type: Plain text #: build/C/man7/regex.7:52 msgid "" "Regular expressions (\"RE\"s), as defined in POSIX.2, come in two forms: " "modern REs (roughly those of I; POSIX.2 calls these \"extended\" " "REs) and obsolete REs (roughly those of B(1); POSIX.2 \"basic\" REs). " "Obsolete REs mostly exist for backward compatibility in some old programs; " "they will be discussed at the end. POSIX.2 leaves some aspects of RE syntax " "and semantics open; \"\\*(dg\" marks decisions on these aspects that may not " "be fully portable to other POSIX.2 implementations." msgstr "" "正規表現 (Regular expression: RE) は POSIX.2 で定義されており、 二つの形式が" "ある。新しい正規表現 (modern RE) と古い正規表現 (obsolete RE) である。新しい" "正規表現はだいたい I のものと同じで、 POSIX.2 では「拡張」正規表現 " "(\"extended\" RE) と呼ばれている。古い正規表現はだいたい B(1) のものと" "同じで、 POSIX.2 では「基本」正規表現 (\"basic\" RE) である。 古い正規表現" "は、古いプログラムとの互換性を保つためのものである。 これについては最後に議論" "する。 POSIX.2 では、正規表現の文法や記号の一部が、未定義のまま残されてい" "る。 \"\\*(dg\" は、このような意味で、他の POSIX.2 の実装と 完全には互換でな" "いかも知れない部分である。" #. type: Plain text #: build/C/man7/regex.7:56 msgid "" "A (modern) RE is one\\*(dg or more nonempty\\*(dg I, separated by " "\\(aq|\\(aq. It matches anything that matches one of the branches." msgstr "" "(新しい) 正規表現は一つ以上\\*(dg の空白でない I<枝 (branch)> からなる。 枝ど" "うしは \\(aq|\\(aq で区切られる。正規表現は、 枝のどれかにマッチ (match) した" "ものにマッチする。" #. type: Plain text #: build/C/man7/regex.7:59 msgid "" "A branch is one\\*(dg or more I, concatenated. It matches a match " "for the first, followed by a match for the second, etc." msgstr "" "枝は一つ以上の文節 (piece) が結合されたものである。 枝は第一の文節がマッチ" "し、 続いて第二の文節がマッチし、... したものにマッチする。" #. type: Plain text #: build/C/man7/regex.7:68 msgid "" "A piece is an I possibly followed by a single\\*(dg \\(aq*\\(aq, \\(aq+" "\\(aq, \\(aq?\\(aq, or I. An atom followed by \\(aq*\\(aq matches a " "sequence of 0 or more matches of the atom. An atom followed by \\(aq+\\(aq " "matches a sequence of 1 or more matches of the atom. An atom followed by " "\\(aq?\\(aq matches a sequence of 0 or 1 matches of the atom." msgstr "" "文節はI<アトム (atom)> からなる。ただしアトムの後には一つ\\*(dg の \\(aq*" "\\(aq, \\(aq+\\(aq, \\(aq?\\(aq あるいは I<繰り返し指定 (bound)> が続くことも" "ある。 \\(aq*\\(aq が後置されたアトムは、マッチしたアトムの 0 個以上の並びに" "マッチする。 \\(aq+\\(aq が後置されたアトムは、マッチしたアトムの 1 個以上の" "並びにマッチする。 \\(aq?\\(aq が後置されたアトムは、マッチしたアトムの 0 個" "または 1 個にマッチする。" #. type: Plain text #: build/C/man7/regex.7:86 msgid "" "A I is \\(aq{\\(aq followed by an unsigned decimal integer, possibly " "followed by \\(aq,\\(aq possibly followed by another unsigned decimal " "integer, always followed by \\(aq}\\(aq. The integers must lie between 0 " "and B (255\\*(dg) inclusive, and if there are two of them, the " "first may not exceed the second. An atom followed by a bound containing one " "integer I and no comma matches a sequence of exactly I matches of the " "atom. An atom followed by a bound containing one integer I and a comma " "matches a sequence of I or more matches of the atom. An atom followed by " "a bound containing two integers I and I matches a sequence of I " "through I (inclusive) matches of the atom." msgstr "" "I<繰り返し指定>とは \\(aq{\\(aq に続いて、符号なし 10 進整数、\\(aq,\\(aq、 " "もう一つの 10 進整数、\\(aq}\\(aq を並べたものである。\\(aq,\\(aq と二つめの " "10 進整数は省略できる。二つめの 10 進整数だけを省略することもできる (最後の " "`}' は省略できない)。 整数は 0 以上 B (255\\*(dg) 以下の間で指定" "できる。 二つ指定する場合には、最初の数値は後の数値を越えてはならない。 整数 " "I だけからなる繰り返し指定を後置されたアトムは、 アトムをぴったりちょうど " "I 個だけ並べたものにマッチする。 整数 I とコンマが指定された繰り返し指" "定を後置されたアトムは、 アトムを I個以上並べたものにマッチする。 整数 " "I と I が指定された繰り返し指定を後置されたアトムは、 アトムを I個以" "上 I 個以下だけ並べたものにマッチする。" #. type: Plain text #: build/C/man7/regex.7:103 msgid "" "An atom is a regular expression enclosed in \"I<()>\" (matching a match for " "the regular expression), an empty set of \"I<()>\" (matching the null " "string)\\*(dg, a I (see below), \\(aq.\\(aq (matching " "any single character), \\(aq^\\(aq (matching the null string at the " "beginning of a line), \\(aq$\\(aq (matching the null string at the end of a " "line), a \\(aq\\e\\(aq followed by one of the characters \"I<^.[$()|*+?{\\e>" "\" (matching that character taken as an ordinary character), a \\(aq\\e\\(aq " "followed by any other character\\*(dg (matching that character taken as an " "ordinary character, as if the \\(aq\\e\\(aq had not been present\\*(dg), or " "a single character with no other significance (matching that character). A " "\\(aq{\\(aq followed by a character other than a digit is an ordinary " "character, not the beginning of a bound\\*(dg. It is illegal to end an RE " "with \\(aq\\e\\(aq." msgstr "" "アトムの種類は以下の通り。\"I<()>\" に囲まれた正規表現 (その正規表現がマッチ" "する文字列にマッチする)、 中身が空の \"I<()>\" (null 文字列にマッチする)\\*" "(dg、 I<ブラケット表現 (bracket expression> :後述)、 \\(aq.\\(aq (任意の 1 文" "字にマッチする)、 \\(aq^\\(aq (行頭の空白文字にマッチする)、 \\(aq$\\(aq (行" "末の空白文字にマッチする)、 \\(aq\\e\\(aq に \"I<^.[$()|*+?{\\e>\" のいずれか" "一文字を後置したもの (通常の文字として扱われ、その文字にマッチする)、 \\(aq" "\\e\\(aq にそれ以外の文字を後置したもの\\*(dg (\\(aq\\e\\(aq がない場合と同じ" "ように、その文字にマッチする\\*(dg)、 特に意味を持たない文字一つ (その文字に" "マッチする)。 \\(aq{\\(aq は数字以外の文字が後置されると通常の文字として扱わ" "れ、 繰り返し指定の始まりとはされない\\*(dg。\\(aq\\e\\(aq で終わる正規表現は" "不正なものとみなされる。" #. type: Plain text #: build/C/man7/regex.7:117 msgid "" "A I is a list of characters enclosed in \"I<[]>\". It " "normally matches any single character from the list (but see below). If the " "list begins with \\(aq^\\(aq, it matches any single character (but see " "below) I from the rest of the list. If two characters in the list are " "separated by \\(aq-\\(aq, this is shorthand for the full I of " "characters between those two (inclusive) in the collating sequence, for " "example, \"I<[0-9]>\" in ASCII matches any decimal digit. It is illegal\\*" "(dg for two ranges to share an endpoint, for example, \"I\". Ranges " "are very collating-sequence-dependent, and portable programs should avoid " "relying on them." msgstr "" "I<ブラケット表現>は \"I<[]>\" によって閉じられた文字のリストである。 これは通" "常リスト中に存在している文字にマッチする。 (例外あり、後述。) リストが \\(aq^" "\\(aq で始まると、 I<ブラケット表現>はリストに存在してI<いない>文字一つにマッ" "チする (例外あり、後述)。 リスト中の二つの文字が \\(aq-\\(aq で区切られている" "場合は、 これは照合順序 (collating sequence) でその二つの文字に挟まれる、 す" "べての文字の並びを短縮したものとみなされる (両端含む)。 例えば \"I<[0-9]>\" " "は ASCII では 10 進の数字 (digit) のいずれかにマッチする。 二つの領域指定が端" "点を共有してはならない\\*(dg。 つまり \"I\" のようなものは不正である。" "領域指定は照合順序に強く依存する。 したがって移植性の高いプログラムを作る場合" "は、 領域指定には頼らないほうが良いだろう。 【B<訳注>: 照合順序 (collating " "sequence) というのは、国際化 (Internationalization) に関連した用語です。アル" "ファベット順に単語を並 べる際には、言語によって並べる基準が異なります。照合順" "序は、その差異を 吸収するための仕組みです。 例えば、スペイン語では ch という" "文字並びを特別扱いするため、アルファベッ ト順が a, b, c, ch, d, e, ... の順に" "なるそうです。このようなシーケンス のことを collating sequence と言います。こ" "のとき `ch' という文字並びは、 単語整列の際にあたかも「一文字」のように扱われ" "ます。ここで、 順序付けを行う際に最小の単位となる、`a'、`b' の文字や `ch' の" "ような特別な文字並びなど、照合順序の要素のことを collating element と言いま" "す。collating sequence は、文字単位ではなく collating element を単位として定" "義されます。】" #. type: Plain text #: build/C/man7/regex.7:128 msgid "" "To include a literal \\(aq]\\(aq in the list, make it the first character " "(following a possible \\(aq^\\(aq). To include a literal \\(aq-\\(aq, make " "it the first or last character, or the second endpoint of a range. To use a " "literal \\(aq-\\(aq as the first endpoint of a range, enclose it in \"I<[.>" "\" and \"I<.]>\" to make it a collating element (see below). With the " "exception of these and some combinations using \\(aq[\\(aq (see next " "paragraphs), all other special characters, including \\(aq\\e\\(aq, lose " "their special significance within a bracket expression." msgstr "" "文字 \\(aq]\\(aq そのものをリストに入れたい場合は、 最初の文字として指定すれ" "ば良い (\\(aq^\\(aq) の後に続けるのでも良い)。 文字 \\(aq-\\(aq そのものをリ" "ストに入れたい場合は、 最初か最後の文字とすれば良い。 あるいは領域指定の終端" "文字として指定しても良い。 \\(aq-\\(aq を領域指定の先頭文字に指定するに" "は、\"I<[.>\" と \"I<.]>\" で囲って、 照合順序の要素 (collating element: 後" "述) にすれば良い。 他の特殊文字 ( も含む) は、 ブラケット表現の内部ではすべて" "通常の文字として扱われる。" #. type: Plain text #: build/C/man7/regex.7:140 msgid "" "Within a bracket expression, a collating element (a character, a " "multicharacter sequence that collates as if it were a single character, or a " "collating-sequence name for either) enclosed in \"I<[.>\" and \"I<.]>\" " "stands for the sequence of characters of that collating element. The " "sequence is a single element of the bracket expression's list. A bracket " "expression containing a multicharacter collating element can thus match more " "than one character, for example, if the collating sequence includes a \"ch\" " "collating element, then the RE \"I<[[.ch.]]*c>\" matches the first five " "characters of \"chchcc\"." msgstr "" "ブラケット表現の内部では、\"I<[.>\" と \"I<.]>\" に囲われた照合順序の要素" "は、 その要素に対応する文字並びを表す。 「照合順序の要素」とは、 [1] 文字、 " "[2] 単一文字のように扱われる複数文字のシーケンス、 [3] 1, 2 いずれかに対応す" "る照合順序上の名前、のいずれかである。 この繰り返しは、ブラケット表現のリスト" "における単一の要素となる。 上記 [2] の、「複数文字からなる照合順序要素」を含" "むブラケット表現は、 したがって一文字以上にマッチすることがある。 例えば、も" "し照合順序が \"ch\" という要素を含んでいる場合には、 正規表現 \"I<[[.ch.]]*c>" "\" は \"chchcc\" の最初の 5 文字にマッチする。" #. type: Plain text #: build/C/man7/regex.7:152 msgid "" "Within a bracket expression, a collating element enclosed in \"I<[=>\" and " "\"I<=]>\" is an equivalence class, standing for the sequences of characters " "of all collating elements equivalent to that one, including itself. (If " "there are no other equivalent collating elements, the treatment is as if the " "enclosing delimiters were \"I<[.>\" and \"I<.]>\".) For example, if o and " "\\o'o^' are the members of an equivalence class, then \"I<[[=o=]]>\", \"I<[[=" "\\o'o^'=]]>\", and \"I<[o\\o'o^']>\" are all synonymous. An equivalence " "class may not\\*(dg be an endpoint of a range." msgstr "" "ブラケット表現の内部では、\"I<[=>\" と \"I<=]>\" に囲まれた照合順序の要素" "は、 等価クラス (equivalence class) となる。 これは、その要素と等価な要素すべ" "てからなる文字シーケンス (自身も含む) を表す。 他に等価な要素がなければ、 取" "り扱いは \"I<[.>\" と \"I<.]>\" で囲まれている場合と同じである。 例えば o と " "ou が等価クラスのメンバーであれば、 \"I<[[=o=]]>\", \"I<[[=\\o'o^'=]]>\", " "\"I<[o\\o'o^']>\" はすべて同じ意味になる。 等価クラスは領域指定の端点にはなれ" "ない\\*(dg。" #. type: Plain text #: build/C/man7/regex.7:158 msgid "" "Within a bracket expression, the name of a I enclosed in " "\"I<[:>\" and \"I<:]>\" stands for the list of all characters belonging to " "that class. Standard character class names are:" msgstr "" "ブラケット表現の内部では、\"I<[:>\" と \"I<:]>\" で囲われたI<文字クラス " "(character class)> はそのクラスに属するすべての文字のリストを表す。 標準で用" "意されている文字クラスの名前は以下の通り:" #. type: ta #: build/C/man7/regex.7:161 #, no-wrap msgid "3c 6c 9c" msgstr "3c 6c 9c" #. type: Plain text #: build/C/man7/regex.7:166 #, no-wrap msgid "" "alnum\tdigit\tpunct\n" "alpha\tgraph\tspace\n" "blank\tlower\tupper\n" "cntrl\tprint\txdigit\n" msgstr "" "alnum\tdigit\tpunct\n" "alpha\tgraph\tspace\n" "blank\tlower\tupper\n" "cntrl\tprint\txdigit\n" #. As per http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=295666 #. The following does not seem to apply in the glibc implementation #. .PP #. There are two special cases\*(dg of bracket expressions: #. the bracket expressions "\fI[[:<:]]\fP" and "\fI[[:>:]]\fP" match #. the null string at the beginning and end of a word respectively. #. A word is defined as a sequence of #. word characters #. which is neither preceded nor followed by #. word characters. #. A word character is an #. .I alnum #. character (as defined by #. .BR wctype (3)) #. or an underscore. #. This is an extension, #. compatible with but not specified by POSIX.2, #. and should be used with #. caution in software intended to be portable to other systems. #. type: Plain text #: build/C/man7/regex.7:192 msgid "" "These stand for the character classes defined in B(3). A locale may " "provide others. A character class may not be used as an endpoint of a range." msgstr "" "これらは B(3) で定義されている文字クラスを表している。ロケール " "(locale) によって、 これら以外のクラスが定義されることもある。 文字クラスは領" "域指定の端点にはなれない。" #. type: Plain text #: build/C/man7/regex.7:204 msgid "" "In the event that an RE could match more than one substring of a given " "string, the RE matches the one starting earliest in the string. If the RE " "could match more than one substring starting at that point, it matches the " "longest. Subexpressions also match the longest possible substrings, subject " "to the constraint that the whole match be as long as possible, with " "subexpressions starting earlier in the RE taking priority over ones starting " "later. Note that higher-level subexpressions thus take priority over their " "lower-level component subexpressions." msgstr "" "正規表現が、与えられた文字列の複数の部分文字列 (substring) にマッチできるよう" "な場合には、 最も先頭の近くから始まるものにマッチする。 その位置から始まり、" "正規表現がマッチできる部分文字列が複数ある場合には、 最長のものにマッチす" "る。 部分正規表現 (subexpression) も最も長い部分文字列にマッチする。 ただし、" "全体のマッチが最長であるように、という条件が優先される。 正規表現の中で先に現" "れる部分正規表現は、後に現れるものより優先される。 ただし、より高位の部分正規" "表現は、 それを構成する低位の部分正規表現よりも優先されることに注意すること。" #. type: Plain text #: build/C/man7/regex.7:216 msgid "" "Match lengths are measured in characters, not collating elements. A null " "string is considered longer than no match at all. For example, \"I\" " "matches the three middle characters of \"abbbc\", \"I<(wee|week)(knights|" "nights)>\" matches all ten characters of \"weeknights\", when \"I<(.*).*>\" " "is matched against \"abc\" the parenthesized subexpression matches all three " "characters, and when \"I<(a*)*>\" is matched against \"bc\" both the whole " "RE and the parenthesized subexpression match the null string." msgstr "" "マッチ長は照合順序の要素ではなく、文字数を単位としてカウントされる。 null 文" "字列は、全くマッチしなかった場合よりも長いとみなされる。 例えば \"I\" " "は \"abbbc\" のまん中の 3 文字にマッチする。 \"I<(wee|week)(knights|nights)>" "\" は \"weeknights\" の全体にマッチする。 \"I<(.*).*>\" を \"abc\" にマッチさ" "せると、 括弧の内部の部分正規表現が 3 文字すべてにマッチする。 \"I<(a*)*>\" " "を \"bc\" にマッチさせると、正規表現全体も、 括弧で括られた部分正規表現も " "null 文字列にマッチする。" #. type: Plain text #: build/C/man7/regex.7:227 msgid "" "If case-independent matching is specified, the effect is much as if all case " "distinctions had vanished from the alphabet. When an alphabetic that exists " "in multiple cases appears as an ordinary character outside a bracket " "expression, it is effectively transformed into a bracket expression " "containing both cases, for example, \\(aqx\\(aq becomes \"I<[xX]>\". When " "it appears inside a bracket expression, all case counterparts of it are " "added to the bracket expression, so that, for example, \"I<[x]>\" becomes " "\"I<[xX]>\" and \"I<[^x]>\" becomes \"I<[^xX]>\"." msgstr "" "マッチが大文字・小文字を無視するように指定されると、 アルファベット全体から大" "小文字の区別が無くなったかのような効果となる。 大文字・小文字を持つアルファ" "ベットがブラケット表現の外部で 通常の文字として現れると、 これは実効的に大小" "両方の文字のブラケット表現のように変換される。 すなわち \\(aqx\\(aq は \"I<" "[xX]>\" となる。ブラケット表現の内部に現れると、 大文字なら小文字が、小文字な" "ら大文字がそのブラケット表現に加えられる。 すなわち \"I<[x]>\" は \"I<[xX]>" "\" に、\"I<[^x]>\" は \"I<[^xX]>\" になる。" #. type: Plain text #: build/C/man7/regex.7:233 msgid "" "No particular limit is imposed on the length of REs\\*(dg. Programs " "intended to be portable should not employ REs longer than 256 bytes, as an " "implementation can refuse to accept such REs and remain POSIX-compliant." msgstr "" "正規表現の長さには特に制限はない\\*(dg。 ただし移植性を高くしたいプログラムで" "は、 256 バイトより長い正規表現は実行しないようにするほうが良い。 なぜなら、" "そのような正規表現を拒否し、 しかも POSIX 互換を保つような実装が可能だからで" "ある。" #. type: Plain text #: build/C/man7/regex.7:249 msgid "" "Obsolete (\"basic\") regular expressions differ in several respects. \\(aq|" "\\(aq, \\(aq+\\(aq, and \\(aq?\\(aq are ordinary characters and there is no " "equivalent for their functionality. The delimiters for bounds are \"I<\\e{>" "\" and \"I<\\e}>\", with \\(aq{\\(aq and \\(aq}\\(aq by themselves ordinary " "characters. The parentheses for nested subexpressions are \"I<\\e(>\" and " "\"I<\\e)>\", with \\(aq(\\(aq and \\(aq)\\(aq by themselves ordinary " "characters. \\(aq^\\(aq is an ordinary character except at the beginning of " "the RE or\\*(dg the beginning of a parenthesized subexpression, \\(aq$\\(aq " "is an ordinary character except at the end of the RE or\\*(dg the end of a " "parenthesized subexpression, and \\(aq*\\(aq is an ordinary character if it " "appears at the beginning of the RE or the beginning of a parenthesized " "subexpression (after a possible leading \\(aq^\\(aq)." msgstr "" "古い (\"基本\") 正規表現は、いくつかの点において異なる。 \\(aq|\\(aq, \\(aq+" "\\(aq, and \\(aq?\\(aq は通常の文字となる。 対応する機能は存在しない。繰り返" "し指定の区切りは \"I<\\e{>\" および \"I<\\e}>\" となる。\\(aq{\\(aq と " "\\(aq}\\(aq は、 単独では通常の文字として扱われる。 部分正規表現をネストする" "括弧は \"I<\\e(>\" および \"I<\\e)>\" となり、 \\(aq(\\(aq と \\(aq)\\(aq は" "単独では通常の文字となる。 \\(aq^\\(aq は正規表現の先頭か、 括弧でくくられた" "部分表現の先頭\\*(dgを除いて通常の文字となる。 \\(aq$\\(aq は正規表現の末尾" "か、 括弧でくくられた部分正規表現の末尾\\*(dgを除いて通常の文字となる。 " "\\(aq*\\(aq は、正規表現の先頭か、 括弧でくくられた部分文字列の先頭に置かれた" "場合は通常の文字となる (\\(aq^\\(aq) が前置されていてもよい)。" #. type: Plain text #: build/C/man7/regex.7:257 msgid "" "Finally, there is one new type of atom, a I: \\(aq\\e\\(aq " "followed by a nonzero decimal digit I matches the same sequence of " "characters matched by the Ith parenthesized subexpression (numbering " "subexpressions by the positions of their opening parentheses, left to " "right), so that, for example, \"I<\\e([bc]\\e)\\e1>\" matches \"bb\" or \"cc" "\" but not \"bc\"." msgstr "" "最後に、アトムとして別のタイプが存在する。 I<後方参照 (back reference)> であ" "る。 \\(aq\\e\\(aq の後に 0 でない 10 進数値文字 I が続くと、 括弧でくくら" "れた部分正規表現の I 番目にマッチした文字並びと同じものにマッチする。 (部" "分正規表現の番号付けは、 開き括弧 `(' の位置が左のものから右のものへ向かって" "なされる。) したがって \"I<\\e([bc]\\e)\\e1>\" は \"bb\" または \"cc\" には" "マッチするが、\"bc\" にはマッチしない。" #. type: Plain text #: build/C/man7/regex.7:259 msgid "Having two kinds of REs is a botch." msgstr "正規表現が 2 種類あるのは格好悪い。" #. type: Plain text #: build/C/man7/regex.7:265 msgid "" "The current POSIX.2 spec says that \\(aq)\\(aq is an ordinary character in " "the absence of an unmatched \\(aq(\\(aq; this was an unintentional result of " "a wording error, and change is likely. Avoid relying on it." msgstr "" "現在の POSIX.2 規格においては、\\(aq)\\(aq は、 対応する \\(aq(\\(aq がない場" "合には通常の文字として扱われることになっている。 しかしこれは、本来の意図とは" "異なる記述上のエラーであり、 修正される可能性が高い。これに依存したコードは使" "わないこと。" #. type: Plain text #: build/C/man7/regex.7:272 msgid "" "Back references are a dreadful botch, posing major problems for efficient " "implementations. They are also somewhat vaguely defined (does \"I\" match \"abbbd\"?). Avoid using them." msgstr "" "後方参照はひどく出来の悪い代物である。 効率の良い実装をするのはとても難し" "い。 また定義があいまいである。 (\"I\" は \"abbbd" "\" にマッチすると思うか?) 使わないほうが良い。" #. As per http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=295666 #. The following does not seem to apply in the glibc implementation #. .PP #. The syntax for word boundaries is incredibly ugly. #. type: Plain text #: build/C/man7/regex.7:280 msgid "" "POSIX.2's specification of case-independent matching is vague. The \"one " "case implies all cases\" definition given above is current consensus among " "implementors as to the right interpretation." msgstr "" "POSIX.2 の規格では、case (大文字か小文字か) に依存しないマッチの記述があいま" "いである。 現在のところでは「一つの case がすべての case を意味する」 という" "上記の定義が正しい解釈であるというのが、 実装者の間での共通認識のようである。" #. type: SH #: build/C/man7/regex.7:280 #, no-wrap msgid "AUTHOR" msgstr "著者" #. Sigh... The page license means we must have the author's name #. in the formatted output. #. type: Plain text #: build/C/man7/regex.7:284 msgid "This page was taken from Henry Spencer's regex package." msgstr "このページは Henry Spencer の regex パッケージから採録したものである。" #. type: Plain text #: build/C/man7/regex.7:287 msgid "B(1), B(3)" msgstr "B(1), B(3)" #. type: Plain text #: build/C/man7/regex.7:289 msgid "POSIX.2, section 2.8 (Regular Expression Notation)." msgstr "POSIX.2, section 2.8 (Regular Expression Notation)." #. type: TH #: build/C/man3/wordexp.3:23 #, no-wrap msgid "WORDEXP" msgstr "WORDEXP" #. type: TH #: build/C/man3/wordexp.3:23 #, no-wrap msgid "2008-07-14" msgstr "2008-07-14" #. type: Plain text #: build/C/man3/wordexp.3:26 msgid "wordexp, wordfree - perform word expansion like a posix-shell" msgstr "wordexp, wordfree - posix シェルのように単語の展開を行う" #. type: Plain text #: build/C/man3/wordexp.3:28 msgid "B<#include Ewordexp.hE>" msgstr "B<#include Ewordexp.hE>" #. type: Plain text #: build/C/man3/wordexp.3:30 msgid "" "BIB<, wordexp_t *>I

B<, int >IB<);>" msgstr "" "BIB<, wordexp_t *>I

B<, int >IB<);>" #. type: Plain text #: build/C/man3/wordexp.3:32 msgid "BI

B<);>" msgstr "BI

B<);>" #. type: Plain text #: build/C/man3/wordexp.3:36 msgid "" "Feature Test Macro Requirements for glibc (see B(7)):" msgstr "glibc 向けの機能検査マクロの要件 (B(7) 参照):" #. type: Plain text #: build/C/man3/wordexp.3:41 msgid "B(), B(): _XOPEN_SOURCE" msgstr "B(), B(): _XOPEN_SOURCE" #. type: Plain text #: build/C/man3/wordexp.3:75 msgid "" "The function B() performs a shell-like expansion of the string " "I and returns the result in the structure pointed to by I

. The data " "type I is a structure that at least has the fields I, " "I, and I. The field I is a I that " "gives the number of words in the expansion of I. The field I " "is a I that points to the array of words found. The field " "I of type I is sometimes (depending on I, see below) " "used to indicate the number of initial elements in the I array " "that should be filled with NULLs." msgstr "" "関数 B() はシェルのように文字列 I を展開し、 I

で指し示す構造" "体に結果を返す。 データ型 I は少なくともフィールド I, " "I, I を持つ構造体である。 フィールド I は " "I であり、 I を展開した結果に単語がいくつあるかを表す。 フィール" "ド I は I であり、見つかった単語の配列を指し示す。 " "I 型のフィールド I は、 I 配列にある初期要素のうち" "いくつが NULL で埋められるべきかを表すのに使われたりする (I により決定" "される。下記を参照。)。" #. type: Plain text #: build/C/man3/wordexp.3:83 msgid "" "The function B() frees the allocated memory again. More " "precisely, it does not free its argument, but it frees the array I " "and the strings that points to." msgstr "" "関数 B() は割り当てたメモリを再度解放する。 より正確にいうと、この" "関数はその引き数を解放するのではなく、 配列 I とそれが指し示す文字" "列を解放する。" #. type: SS #: build/C/man3/wordexp.3:83 #, no-wrap msgid "The string argument" msgstr "文字列引き数" #. type: Plain text #: build/C/man3/wordexp.3:93 msgid "" "Since the expansion is the same as the expansion by the shell (see B" "(1)) of the parameters to a command, the string I must not contain " "characters that would be illegal in shell command parameters. In " "particular, there must not be any unescaped newline or |, &, ;, E, " "E, (, ), {, } characters outside a command substitution or parameter " "substitution context." msgstr "" "この展開はシェルによるコマンドのパラメータの展開 (B(1) を参照) と同じで" "あるので、文字列 I はシェルコマンドパラメータで不正とされる文字を含んでは" "ならない。 特にエスケープされていない改行、|, &, ;, E, E, (, ), {, } " "文字を コマンド置換やパラメータ置換の場面以外に含めてはならない。" #. type: Plain text #: build/C/man3/wordexp.3:99 msgid "" "If the argument I contains a word that starts with an unquoted comment " "character #, then it is unspecified whether that word and all following " "words are ignored, or the # is treated as a non-comment character." msgstr "" "引き数 I にクォートしていないコメント文字 # で始まる単語が含まれている場合" "には、 その単語とそれ以降の単語が無視されるか、 それとも # がコメント文字とし" "て扱わないかは、規定されていない。" #. type: SS #: build/C/man3/wordexp.3:99 #, no-wrap msgid "The expansion" msgstr "展開" #. type: Plain text #: build/C/man3/wordexp.3:106 msgid "" "The expansion done consists of the following stages: tilde expansion " "(replacing ~user by user's home directory), variable substitution (replacing " "$FOO by the value of the environment variable FOO), command substitution " "(replacing $(command) or \\`command\\` by the output of command), arithmetic " "expansion, field splitting, wildcard expansion, quote removal." msgstr "" "実行される展開は、以下の段階で構成される: チルダ展開 (~user を user のホーム" "ディレクトリに置き換える)、 変数展開 ($FOO を環境変数 FOO の値に置き換え" "る)、 コマンド展開 ($(command) または \\`command\\` を command の出力で置き換" "える)、 算術展開、フィールド分割、ワイルドカード展開、クォートの除去。" #. type: Plain text #: build/C/man3/wordexp.3:109 msgid "" "The result of expansion of special parameters ($@, $*, $#, $?, $-, $$, $!, " "$0) is unspecified." msgstr "" "特殊なパラメータ ($@, $*, $#, $?, $-, $$, $!, $0) の 展開結果は規定されていな" "い。" #. type: Plain text #: build/C/man3/wordexp.3:112 msgid "" "Field splitting is done using the environment variable $IFS. If it is not " "set, the field separators are space, tab and newline." msgstr "" "フィールド分割は環境変数 $IFS を用いて行われる。 この環境変数が設定されていな" "い場合、 フィールド区切り文字はスペース・タブ・改行である。" #. type: SS #: build/C/man3/wordexp.3:112 #, no-wrap msgid "The output array" msgstr "出力される配列" #. type: Plain text #: build/C/man3/wordexp.3:116 msgid "The array I contains the words found, followed by a NULL." msgstr "配列 I は見つかった単語をを含み、最後に NULL が続く。" #. type: SS #: build/C/man3/wordexp.3:116 #, no-wrap msgid "The flags argument" msgstr "flags 引き数" #. type: Plain text #: build/C/man3/wordexp.3:120 msgid "The I argument is a bitwise inclusive OR of the following values:" msgstr "I 引き数は以下の値のビット包含的 OR である:" #. type: TP #: build/C/man3/wordexp.3:120 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:123 msgid "Append the words found to the array resulting from a previous call." msgstr "見つかった単語を前回の呼び出し結果の配列に追加する。" #. type: TP #: build/C/man3/wordexp.3:123 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:131 msgid "" "Insert I initial NULLs in the array I. (These are not " "counted in the returned I.)" msgstr "" "初期状態である I 個の NULL を配列 I に挿入する (これらは返" "される I にはカウントされない)。" #. type: TP #: build/C/man3/wordexp.3:131 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:134 msgid "Don't do command substitution." msgstr "コマンド置換を行わない。" #. type: TP #: build/C/man3/wordexp.3:134 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:144 msgid "" "The argument I

resulted from a previous call to B(), and " "B() was not called. Reuse the allocated storage." msgstr "" "引き数 I

は前回の B() の呼び出し結果であり、 B() が " "(まだ) 呼び出されない。 割り当てられた領域を再利用する。" #. type: TP #: build/C/man3/wordexp.3:144 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:153 msgid "" "Normally during command substitution I is redirected to I. This flag specifies that I is not to be redirected." msgstr "" "通常はコマンド置換のときに I が I にリダイレクトされる。 " "このフラグは I をリダイレクトしないように指定する。" #. type: TP #: build/C/man3/wordexp.3:153 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:156 msgid "Consider it an error if an undefined shell variable is expanded." msgstr "未定義のシェル変数を展開しようとした場合に、エラーとして扱う。" #. type: Plain text #: build/C/man3/wordexp.3:160 msgid "" "In case of success 0 is returned. In case of error one of the following " "five values is returned." msgstr "" "成功した場合は 0 が返される。 エラーの場合は以下の 5 つの値のうちの 1 つが返" "される。" #. type: TP #: build/C/man3/wordexp.3:160 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:163 msgid "" "Illegal occurrence of newline or one of |, &, ;, E, E, (, ), {, }." msgstr "" "改行または |, &, ;, E, E, (, ), {, } のうちの 1 つが不正に出現した。" #. type: TP #: build/C/man3/wordexp.3:163 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:169 msgid "" "An undefined shell variable was referenced, and the B flag told " "us to consider this an error." msgstr "" "未定義のシェル変数が参照され、かつ B フラグでこれをエラーとして扱" "うように指示されている。" #. type: TP #: build/C/man3/wordexp.3:169 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:174 msgid "" "Command substitution occurred, and the B flag told us to " "consider this an error." msgstr "" "コマンド置換が起こり、かつ B フラグでこれをエラーとして扱うように" "指示されている。" #. type: TP #: build/C/man3/wordexp.3:174 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:177 msgid "Out of memory." msgstr "メモリが足りない。" #. type: TP #: build/C/man3/wordexp.3:177 #, no-wrap msgid "B" msgstr "B" #. type: Plain text #: build/C/man3/wordexp.3:181 msgid "Shell syntax error, such as unbalanced parentheses or unmatched quotes." msgstr "" "対応する括弧がない、クォートが合致しないといった、 シェルの書式エラー。" #. type: SH #: build/C/man3/wordexp.3:181 #, no-wrap msgid "VERSIONS" msgstr "バージョン" #. type: Plain text #: build/C/man3/wordexp.3:186 msgid "" "B() and B() are provided in glibc since version 2.1." msgstr "" "B() と B() は、バージョン 2.1 以降の glibc で提供されて" "いる。" #. type: Plain text #: build/C/man3/wordexp.3:191 msgid "" "The output of the following example program is approximately that of \"ls [a-" "c]*.c\"." msgstr "" "以下のサンプルプログラムの出力はだいたい \"ls [a-c]*.c\" と同じになる。" #. type: Plain text #: build/C/man3/wordexp.3:196 #, no-wrap msgid "" "#include Estdio.hE\n" "#include Estdlib.hE\n" "#include Ewordexp.hE\n" msgstr "" "#include Estdio.hE\n" "#include Estdlib.hE\n" "#include Ewordexp.hE\n" #. type: Plain text #: build/C/man3/wordexp.3:203 #, no-wrap msgid "" "int\n" "main(int argc, char **argv)\n" "{\n" " wordexp_t p;\n" " char **w;\n" " int i;\n" msgstr "" "int\n" "main(int argc, char **argv)\n" "{\n" " wordexp_t p;\n" " char **w;\n" " int i;\n" #. type: Plain text #: build/C/man3/wordexp.3:211 #, no-wrap msgid "" " wordexp(\"[a-c]*.c\", &p, 0);\n" " w = p.we_wordv;\n" " for (i = 0; i E p.we_wordc; i++)\n" " printf(\"%s\\en\", w[i]);\n" " wordfree(&p);\n" " exit(EXIT_SUCCESS);\n" "}\n" msgstr "" " wordexp(\"[a-c]*.c\", &p, 0);\n" " w = p.we_wordv;\n" " for (i = 0; i E p.we_wordc; i++)\n" " printf(\"%s\\en\", w[i]);\n" " wordfree(&p);\n" " exit(EXIT_SUCCESS);\n" "}\n" #. type: Plain text #: build/C/man3/wordexp.3:215 msgid "B(3), B(3)" msgstr "B(3), B(3)"