1 # SOME DESCRIPTIVE TITLE
2 # Copyright (C) YEAR Free Software Foundation, Inc.
3 # This file is distributed under the same license as the PACKAGE package.
4 # FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
8 "Project-Id-Version: PACKAGE VERSION\n"
9 "POT-Creation-Date: 2012-05-28 07:16+0900\n"
10 "PO-Revision-Date: 2012-05-01 04:49+0900\n"
11 "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
12 "Language-Team: LANGUAGE <LL@li.org>\n"
15 "Content-Type: text/plain; charset=UTF-8\n"
16 "Content-Transfer-Encoding: 8bit\n"
19 #: build/C/man3/mq_close.3:26
25 #: build/C/man3/mq_close.3:26 build/C/man3/mq_getattr.3:26
26 #: build/C/man2/mq_getsetattr.2:26 build/C/man3/mq_unlink.3:26
32 #: build/C/man3/mq_close.3:26 build/C/man3/mq_getattr.3:26
33 #: build/C/man2/mq_getsetattr.2:26 build/C/man3/mq_notify.3:26
34 #: build/C/man3/mq_open.3:26 build/C/man7/mq_overview.7:26
35 #: build/C/man3/mq_receive.3:26 build/C/man3/mq_send.3:26
36 #: build/C/man3/mq_unlink.3:26 build/C/man2/msgctl.2:35
37 #: build/C/man2/msgget.2:33 build/C/man2/msgop.2:38
43 #: build/C/man3/mq_close.3:26 build/C/man3/mq_getattr.3:26
44 #: build/C/man2/mq_getsetattr.2:26 build/C/man3/mq_notify.3:26
45 #: build/C/man3/mq_open.3:26 build/C/man7/mq_overview.7:26
46 #: build/C/man3/mq_receive.3:26 build/C/man3/mq_send.3:26
47 #: build/C/man3/mq_unlink.3:26 build/C/man2/msgctl.2:35
48 #: build/C/man2/msgget.2:33 build/C/man2/msgop.2:38
50 msgid "Linux Programmer's Manual"
51 msgstr "Linux Programmer's Manual"
54 #: build/C/man3/mq_close.3:27 build/C/man3/mq_getattr.3:27
55 #: build/C/man2/mq_getsetattr.2:27 build/C/man3/mq_notify.3:27
56 #: build/C/man3/mq_open.3:27 build/C/man7/mq_overview.7:27
57 #: build/C/man3/mq_receive.3:27 build/C/man3/mq_send.3:27
58 #: build/C/man3/mq_unlink.3:27 build/C/man2/msgctl.2:36
59 #: build/C/man2/msgget.2:34 build/C/man2/msgop.2:39
65 #: build/C/man3/mq_close.3:29
66 msgid "mq_close - close a message queue descriptor"
67 msgstr "mq_close - メッセージキュー記述子をクローズする"
70 #: build/C/man3/mq_close.3:29 build/C/man3/mq_getattr.3:29
71 #: build/C/man2/mq_getsetattr.2:29 build/C/man3/mq_notify.3:29
72 #: build/C/man3/mq_open.3:29 build/C/man3/mq_receive.3:29
73 #: build/C/man3/mq_send.3:29 build/C/man3/mq_unlink.3:29
74 #: build/C/man2/msgctl.2:38 build/C/man2/msgget.2:36 build/C/man2/msgop.2:41
80 #: build/C/man3/mq_close.3:32 build/C/man3/mq_getattr.3:32
81 #: build/C/man3/mq_notify.3:32 build/C/man3/mq_receive.3:32
82 #: build/C/man3/mq_send.3:32 build/C/man3/mq_unlink.3:32
84 msgid "B<#include E<lt>mqueue.hE<gt>>\n"
85 msgstr "B<#include E<lt>mqueue.hE<gt>>\n"
88 #: build/C/man3/mq_close.3:34
90 msgid "B<int mq_close(mqd_t >I<mqdes>B<);>\n"
91 msgstr "B<int mq_close(mqd_t >I<mqdes>B<);>\n"
94 #: build/C/man3/mq_close.3:37 build/C/man3/mq_getattr.3:40
95 #: build/C/man3/mq_notify.3:37 build/C/man3/mq_open.3:41
96 #: build/C/man3/mq_receive.3:45 build/C/man3/mq_send.3:45
97 #: build/C/man3/mq_unlink.3:37
98 msgid "Link with I<-lrt>."
99 msgstr "I<-lrt> でリンクする。"
102 #: build/C/man3/mq_close.3:37 build/C/man3/mq_getattr.3:40
103 #: build/C/man2/mq_getsetattr.2:37 build/C/man3/mq_notify.3:37
104 #: build/C/man3/mq_open.3:41 build/C/man7/mq_overview.7:29
105 #: build/C/man3/mq_receive.3:57 build/C/man3/mq_send.3:57
106 #: build/C/man3/mq_unlink.3:37 build/C/man2/msgctl.2:46
107 #: build/C/man2/msgget.2:44 build/C/man2/msgop.2:54
113 #: build/C/man3/mq_close.3:41
114 msgid "B<mq_close>() closes the message queue descriptor I<mqdes>."
116 "B<mq_close>() はメッセージキュー記述子 (message queue descriptor) I<mqdes> "
120 #: build/C/man3/mq_close.3:47
122 "If the calling process has attached a notification request to this message "
123 "queue via I<mqdes>, then this request is removed, and another process can "
124 "now attach a notification request."
126 "呼び出し元のプロセスが I<mqdes> 経由でこのメッセージキューに通知要求 "
127 "(notification request) を設定している場合、通知要求は削除され、他のプロセス"
128 "がそのキューに 対して通知要求を設定できるようになる。"
131 #: build/C/man3/mq_close.3:47 build/C/man3/mq_getattr.3:118
132 #: build/C/man3/mq_notify.3:134 build/C/man3/mq_open.3:123
133 #: build/C/man3/mq_receive.3:113 build/C/man3/mq_send.3:119
134 #: build/C/man3/mq_unlink.3:44 build/C/man2/msgctl.2:224
135 #: build/C/man2/msgget.2:135 build/C/man2/msgop.2:285
141 #: build/C/man3/mq_close.3:53
143 "On success B<mq_close>() returns 0; on error, -1 is returned, with I<errno> "
144 "set to indicate the error."
146 "成功すると、 B<mq_close>() は 0 を返す。エラーの場合、-1 を返し、 I<errno> "
150 #: build/C/man3/mq_close.3:53 build/C/man3/mq_getattr.3:126
151 #: build/C/man3/mq_notify.3:140 build/C/man3/mq_open.3:135
152 #: build/C/man3/mq_receive.3:122 build/C/man3/mq_send.3:127
153 #: build/C/man3/mq_unlink.3:50 build/C/man2/msgctl.2:249
154 #: build/C/man2/msgget.2:141 build/C/man2/msgop.2:298
160 #: build/C/man3/mq_close.3:54 build/C/man3/mq_getattr.3:127
161 #: build/C/man3/mq_notify.3:141 build/C/man3/mq_receive.3:129
162 #: build/C/man3/mq_send.3:134
168 #: build/C/man3/mq_close.3:59 build/C/man3/mq_getattr.3:132
169 #: build/C/man3/mq_notify.3:146
170 msgid "The descriptor specified in I<mqdes> is invalid."
171 msgstr "I<mqdes> に指定されたディスクリプタが不正である。"
174 #: build/C/man3/mq_close.3:59 build/C/man3/mq_getattr.3:137
175 #: build/C/man2/mq_getsetattr.2:47 build/C/man3/mq_notify.3:174
176 #: build/C/man3/mq_open.3:224 build/C/man7/mq_overview.7:263
177 #: build/C/man3/mq_receive.3:156 build/C/man3/mq_send.3:161
178 #: build/C/man3/mq_unlink.3:62 build/C/man2/msgctl.2:309
179 #: build/C/man2/msgget.2:181 build/C/man2/msgop.2:397
181 msgid "CONFORMING TO"
185 #: build/C/man3/mq_close.3:61 build/C/man3/mq_getattr.3:139
186 #: build/C/man3/mq_notify.3:176 build/C/man3/mq_open.3:226
187 #: build/C/man7/mq_overview.7:265 build/C/man3/mq_receive.3:158
188 #: build/C/man3/mq_send.3:163 build/C/man3/mq_unlink.3:64
189 msgid "POSIX.1-2001."
190 msgstr "POSIX.1-2001."
193 #: build/C/man3/mq_close.3:61 build/C/man3/mq_getattr.3:139
194 #: build/C/man2/mq_getsetattr.2:49 build/C/man7/mq_overview.7:265
195 #: build/C/man3/mq_receive.3:158 build/C/man3/mq_send.3:163
196 #: build/C/man2/msgctl.2:312 build/C/man2/msgget.2:183
197 #: build/C/man2/msgop.2:399
203 #: build/C/man3/mq_close.3:65
205 "All open message queues are automatically closed on process termination, or "
208 "プロセス終了時、もしくは B<execve>(2) 実行時に、全てのオープンされたメッセー"
212 #: build/C/man3/mq_close.3:65 build/C/man3/mq_getattr.3:147
213 #: build/C/man2/mq_getsetattr.2:53 build/C/man3/mq_notify.3:243
214 #: build/C/man3/mq_open.3:230 build/C/man7/mq_overview.7:281
215 #: build/C/man3/mq_receive.3:164 build/C/man3/mq_send.3:169
216 #: build/C/man3/mq_unlink.3:64 build/C/man2/msgctl.2:337
217 #: build/C/man2/msgget.2:215 build/C/man2/msgop.2:431
223 #: build/C/man3/mq_close.3:73
225 "B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
226 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
228 "B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
229 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
232 #: build/C/man3/mq_close.3:73 build/C/man3/mq_getattr.3:155
233 #: build/C/man2/mq_getsetattr.2:56 build/C/man3/mq_notify.3:252
234 #: build/C/man3/mq_open.3:238 build/C/man7/mq_overview.7:294
235 #: build/C/man3/mq_receive.3:173 build/C/man3/mq_send.3:178
236 #: build/C/man3/mq_unlink.3:72 build/C/man2/msgctl.2:344
237 #: build/C/man2/msgget.2:223 build/C/man2/msgop.2:437
243 #: build/C/man3/mq_close.3:80 build/C/man3/mq_getattr.3:162
244 #: build/C/man2/mq_getsetattr.2:63 build/C/man3/mq_notify.3:259
245 #: build/C/man3/mq_open.3:245 build/C/man7/mq_overview.7:301
246 #: build/C/man3/mq_receive.3:180 build/C/man3/mq_send.3:185
247 #: build/C/man3/mq_unlink.3:79 build/C/man2/msgctl.2:351
248 #: build/C/man2/msgget.2:230 build/C/man2/msgop.2:444
251 #| "This page is part of release 3.40 of the Linux I<man-pages> project. A "
252 #| "description of the project, and information about reporting bugs, can be "
253 #| "found at http://www.kernel.org/doc/man-pages/."
255 "This page is part of release 3.41 of the Linux I<man-pages> project. A "
256 "description of the project, and information about reporting bugs, can be "
257 "found at http://www.kernel.org/doc/man-pages/."
259 "この man ページは Linux I<man-pages> プロジェクトのリリース 3.40 の一部\n"
260 "である。プロジェクトの説明とバグ報告に関する情報は\n"
261 "http://www.kernel.org/doc/man-pages/ に書かれている。"
264 #: build/C/man3/mq_getattr.3:26
270 #: build/C/man3/mq_getattr.3:29
271 msgid "mq_getattr, mq_setattr - get/set message queue attributes"
272 msgstr "mq_getattr, mq_setattr - メッセージキューの属性を設定/取得する"
275 #: build/C/man3/mq_getattr.3:34
277 msgid "B<int mq_getattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<attr>B<);>\n"
278 msgstr "B<int mq_getattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<attr>B<);>\n"
281 #: build/C/man3/mq_getattr.3:37
284 "B<int mq_setattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
285 "B< struct mq_attr *>I<oldattr>B<);>\n"
287 "B<int mq_setattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
288 "B< struct mq_attr *>I<oldattr>B<);>\n"
291 #: build/C/man3/mq_getattr.3:47
293 "B<mq_getattr>() and B<mq_setattr>() respectively retrieve and modify "
294 "attributes of the message queue referred to by the descriptor I<mqdes>."
296 "B<mq_getattr>() と B<mq_setattr>() は、記述子 I<mqdes> で参照されるメッセー"
297 "ジキューの属性の取得と変更をそれぞれ行う。"
300 #: build/C/man3/mq_getattr.3:54
302 "B<mq_getattr>() returns an I<mq_attr> structure in the buffer pointed by "
303 "I<attr>. This structure is defined as:"
305 "B<mq_getattr>() は、 I<attr> が指すバッファに I<mq_attr> 構造体を格納して返"
306 "す。この構造体は以下のように定義されている:"
309 #: build/C/man3/mq_getattr.3:63
313 " long mq_flags; /* Flags: 0 or O_NONBLOCK */\n"
314 " long mq_maxmsg; /* Max. # of messages on queue */\n"
315 " long mq_msgsize; /* Max. message size (bytes) */\n"
316 " long mq_curmsgs; /* # of messages currently in queue */\n"
320 " long mq_flags; /* フラグ: 0 か O_NONBLOCK */\n"
321 " long mq_maxmsg; /* キューの最大メッセージ数 */\n"
322 " long mq_msgsize; /* 最大メッセージサイズ (バイト単位) */\n"
323 " long mq_curmsgs; /* キューに現在入っているメッセージ数 */\n"
327 #: build/C/man3/mq_getattr.3:73
329 "The I<mq_flags> field contains flags associated with the open message queue "
330 "description. This field is initialized when the queue is created by "
331 "B<mq_open>(3). The only flag that can appear in this field is B<O_NONBLOCK>."
333 "I<mq_flags> フィールドには、オープンメッセージキュー記述 (open message queue "
334 "description) に関連付けられているフラグが格納される。 このフィールドは "
335 "B<mq_open>(3) でキューが作成される際に初期化される。 このフィールドに現れる"
336 "フラグは B<O_NONBLOCK> だけである。"
339 #: build/C/man3/mq_getattr.3:94
341 "The I<mq_maxmsg> and I<mq_msgsize> fields are set when the message queue is "
342 "created by B<mq_open>(3). The I<mq_maxmsg> field is an upper limit on the "
343 "number of messages that may be placed on the queue using B<mq_send>(3). The "
344 "I<mq_msgsize> field is an upper limit on the size of messages that may be "
345 "placed on the queue. Both of these fields must have a value greater than "
346 "zero. Two I</proc> files that place ceilings on the values for these fields "
347 "are described in B<mq_open>(3)."
349 "I<mq_maxmsg> と I<mq_msgsize> フィールドは B<mq_open>(3) でメッセージキュー"
350 "が作成される際にセットされる。 I<mq_maxmsg> フィールドは、 B<mq_send>(3) を"
351 "使ってキューに入れることができるメッセージ数の上限である。 I<mq_msgsize> "
352 "フィールドは、キューに入れることができるメッセージの 上限サイズである。 これ"
353 "らのフィールドはどちらも 0 より大きな値でなければならない。 これらのフィール"
354 "ドに設定できる値の上限は I</proc> ファイルにより決まる。 I</proc> ファイルの"
355 "詳細は B<mq_open>(3) に説明されている。"
358 #: build/C/man3/mq_getattr.3:98
360 "The I<mq_curmsgs> field returns the number of messages currently held in the "
363 "I<mq_curmsgs> フィールドはキューに現在格納されているメッセージ数を返す。"
366 #: build/C/man3/mq_getattr.3:118
368 "B<mq_setattr>() sets message queue attributes using information supplied in "
369 "the I<mq_attr> structure pointed to by I<newattr>. The only attribute that "
370 "can be modified is the setting of the B<O_NONBLOCK> flag in I<mq_flags>. "
371 "The other fields in I<newattr> are ignored. If the I<oldattr> field is not "
372 "NULL, then the buffer that it points to is used to return an I<mq_attr> "
373 "structure that contains the same information that is returned by "
376 "B<mq_setattr>() は、 I<newattr> が指す I<mq_attr> 構造体で与えられた情報を"
377 "使って、メッセージキューの属性を設定する。 変更することができる属性は、 "
378 "I<mq_flags> の B<O_NONBLOCK> フラグの設定だけである。 I<newattr> の他のフィー"
379 "ルドは無視される。 I<oldattr> フィールドが NULL 以外の場合、 B<mq_getattr>"
380 "() が返すのと同じ情報を格納した I<mq_attr> 構造体を I<oldattr> が指すバッ"
384 #: build/C/man3/mq_getattr.3:126
386 "On success B<mq_getattr>() and B<mq_setattr>() return 0; on error, -1 is "
387 "returned, with I<errno> set to indicate the error."
389 "成功すると、 I<mq_getattr ()> と I<mq_setattr ()> は 0 を返す。エラーの場"
390 "合、-1 を返し、 I<errno> にエラーを示す値を設定する。"
393 #: build/C/man3/mq_getattr.3:132 build/C/man3/mq_notify.3:150
394 #: build/C/man3/mq_open.3:156 build/C/man3/mq_receive.3:138
395 #: build/C/man3/mq_send.3:143 build/C/man2/msgctl.2:280
396 #: build/C/man2/msgop.2:329 build/C/man2/msgop.2:385
402 #: build/C/man3/mq_getattr.3:137
403 msgid "I<newattr-E<gt>mq_flags> contained set bits other than B<O_NONBLOCK>."
405 "I<newattr-E<gt>mq_flags> に B<O_NONBLOCK> 以外のビットがセットされていた。"
408 #: build/C/man3/mq_getattr.3:147
410 "On Linux, B<mq_getattr>() and B<mq_setattr>() are library functions "
411 "layered on top of the B<mq_getsetattr>(2) system call."
413 "Linux では、 B<mq_getattr>() と B<mq_setattr>() はライブラリ関数であり、 "
414 "B<mq_getsetattr>(2) システムコールを用いて実装されている。"
417 #: build/C/man3/mq_getattr.3:155
419 "B<mq_close>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
420 "(3), B<mq_unlink>(3), B<mq_overview>(7)"
422 "B<mq_close>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
423 "(3), B<mq_unlink>(3), B<mq_overview>(7)"
426 #: build/C/man2/mq_getsetattr.2:26
428 msgid "MQ_GETSETATTR"
429 msgstr "MQ_GETSETATTR"
432 #: build/C/man2/mq_getsetattr.2:29
433 msgid "mq_getsetattr - get/set message queue attributes"
434 msgstr "mq_getsetattr - メッセージキューの属性を設定/取得する"
437 #: build/C/man2/mq_getsetattr.2:33
440 "B<#include E<lt>sys/types.hE<gt>>\n"
441 "B<#include E<lt>mqueue.hE<gt>>\n"
443 "B<#include E<lt>sys/types.hE<gt>>\n"
444 "B<#include E<lt>mqueue.hE<gt>>\n"
447 #: build/C/man2/mq_getsetattr.2:36
450 "B<int mq_getsetattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
451 "B< struct mq_attr *>I<oldattr>B<);>\n"
453 "B<int mq_getsetattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
454 "B< struct mq_attr *>I<oldattr>B<);>\n"
457 #: build/C/man2/mq_getsetattr.2:39
458 msgid "Do not use this system call."
459 msgstr "このシステムコールを使用しないこと。"
462 #: build/C/man2/mq_getsetattr.2:47
464 "This is the low-level system call used to implement B<mq_getattr>(3) and "
465 "B<mq_setattr>(3). For an explanation of how this system call operates, see "
466 "the description of B<mq_setattr>(3)."
468 "B<mq_getattr>(3) と B<mq_setattr>(3) の実装に使用される低レベルのシステム"
469 "コールである。 このシステムコールがどのように動作するかは B<mq_setattr>(3) "
473 #: build/C/man2/mq_getsetattr.2:49
474 msgid "This interface is nonstandard; avoid its use."
475 msgstr "このインタフェースは非標準である。使用を避けること。"
478 #: build/C/man2/mq_getsetattr.2:53
480 "Glibc does not provide a wrapper for this system call; call it using "
481 "B<syscall>(2). (Actually, never call it unless you are writing a C library!)"
483 "glibc はこのシステムコールに対するラッパー関数を提供していない。 B<syscall>"
484 "(2) を使って呼び出すこと。 (実のところ、C ライブラリを書いているのでない限"
485 "り、 決してこのシステムコールを呼び出さないこと!)"
488 #: build/C/man2/mq_getsetattr.2:56
489 msgid "B<mq_getattr>(3), B<mq_overview>(7)"
490 msgstr "B<mq_getattr>(3), B<mq_overview>(7)"
493 #: build/C/man3/mq_notify.3:26
499 #: build/C/man3/mq_notify.3:26
505 #: build/C/man3/mq_notify.3:29
506 msgid "mq_notify - register for notification when a message is available"
507 msgstr "mq_notify - メッセージ到着時に通知を行うよう登録する"
510 #: build/C/man3/mq_notify.3:34
512 msgid "B<int mq_notify(mqd_t >I<mqdes>B<, const struct sigevent *>I<sevp>B<);>\n"
513 msgstr "B<int mq_notify(mqd_t >I<mqdes>B<, const struct sigevent *>I<notification>B<);>\n"
516 #: build/C/man3/mq_notify.3:43
518 "B<mq_notify>() allows the calling process to register or unregister for "
519 "delivery of an asynchronous notification when a new message arrives on the "
520 "empty message queue referred to by the descriptor I<mqdes>."
522 "B<mq_notify>() を使うと、ディスクリプタ I<mqdes> で参照される空のメッセージ"
523 "キューに新しくメッセージが到着した時に 非同期の通知 (notification) の配送が行"
524 "われるように登録したり、 その解除を行ったりできる。"
527 #: build/C/man3/mq_notify.3:51
529 "The I<sevp> argument is a pointer to a I<sigevent> structure. For the "
530 "definition and general details of this structure, see B<sigevent>(7)."
532 "I<sevp> 引き数は I<sigevent> 構造体へのポインタである。 この構造体の定義と一"
533 "般的な詳細については B<sigevent>(7) を参照。"
536 #: build/C/man3/mq_notify.3:65
538 "If I<sevp> is a non-NULL pointer, then B<mq_notify>() registers the calling "
539 "process to receive message notification. The I<sigev_notify> field of the "
540 "I<sigevent> structure to which I<sevp> points specifies how notification is "
541 "to be performed. This field has one of the following values:"
543 "I<sevp> が NULL でないポインタであれば、 B<mq_notify>() はメッセージ通知を受"
544 "け取るように呼び出し元のプロセスを登録する。 I<sevp> が指す I<sigevent> 構造"
545 "体の I<sigev_notify> フィールドは、どのような通知を行うのかを指定する。 この"
546 "フィールドは以下の値のいずれかを持つ。"
549 #: build/C/man3/mq_notify.3:65
551 msgid "B<SIGEV_NONE>"
552 msgstr "B<SIGEV_NONE>"
554 #. When is SIGEV_NONE useful?
556 #: build/C/man3/mq_notify.3:70
558 "A \"null\" notification: the calling process is registered as the target for "
559 "notification, but when a message arrives, no notification is sent."
561 "「空の (null)」の通知: 呼び出し元のプロセスを通知の宛先として登録するが、 実"
562 "際にはメッセージが到着した時に通知は送られない。"
565 #: build/C/man3/mq_notify.3:70
567 msgid "B<SIGEV_SIGNAL>"
568 msgstr "B<SIGEV_SIGNAL>"
570 #. I don't know of other implementations that set
571 #. si_pid and si_uid -- MTK
573 #: build/C/man3/mq_notify.3:90
575 "Notify the process by sending the signal specified in I<sigev_signo>. See "
576 "B<sigevent>(7) for general details. The I<si_code> field of the "
577 "I<siginfo_t> structure will be set to B<SI_MESGQ>. In addition, I<si_pid> "
578 "will be set to the PID of the process that sent the message, and I<si_uid> "
579 "will be set to the real user ID of the sending process."
581 "I<sigev_signo> で指定されたシグナルを送って、プロセスに通知する。 一般的な詳"
582 "細については B<sigevent>(7) を参照。 I<siginfo_t> 構造体の I<si_code> フィー"
583 "ルドには B<SI_MESGQ> が設定される。 さらに、 I<si_pid> にはメッセージを送信し"
584 "たプロセスの PID が、 I<si_uid> には送信プロセスの実ユーザ ID が設定される。"
587 #: build/C/man3/mq_notify.3:90
589 msgid "B<SIGEV_THREAD>"
590 msgstr "B<SIGEV_THREAD>"
593 #: build/C/man3/mq_notify.3:98
595 "Upon message delivery, invoke I<sigev_notify_function> as if it were the "
596 "start function of a new thread. See B<sigevent>(7) for details."
598 "メッセージの配送時には、 I<sigev_notify_function> があたかも新しいスレッドの"
599 "開始関数であるかのように起動される。 詳細は B<sigevent>(7) を参照。"
602 #: build/C/man3/mq_notify.3:101
604 "Only one process can be registered to receive notification from a message "
607 "一つのメッセージキューから通知を受信するように登録できるプロセスは 一つだけで"
611 #: build/C/man3/mq_notify.3:108
613 "If I<sevp> is NULL, and the calling process is currently registered to "
614 "receive notifications for this message queue, then the registration is "
615 "removed; another process can then register to receive a message notification "
618 "I<sevp> が NULL で、かつ呼び出し元のプロセスがこのメッセージキューからの 通知"
619 "を受信するに現在登録している場合、登録を削除する。 これ以降、別のプロセスがこ"
620 "のメッセージキューから通知を受信するように 登録できるようになる。"
623 #: build/C/man3/mq_notify.3:115
625 "Message notification only occurs when a new message arrives and the queue "
626 "was previously empty. If the queue was not empty at the time B<mq_notify>"
627 "() was called, then a notification will only occur after the queue is "
628 "emptied and a new message arrives."
630 "メッセージ通知は、それまで空のキューに新しいメッセージが到着した 場合にのみ行"
631 "われる。 B<mq_notify>() が呼び出された時にそのキューが空でない場合、 その"
632 "キューが空になり、その後新しいメッセージが到着した時に 初めて通知が行われるこ"
636 #: build/C/man3/mq_notify.3:123
638 "If another process or thread is waiting to read a message from an empty "
639 "queue using B<mq_receive>(3), then any message notification registration is "
640 "ignored: the message is delivered to the process or thread calling "
641 "B<mq_receive>(3), and the message notification registration remains in "
644 "別のプロセスやスレッドが B<mq_receive>(3) を使って、空のキューからメッセージ"
645 "の読み出しを待っている場合、 メッセージ通知の登録は全て無視される。 メッセー"
646 "ジは B<mq_receive>(3) を呼び出しているプロセスやスレッドに配送され、 メッ"
647 "セージ通知の登録は効力を持ったままとなる。"
650 #: build/C/man3/mq_notify.3:134
652 "Notification occurs once: after a notification is delivered, the "
653 "notification registration is removed, and another process can register for "
654 "message notification. If the notified process wishes to receive the next "
655 "notification, it can use B<mq_notify>() to request a further notification. "
656 "This should be done before emptying all unread messages from the queue. "
657 "(Placing the queue in nonblocking mode is useful for emptying the queue of "
658 "messages without blocking once it is empty.)"
660 "通知は一度だけ行われる。通知が送られた後は、通知要求の登録は削除され、 別のプ"
661 "ロセスがメッセージ通知を受信するように登録できるようになる。 通知を受けたプロ"
662 "セスが次の通知も受信したい場合は、 B<mq_notify>() を使ってその後の通知も受け"
663 "るように要求することができる。 B<mq_notify>() を再度呼び出すのは、読み出して"
664 "いないメッセージを全部読み出して キューが空になる前にすべきである (キューから"
665 "のメッセージ読み出しをキューが空になった時に 停止 (block) せずに行うには、"
666 "キューを非停止モード (non-blocking mode) に設定しておくとよい)。"
669 #: build/C/man3/mq_notify.3:140
671 "On success B<mq_notify>() returns 0; on error, -1 is returned, with "
672 "I<errno> set to indicate the error."
674 "成功すると、 B<mq_notify>() は 0 を返す。エラーの場合、-1 を返し、 I<errno> "
678 #: build/C/man3/mq_notify.3:146
684 #: build/C/man3/mq_notify.3:150
686 "Another process has already registered to receive notification for this "
689 "別のプロセスがすでに このメッセージキューに対する通知を受信するように登録して"
693 #: build/C/man3/mq_notify.3:160
695 "I<sevp-E<gt>sigev_notify> is not one of the permitted values; or I<sevp-"
696 "E<gt>sigev_notify> is B<SIGEV_SIGNAL> and I<sevp-E<gt>sigev_signo> is not a "
697 "valid signal number."
699 "I<sevp-E<gt>sigev_notify> が許可された値のいずれでもない。もしくは I<sevp-"
700 "E<gt>sigev_notify> が B<SIGEV_SIGNAL> だが I<sevp-E<gt>sigev_signo> が有効な"
704 #: build/C/man3/mq_notify.3:160 build/C/man3/mq_open.3:214
705 #: build/C/man2/msgget.2:171 build/C/man2/msgop.2:340
711 #: build/C/man3/mq_notify.3:163 build/C/man3/mq_open.3:217
712 msgid "Insufficient memory."
715 #. Linux does not do this
717 #: build/C/man3/mq_notify.3:174
719 "POSIX.1-2008 says that an implementation I<may> generate an B<EINVAL> error "
720 "if I<sevp> is NULL, and the caller is not currently registered to receive "
721 "notifications for the queue I<mqdes>."
723 "POSIX.1-2008 では、 I<sevp> が NULL で、呼び出し元のプロセスがキュー "
724 "I<mqdes> に関する通知を受信するように登録されていない場合、エラー B<EINVAL> "
725 "を生成するような実装を行っても「よい」ことになっている。"
728 #: build/C/man3/mq_notify.3:176 build/C/man7/mq_overview.7:278
734 #: build/C/man3/mq_notify.3:182
736 "The following program registers a notification request for the message queue "
737 "named in its command-line argument. Notification is performed by creating a "
738 "thread. The thread executes a function which reads one message from the "
739 "queue and then terminates the process."
741 "以下のプログラムは、 コマンドライン引き数で指定された名前のメッセージキューへ"
742 "の 通知要求を登録し、通知はスレッドの作成によって行われる。 そのスレッドは、"
743 "そのキューからメッセージを一つ読み出してから、 プロセスを終了する関数を実行す"
747 #: build/C/man3/mq_notify.3:189
750 "#include E<lt>pthread.hE<gt>\n"
751 "#include E<lt>mqueue.hE<gt>\n"
752 "#include E<lt>stdio.hE<gt>\n"
753 "#include E<lt>stdlib.hE<gt>\n"
754 "#include E<lt>unistd.hE<gt>\n"
756 "#include E<lt>pthread.hE<gt>\n"
757 "#include E<lt>mqueue.hE<gt>\n"
758 "#include E<lt>stdio.hE<gt>\n"
759 "#include E<lt>stdlib.hE<gt>\n"
760 "#include E<lt>unistd.hE<gt>\n"
763 #: build/C/man3/mq_notify.3:192
766 "#define handle_error(msg) \\e\n"
767 " do { perror(msg); exit(EXIT_FAILURE); } while (0)\n"
769 "#define handle_error(msg) \\e\n"
770 " do { perror(msg); exit(EXIT_FAILURE); } while (0)\n"
773 #: build/C/man3/mq_notify.3:200
776 "static void /* Thread start function */\n"
777 "tfunc(union sigval sv)\n"
779 " struct mq_attr attr;\n"
782 " mqd_t mqdes = *((mqd_t *) sv.sival_ptr);\n"
784 "static void /* スレッド開始関数 */\n"
785 "tfunc(union sigval sv)\n"
787 " struct mq_attr attr;\n"
790 " mqd_t mqdes = *((mqd_t *) sv.sival_ptr);\n"
793 #: build/C/man3/mq_notify.3:202
795 msgid " /* Determine max. msg size; allocate buffer to receive msg */\n"
797 " /* 最大メッセージサイズを決定し、\n"
798 " メッセージ受信用のバッファを確保する */\n"
801 #: build/C/man3/mq_notify.3:208
804 " if (mq_getattr(mqdes, &attr) == -1)\n"
805 " handle_error(\"mq_getattr\");\n"
806 " buf = malloc(attr.mq_msgsize);\n"
807 " if (buf == NULL)\n"
808 " handle_error(\"malloc\");\n"
810 " if (mq_getattr(mqdes, &attr) == -1)\n"
811 " handle_error(\"mq_getattr\");\n"
812 " buf = malloc(attr.mq_msgsize);\n"
813 " if (buf == NULL)\n"
814 " handle_error(\"malloc\");\n"
817 #: build/C/man3/mq_notify.3:212
820 " nr = mq_receive(mqdes, buf, attr.mq_msgsize, NULL);\n"
822 " handle_error(\"mq_receive\");\n"
824 " nr = mq_receive(mqdes, buf, attr.mq_msgsize, NULL);\n"
826 " handle_error(\"mq_receive\");\n"
829 #: build/C/man3/mq_notify.3:217
832 " printf(\"Read %ld bytes from MQ\\en\", (long) nr);\n"
834 " exit(EXIT_SUCCESS); /* Terminate the process */\n"
837 " printf(\"Read %ld bytes from MQ\\en\", (long) nr);\n"
839 " exit(EXIT_SUCCESS); /* プロセスを終了する */\n"
843 #: build/C/man3/mq_notify.3:223
847 "main(int argc, char *argv[])\n"
850 " struct sigevent sev;\n"
853 "main(int argc, char *argv[])\n"
856 " struct sigevent sev;\n"
859 #: build/C/man3/mq_notify.3:228
862 " if (argc != 2) {\n"
863 "\tfprintf(stderr, \"Usage: %s E<lt>mq-nameE<gt>\\en\", argv[0]);\n"
864 "\texit(EXIT_FAILURE);\n"
867 " if (argc != 2) {\n"
868 "\tfprintf(stderr, \"Usage: %s E<lt>mq-nameE<gt>\\en\", argv[0]);\n"
869 "\texit(EXIT_FAILURE);\n"
873 #: build/C/man3/mq_notify.3:232
876 " mqdes = mq_open(argv[1], O_RDONLY);\n"
877 " if (mqdes == (mqd_t) -1)\n"
878 " handle_error(\"mq_open\");\n"
880 " mqdes = mq_open(argv[1], O_RDONLY);\n"
881 " if (mqdes == (mqd_t) -1)\n"
882 " handle_error(\"mq_open\");\n"
885 #: build/C/man3/mq_notify.3:239
888 " sev.sigev_notify = SIGEV_THREAD;\n"
889 " sev.sigev_notify_function = tfunc;\n"
890 " sev.sigev_notify_attributes = NULL;\n"
891 " sev.sigev_value.sival_ptr = &mqdes; /* Arg. to thread func. */\n"
892 " if (mq_notify(mqdes, &sev) == -1)\n"
893 " handle_error(\"mq_notify\");\n"
895 " sev.sigev_notify = SIGEV_THREAD;\n"
896 " sev.sigev_notify_function = tfunc;\n"
897 " sev.sigev_notify_attributes = NULL;\n"
898 " sev.sigev_value.sival_ptr = &mqdes; /* スレッド関数に渡す引き数 */\n"
899 " if (mq_notify(mqdes, &sev) == -1)\n"
900 " handle_error(\"mq_notify\");\n"
903 #: build/C/man3/mq_notify.3:242
906 " pause(); /* Process will be terminated by thread function */\n"
909 " pause(); /* プロセスはスレッド関数により終了される */\n"
913 #: build/C/man3/mq_notify.3:252
915 "B<mq_close>(3), B<mq_getattr>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
916 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<sigevent>(7)"
918 "B<mq_close>(3), B<mq_getattr>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
919 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<sigevent>(7)"
922 #: build/C/man3/mq_open.3:26
928 #: build/C/man3/mq_open.3:26
934 #: build/C/man3/mq_open.3:29
935 msgid "mq_open - open a message queue"
936 msgstr "mq_open - メッセージキューをオープンする"
939 #: build/C/man3/mq_open.3:34
942 "B<#include E<lt>fcntl.hE<gt>> /* For O_* constants */\n"
943 "B<#include E<lt>sys/stat.hE<gt>> /* For mode constants */\n"
944 "B<#include E<lt>mqueue.hE<gt>>\n"
946 "B<#include E<lt>fcntl.hE<gt>> /* For O_* constants */\n"
947 "B<#include E<lt>sys/stat.hE<gt>> /* For mode constants */\n"
948 "B<#include E<lt>mqueue.hE<gt>>\n"
951 #: build/C/man3/mq_open.3:38
954 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<);>\n"
955 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<, mode_t >I<mode>B<,>\n"
956 "B< struct mq_attr *>I<attr>B<);>\n"
958 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<);>\n"
959 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<, mode_t >I<mode>B<,>\n"
960 "B< struct mq_attr *>I<attr>B<);>\n"
963 #: build/C/man3/mq_open.3:50
965 "B<mq_open>() creates a new POSIX message queue or opens an existing queue. "
966 "The queue is identified by I<name>. For details of the construction of "
967 "I<name>, see B<mq_overview>(7)."
969 "B<mq_open>() は、新しい POSIX メッセージキューを作成するか、既存のキューを "
970 "オープンする。キューは I<name> で識別される。 I<name> の構成の詳細については "
971 "B<mq_overview (7)> を参照。"
974 #: build/C/man3/mq_open.3:58
976 "The I<oflag> argument specifies flags that control the operation of the "
977 "call. (Definitions of the flags values can be obtained by including "
978 "I<E<lt>fcntl.hE<gt>>.) Exactly one of the following must be specified in "
981 "I<oflag> 引き数には、関数呼び出しの操作を制御するフラグを指定する (oflag の値"
982 "の定義は I<E<lt>fcntl.hE<gt>> のインクルードにより得られる)。 I<oflag> には、"
983 "以下のうちいずれか一つを必ず指定しなければならない。"
986 #: build/C/man3/mq_open.3:58
992 #: build/C/man3/mq_open.3:61
993 msgid "Open the queue to receive messages only."
994 msgstr "メッセージの受信専用としてキューをオープンする。"
997 #: build/C/man3/mq_open.3:61
1000 msgstr "B<O_WRONLY>"
1003 #: build/C/man3/mq_open.3:64
1004 msgid "Open the queue to send messages only."
1005 msgstr "メッセージの送信専用としてキューをオープンする。"
1008 #: build/C/man3/mq_open.3:64
1014 #: build/C/man3/mq_open.3:67
1015 msgid "Open the queue to both send and receive messages."
1016 msgstr "メッセージの送受信両用としてキューをオープンする。"
1019 #: build/C/man3/mq_open.3:72
1021 "Zero or more of the following flags can additionally be I<OR>ed in I<oflag>:"
1023 "0 個以上の下記のフラグを、ビット単位の OR (論理和) で I<oflag> に追加で指定で"
1027 #: build/C/man3/mq_open.3:72
1029 msgid "B<O_NONBLOCK>"
1030 msgstr "B<O_NONBLOCK>"
1033 #: build/C/man3/mq_open.3:81
1035 "Open the queue in nonblocking mode. In circumstances where B<mq_receive>"
1036 "(3) and B<mq_send>(3) would normally block, these functions instead fail "
1037 "with the error B<EAGAIN>."
1039 "非停止 (nonblocking) モードでキューをオープンする。 B<mq_receive>(3) と "
1040 "B<mq_send>(3) は、通常は停止 (block) する状況において、エラー B<EAGAIN> で失"
1044 #: build/C/man3/mq_open.3:81
1049 #. In reality the file system IDs are used on Linux.
1051 #: build/C/man3/mq_open.3:89
1053 "Create the message queue if it does not exist. The owner (user ID) of the "
1054 "message queue is set to the effective user ID of the calling process. The "
1055 "group ownership (group ID) is set to the effective group ID of the calling "
1058 "存在しない場合、メッセージキューを作成する。 メッセージキューの所有者 (ユー"
1059 "ザ ID) とグループ所有権 (グループ ID) は、 それぞれ呼び出し元プロセスの実効"
1060 "ユーザ ID と実効グループ ID に設定される。"
1063 #: build/C/man3/mq_open.3:89
1069 #: build/C/man3/mq_open.3:99
1071 "If B<O_CREAT> was specified in I<oflag>, and a queue with the given I<name> "
1072 "already exists, then fail with the error B<EEXIST>."
1074 "B<O_CREAT> が I<oflag> に指定され、かつ指定された名前 I<name> を持つキューが"
1075 "すでに存在する場合、エラー B<EEXIST> で失敗する。"
1078 #: build/C/man3/mq_open.3:123
1080 "If B<O_CREAT> is specified in I<oflag>, then two additional arguments must "
1081 "be supplied. The I<mode> argument specifies the permissions to be placed on "
1082 "the new queue, as for B<open>(2). (Symbolic definitions for the permissions "
1083 "bits can be obtained by including I<E<lt>sys/stat.hE<gt>>.) The permissions "
1084 "settings are masked against the process umask. The I<attr> argument "
1085 "specifies attributes for the queue. See B<mq_getattr>(3) for details. If "
1086 "I<attr> is NULL, then the queue is created with implementation-defined "
1087 "default attributes."
1089 "I<oflag> に B<O_CREAT> を指定する場合、追加で 2つの引き数を与える必要があ"
1090 "る。 I<mode> 引き数は、新しいキューに適用される許可設定 (permission) を、 "
1091 "B<open>(2) と同じように指定する (許可ビットのシンボル定義は I<E<lt>sys/stat."
1092 "hE<gt>> のインクルードにより得られる)。 許可設定はプロセスの umask でマスクさ"
1093 "れる。 I<attr> 引き数は、キューの属性を指定する。詳細は、 B<mq_getattr>(3) "
1094 "を参照。 I<attr> が NULL の場合、キューは実装で定義されたデフォルト属性で作成"
1098 #: build/C/man3/mq_open.3:135
1100 "On success, B<mq_open>() returns a message queue descriptor for use by "
1101 "other message queue functions. On error, B<mq_open>() returns I<(mqd_t)\\ "
1102 "-1>, with I<errno> set to indicate the error."
1104 "成功すると、 B<mq_open>() はメッセージキュー記述子 (message queue "
1105 "descriptor) を返す。 メッセージキュー記述子は他のメッセージキュー関連の関数で"
1106 "使用される。 エラーの場合、 B<mq_open>() は I<(mqd_t)\\ -1> を返し、 "
1107 "I<errno> にエラーを示す値を設定する。"
1110 #: build/C/man3/mq_open.3:136 build/C/man3/mq_open.3:140
1111 #: build/C/man3/mq_unlink.3:51 build/C/man2/msgctl.2:253
1112 #: build/C/man2/msgget.2:145 build/C/man2/msgop.2:304 build/C/man2/msgop.2:359
1118 #: build/C/man3/mq_open.3:140
1120 "The queue exists, but the caller does not have permission to open it in the "
1123 "キューは存在するが、呼び出し元が指定されたモードでそのキュー をオープンする許"
1126 #. Note that this isn't consistent with the same case for sem_open()
1128 #: build/C/man3/mq_open.3:145
1129 msgid "I<name> contained more than one slash."
1130 msgstr "I<name> にスラッシュが 2 個以上含まれていた。"
1133 #: build/C/man3/mq_open.3:145 build/C/man2/msgget.2:153
1139 #: build/C/man3/mq_open.3:156
1141 "Both B<O_CREAT> and B<O_EXCL> were specified in I<oflag>, but a queue with "
1142 "this I<name> already exists."
1144 "I<oflag> に B<O_CREAT> と B<O_EXCL> の両方が指定されたが、指定された名前 "
1145 "I<name> を持つキューがすでに存在する。"
1148 #: build/C/man3/mq_open.3:188
1150 "B<O_CREAT> was specified in I<oflag>, and I<attr> was not NULL, but I<attr-"
1151 "E<gt>mq_maxmsg> or I<attr-E<gt>mq_msqsize> was invalid. Both of these "
1152 "fields must be greater than zero. In a process that is unprivileged (does "
1153 "not have the B<CAP_SYS_RESOURCE> capability), I<attr-E<gt>mq_maxmsg> must be "
1154 "less than or equal to the I<msg_max> limit, and I<attr-E<gt>mq_msgsize> must "
1155 "be less than or equal to the I<msgsize_max> limit. In addition, even in a "
1156 "privileged process, I<attr-E<gt>mq_maxmsg> cannot exceed the B<HARD_MAX> "
1157 "limit. (See B<mq_overview>(7) for details of these limits.)"
1159 "I<oflag> に B<O_CREAT> が指定され、かつ I<attr> が NULL 以外だが、 I<attr-"
1160 "E<gt>mq_maxmsg> か I<attr-E<gt>mq_msqsize> が不正であった。 これらのフィール"
1161 "ドは両方とも 0 より大きくなければならない。 プロセスが特権を持たない "
1162 "(B<CAP_SYS_RESOURCE> ケーパビリティを持たない) 場合、 I<attr-E<gt>mq_maxmsg> "
1163 "と I<attr-E<gt>mq_msgsize> は、それぞれ上限 I<msg_max>、 I<msgsize_max> 以下"
1164 "でなければならない。 また、特権プロセスの場合でも、 I<attr-E<gt>mq_maxmsg> "
1165 "は B<HARD_MAX> 上限を超えることはできない。 (これらの上限に関する詳細は "
1166 "B<mq_overview>(7) を参照。)"
1169 #: build/C/man3/mq_open.3:188
1175 #: build/C/man3/mq_open.3:192
1177 "The process already has the maximum number of files and message queues open."
1179 "そのプロセスがオープンしているファイルとメッセージキューの数が プロセス毎の上"
1183 #: build/C/man3/mq_open.3:192 build/C/man3/mq_unlink.3:54
1185 msgid "B<ENAMETOOLONG>"
1186 msgstr "B<ENAMETOOLONG>"
1189 #: build/C/man3/mq_open.3:196 build/C/man3/mq_unlink.3:58
1190 msgid "I<name> was too long."
1191 msgstr "I<name> が長過ぎる。"
1194 #: build/C/man3/mq_open.3:196
1200 #: build/C/man3/mq_open.3:200
1202 "The system limit on the total number of open files and message queues has "
1205 "システム全体でオープンしているファイルとメッセージキューの合計数が システム上"
1209 #: build/C/man3/mq_open.3:200 build/C/man3/mq_open.3:209
1210 #: build/C/man3/mq_unlink.3:58 build/C/man2/msgget.2:163
1216 #: build/C/man3/mq_open.3:209
1218 "The B<O_CREAT> flag was not specified in I<oflag>, and no queue with this "
1221 "B<O_CREAT> フラグが I<oflag> に指定されなかったが、指定された名前 I<name> を"
1224 #. Note that this isn't consistent with the same case for sem_open()
1226 #: build/C/man3/mq_open.3:214
1227 msgid "I<name> was just \"/\" followed by no other characters."
1228 msgstr "I<name> が \"/\" だけで、その後ろに他の文字が続いていなかった。"
1231 #: build/C/man3/mq_open.3:217 build/C/man2/msgget.2:175
1237 #: build/C/man3/mq_open.3:224
1239 "Insufficient space for the creation of a new message queue. This probably "
1240 "occurred because the I<queues_max> limit was encountered; see B<mq_overview>"
1243 "新しいメッセージキューを作成するのに十分な空間がない。 このエラーはおそらく "
1244 "I<queues_max> 上限に抵触したため起こったのだろう。 B<mq_overview>(7) を参"
1248 #: build/C/man3/mq_open.3:226 build/C/man2/msgget.2:209
1254 #: build/C/man3/mq_open.3:230
1256 "In kernels before 2.6.14, the process umask was not applied to the "
1257 "permissions specified in I<mode>."
1259 "2.6.14 より前のカーネルには、 プロセスの umask が I<mode> で指定された許可設"
1263 #: build/C/man3/mq_open.3:238
1265 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_receive>(3), "
1266 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
1268 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_receive>(3), "
1269 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
1272 #: build/C/man7/mq_overview.7:26
1275 msgstr "MQ_OVERVIEW"
1278 #: build/C/man7/mq_overview.7:26
1284 #: build/C/man7/mq_overview.7:29
1285 msgid "mq_overview - Overview of POSIX message queues"
1286 msgstr "mq_overview - POSIX メッセージキューの概要"
1289 #: build/C/man7/mq_overview.7:37
1291 "POSIX message queues allow processes to exchange data in the form of "
1292 "messages. This API is distinct from that provided by System V message "
1293 "queues (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2), etc.), but provides "
1294 "similar functionality."
1296 "POSIX メッセージキューを使用すると、プロセス間で メッセージの形でのデータのや"
1297 "り取りを行うことができる。 この API は System V メッセージキューの API "
1298 "(B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2) など) とは異なるものだが、同様の機"
1302 #: build/C/man7/mq_overview.7:52
1304 "Message queues are created and opened using B<mq_open>(3); this function "
1305 "returns a I<message queue descriptor> (I<mqd_t>), which is used to refer to "
1306 "the open message queue in later calls. Each message queue is identified by "
1307 "a name of the form I</somename>; that is, a null-terminated string of up to "
1308 "B<NAME_MAX> (i.e., 255) characters consisting of an initial slash, followed "
1309 "by one or more characters, none of which are slashes. Two processes can "
1310 "operate on the same queue by passing the same name to B<mq_open>(3)."
1312 "メッセージキューの作成とオープンは B<mq_open>(3) を使って行う。この関数は I<"
1313 "メッセージキュー記述子 (message queue descriptor)> (I<mqd_t>) を返す。これ以"
1314 "降のコールでは、オープンされたメッセージキューは I<メッセージキュー記述子> を"
1315 "使って参照される。 各メッセージキューは I</somename> の形の名前で区別すること"
1316 "ができる。 その名前は、最大で B<NAME_MAX> (すなわち 255) 文字の NULL 終端され"
1317 "た文字列で、 スラッシュで始まり、スラッシュ以外の文字が 1 文字以上続く形式で"
1318 "ある。 B<mq_open>(3) に同じ名前を渡すことで、2つのプロセスで同一のキューを "
1322 #: build/C/man7/mq_overview.7:68
1324 "Messages are transferred to and from a queue using B<mq_send>(3) and "
1325 "B<mq_receive>(3). When a process has finished using the queue, it closes it "
1326 "using B<mq_close>(3), and when the queue is no longer required, it can be "
1327 "deleted using B<mq_unlink>(3). Queue attributes can be retrieved and (in "
1328 "some cases) modified using B<mq_getattr>(3) and B<mq_setattr>(3). A "
1329 "process can request asynchronous notification of the arrival of a message on "
1330 "a previously empty queue using B<mq_notify>(3)."
1332 "メッセージのキューへの送受信は B<mq_send>(3) と B<mq_receive>(3) を使って行"
1333 "う。プロセスがキューの使用を終えるときには、 B<mq_close>(3) を使ってキューを"
1334 "クローズする。キューがもはや不要となった場合には、 B<mq_unlink>(3) を使って"
1335 "キューを削除できる。キューの属性は B<mq_getattr>(3) で取得でき、 (制限はある"
1336 "が) B<mq_setattr>(3) で変更できる。 B<mq_notify>(3) を使うことで、空の"
1337 "キューへのメッセージ到着を非同期で 通知するように要求することもできる。"
1340 #: build/C/man7/mq_overview.7:81
1342 "A message queue descriptor is a reference to an I<open message queue "
1343 "description> (cf. B<open>(2)). After a B<fork>(2), a child inherits copies "
1344 "of its parent's message queue descriptors, and these descriptors refer to "
1345 "the same open message queue descriptions as the corresponding descriptors in "
1346 "the parent. Corresponding descriptors in the two processes share the flags "
1347 "(I<mq_flags>) that are associated with the open message queue description."
1349 "メッセージキュー記述子は I<オープンメッセージキュー記述 (open message queue "
1350 "description)> への参照である (B<open>(2) も参照)。 B<fork>(2) 実行後は、子"
1351 "プロセスは親プロセスのメッセージキュー記述子のコピーを継承する。 これらの記述"
1352 "子は、親プロセスの対応する記述子と同じオープンメッセージキュー 記述を参照して"
1353 "いる。親プロセスと子プロセスの対応する記述子は、フラグ (I<mq_flags>) を共有"
1354 "する。なぜなら、フラグはオープンメッセージキュー記述に 関連付けられているから"
1358 #: build/C/man7/mq_overview.7:94
1360 "Each message has an associated I<priority>, and messages are always "
1361 "delivered to the receiving process highest priority first. Message "
1362 "priorities range from 0 (low) to I<sysconf(_SC_MQ_PRIO_MAX)\\ -\\ 1> "
1363 "(high). On Linux, I<sysconf(_SC_MQ_PRIO_MAX)> returns 32768, but "
1364 "POSIX.1-2001 only requires an implementation to support priorities in the "
1365 "range 0 to 31; some implementations only provide this range."
1367 "各メッセージにはそれぞれ I<優先度 (priority)> があり、メッセージの受信プロセ"
1368 "スへの配送は常に 優先度の高いメッセージから順に行われる。 メッセージの優先度"
1369 "は 0 (低優先) から I<sysconf(_SC_MQ_PRIO_MAX)\\ -\\ 1> (高優先) の値を持つ。 "
1370 "Linux では、 I<sysconf(_SC_MQ_PRIO_MAX)> は 32768 を返すが、 POSIX.1-2001 で"
1371 "要求されているのは 0 から 31 までの優先度を 実装することだけであり、実装に"
1372 "よってはこの範囲の優先度しか 対応していない。"
1375 #: build/C/man7/mq_overview.7:97
1377 "The remainder of this section describes some specific details of the Linux "
1378 "implementation of POSIX message queues."
1380 "この節の残りでは、POSIX メッセージキューの Linux の実装の詳細 について説明す"
1384 #: build/C/man7/mq_overview.7:97
1386 msgid "Library interfaces and system calls"
1387 msgstr "ライブラリインタフェースとシステムコール"
1390 #: build/C/man7/mq_overview.7:103
1392 "In most cases the B<mq_*()> library interfaces listed above are implemented "
1393 "on top of underlying system calls of the same name. Deviations from this "
1394 "scheme are indicated in the following table:"
1396 "ほとんどの場合、上記の B<mq_*()> ライブラリインタフェースは、同じ名前の下位層"
1397 "のシステムコールを 使って実装されている。この枠組みにあてはまらないものを 以"
1401 #: build/C/man7/mq_overview.7:107
1403 msgid "Library interface\tSystem call\n"
1404 msgstr "Library interface\tSystem call\n"
1407 #: build/C/man7/mq_overview.7:108
1409 msgid "mq_close(3)\tclose(2)\n"
1410 msgstr "mq_close(3)\tclose(2)\n"
1413 #: build/C/man7/mq_overview.7:109
1415 msgid "mq_getattr(3)\tmq_getsetattr(2)\n"
1416 msgstr "mq_getattr(3)\tmq_getsetattr(2)\n"
1419 #: build/C/man7/mq_overview.7:110
1421 msgid "mq_notify(3)\tmq_notify(2)\n"
1422 msgstr "mq_notify(3)\tmq_notify(2)\n"
1425 #: build/C/man7/mq_overview.7:111
1427 msgid "mq_open(3)\tmq_open(2)\n"
1428 msgstr "mq_open(3)\tmq_open(2)\n"
1431 #: build/C/man7/mq_overview.7:112
1433 msgid "mq_receive(3)\tmq_timedreceive(2)\n"
1434 msgstr "mq_receive(3)\tmq_timedreceive(2)\n"
1437 #: build/C/man7/mq_overview.7:113
1439 msgid "mq_send(3)\tmq_timedsend(2)\n"
1440 msgstr "mq_send(3)\tmq_timedsend(2)\n"
1443 #: build/C/man7/mq_overview.7:114
1445 msgid "mq_setattr(3)\tmq_getsetattr(2)\n"
1446 msgstr "mq_setattr(3)\tmq_getsetattr(2)\n"
1449 #: build/C/man7/mq_overview.7:115
1451 msgid "mq_timedreceive(3)\tmq_timedreceive(2)\n"
1452 msgstr "mq_timedreceive(3)\tmq_timedreceive(2)\n"
1455 #: build/C/man7/mq_overview.7:116
1457 msgid "mq_timedsend(3)\tmq_timedsend(2)\n"
1458 msgstr "mq_timedsend(3)\tmq_timedsend(2)\n"
1461 #: build/C/man7/mq_overview.7:117
1463 msgid "mq_unlink(3)\tmq_unlink(2)\n"
1464 msgstr "mq_unlink(3)\tmq_unlink(2)\n"
1467 #: build/C/man7/mq_overview.7:120
1473 #: build/C/man7/mq_overview.7:123
1475 "POSIX message queues have been supported on Linux since kernel 2.6.6. Glibc "
1476 "support has been provided since version 2.3.4."
1478 "Linux では POSIX メッセージキューはカーネル 2.6.6 以降でサポートされている。 "
1479 "glibc ではバージョン 2.3.4 以降でサポートされている。"
1482 #: build/C/man7/mq_overview.7:123
1484 msgid "Kernel configuration"
1488 #: build/C/man7/mq_overview.7:128
1490 "Support for POSIX message queues is configurable via the "
1491 "B<CONFIG_POSIX_MQUEUE> kernel configuration option. This option is enabled "
1494 "POSIX メッセージキューのサポートは、カーネルの設定 (configuration) オプショ"
1495 "ン B<CONFIG_POSIX_MQUEUE> で設定可能である。このオプションはデフォルトでは有"
1499 #: build/C/man7/mq_overview.7:128
1505 #: build/C/man7/mq_overview.7:133
1507 "POSIX message queues have kernel persistence: if not removed by B<mq_unlink>"
1508 "(3), a message queue will exist until the system is shut down."
1510 "POSIX メッセージキューはカーネル内で保持される。 B<mq_unlink>(3) で削除され"
1511 "なければ、メッセージキューは システムがシャットダウンされるまで存在し続ける。"
1514 #: build/C/man7/mq_overview.7:133
1520 #: build/C/man7/mq_overview.7:138
1522 "Programs using the POSIX message queue API must be compiled with I<cc -lrt> "
1523 "to link against the real-time library, I<librt>."
1525 "POSIX メッセージキュー API を使用したプログラムは I<cc -lrt> でコンパイルし、"
1526 "リアルタイムライブラリ I<librt> とリンクしなければならない。"
1529 #: build/C/man7/mq_overview.7:138
1531 msgid "/proc interfaces"
1532 msgstr "/proc インタフェース"
1535 #: build/C/man7/mq_overview.7:141
1537 "The following interfaces can be used to limit the amount of kernel memory "
1538 "consumed by POSIX message queues:"
1540 "以下のインタフェースを使って、POSIX メッセージキューが消費するカーネル メモリ"
1544 #: build/C/man7/mq_overview.7:141
1546 msgid "I</proc/sys/fs/mqueue/msg_max>"
1547 msgstr "I</proc/sys/fs/mqueue/msg_max>"
1550 #: build/C/man7/mq_overview.7:162
1552 "This file can be used to view and change the ceiling value for the maximum "
1553 "number of messages in a queue. This value acts as a ceiling on the I<attr-"
1554 "E<gt>mq_maxmsg> argument given to B<mq_open>(3). The default value for "
1555 "I<msg_max> is 10. The minimum value is 1 (10 in kernels before 2.6.28). "
1556 "The upper limit is B<HARD_MAX>: I<(131072\\ /\\ sizeof(void\\ *))> (32768 on "
1557 "Linux/86). This limit is ignored for privileged processes "
1558 "(B<CAP_SYS_RESOURCE>), but the B<HARD_MAX> ceiling is nevertheless imposed."
1560 "このファイルを使って、一つのキューに入れられるメッセージの最大数の 上限値を参"
1561 "照したり変更したりできる。この値は、 B<mq_open>(3) に渡す I<attr-"
1562 "E<gt>mq_maxmsg> 引き数に対する上限値として機能する。 I<msg_max> のデフォルト"
1563 "値は 10 で、 最小値は 1 (2.6.28 より前のカーネルでは 10) である。 上限は「埋"
1564 "め込みの固定値」 (B<HARD_MAX>) で I<(131072\\ /\\ sizeof(void\\ *))> "
1565 "(Linux/86 では 32768) である。 この上限は特権プロセス (B<CAP_SYS_RESOURCE>) "
1566 "では無視されるが、埋め込みの固定値による上限は どんな場合にでも適用される。"
1569 #: build/C/man7/mq_overview.7:162
1571 msgid "I</proc/sys/fs/mqueue/msgsize_max>"
1572 msgstr "I</proc/sys/fs/mqueue/msgsize_max>"
1575 #: build/C/man7/mq_overview.7:181
1577 "This file can be used to view and change the ceiling on the maximum message "
1578 "size. This value acts as a ceiling on the I<attr-E<gt>mq_msgsize> argument "
1579 "given to B<mq_open>(3). The default value for I<msgsize_max> is 8192 "
1580 "bytes. The minimum value is 128 (8192 in kernels before 2.6.28). The upper "
1581 "limit for I<msgsize_max> is 1,048,576 (in kernels before 2.6.28, the upper "
1582 "limit was B<INT_MAX>; that is, 2,147,483,647 on Linux/86). This limit is "
1583 "ignored for privileged processes (B<CAP_SYS_RESOURCE>)."
1585 "このファイルを使って、メッセージの最大サイズの上限値を\t 参照したり変更したり"
1586 "できる。\t この値は、\t B<mq_open>(3)\t に渡す\t I<attr-E<gt>mq_msgsize> 引き"
1587 "数に対する上限値として機能する。\t I<msgsize_max\t> のデフォルト値は 8192 バ"
1588 "イトで、 最小値は 128 (2.6.28 より前のカーネルでは 8192) である。 "
1589 "I<msgsize_max> の上限は 1,048,576 である (2.6.28 より前のカーネルでは、上限"
1590 "は B<INT_MAX> (Linux/86 では 2,147,483,647) であった)。 この上限は特権プロセ"
1591 "ス\t (B<CAP_SYS_RESOURCE>)\t では無視される。"
1594 #: build/C/man7/mq_overview.7:181
1596 msgid "I</proc/sys/fs/mqueue/queues_max>"
1597 msgstr "I</proc/sys/fs/mqueue/queues_max>"
1600 #: build/C/man7/mq_overview.7:191
1602 "This file can be used to view and change the system-wide limit on the number "
1603 "of message queues that can be created. Only privileged processes "
1604 "(B<CAP_SYS_RESOURCE>) can create new message queues once this limit has "
1605 "been reached. The default value for I<queues_max> is 256; it can be changed "
1606 "to any value in the range 0 to INT_MAX."
1608 "このファイルを使って、作成することができるメッセージキューの数に\t 対するシス"
1609 "テム全体での制限を参照したり変更したりできる。\t 一度この上限に達すると、新し"
1610 "いメッセージキューを作成できるのは\t 特権プロセス\t (B<CAP_SYS_RESOURCE>)\t "
1611 "だけとなる。\t I<queues_max\t> のデフォルト値は 256 であり、\t 0 から "
1612 "INT_MAX の範囲の任意の値に変更することができる。"
1615 #: build/C/man7/mq_overview.7:191
1617 msgid "Resource limit"
1621 #: build/C/man7/mq_overview.7:198
1623 "The B<RLIMIT_MSGQUEUE> resource limit, which places a limit on the amount of "
1624 "space that can be consumed by all of the message queues belonging to a "
1625 "process's real user ID, is described in B<getrlimit>(2)."
1627 "リソース上限 B<RLIMIT_MSGQUEUE> は、プロセスの実 UID に対応する全メッセージ"
1628 "キューが消費する メモリ空間の量に対して上限を設定する。 B<getrlimit>(2) を参"
1632 #: build/C/man7/mq_overview.7:198
1634 msgid "Mounting the message queue file system"
1635 msgstr "メッセージキュー・ファイルシステムのマウント"
1638 #: build/C/man7/mq_overview.7:204
1640 "On Linux, message queues are created in a virtual file system. (Other "
1641 "implementations may also provide such a feature, but the details are likely "
1642 "to differ.) This file system can be mounted (by the superuser) using the "
1643 "following commands:"
1645 "Linux では、メッセージキューは仮想ファイルシステム内に作成される (他の実装で"
1646 "も同様の機能が提供されているものもあるが、 詳細は違っているだろう)。 以下のコ"
1647 "マンドを使うことで (スーパーユーザは) このファイルシステムをマウントできる:"
1650 #: build/C/man7/mq_overview.7:209
1653 "#B< mkdir /dev/mqueue>\n"
1654 "#B< mount -t mqueue none /dev/mqueue>\n"
1656 "#B< mkdir /dev/mqueue>\n"
1657 "#B< mount -t mqueue none /dev/mqueue>\n"
1660 #: build/C/man7/mq_overview.7:213
1661 msgid "The sticky bit is automatically enabled on the mount directory."
1663 "マウントしたディレクトリのスティッキービット (sticky bit) は 自動的にオンとな"
1667 #: build/C/man7/mq_overview.7:220
1669 "After the file system has been mounted, the message queues on the system can "
1670 "be viewed and manipulated using the commands usually used for files (e.g., "
1671 "B<ls>(1) and B<rm>(1))."
1673 "メッセージキュー・ファイルシステムのマウント後は、ファイルに対して 通常使うコ"
1674 "マンド (例えば B<ls>(1) や B<rm>(1)) を使って、システム上のメッセージキュー"
1678 #: build/C/man7/mq_overview.7:223
1680 "The contents of each file in the directory consist of a single line "
1681 "containing information about the queue:"
1683 "ディレクトリ内の各ファイルの内容は 1行であり、 キューに関する情報が表示され"
1687 #: build/C/man7/mq_overview.7:228
1690 "$B< cat /dev/mqueue/mymq>\n"
1691 "QSIZE:129 NOTIFY:2 SIGNO:0 NOTIFY_PID:8260\n"
1693 "$B< cat /dev/mqueue/mymq>\n"
1694 "QSIZE:129 NOTIFY:2 SIGNO:0 NOTIFY_PID:8260\n"
1697 #: build/C/man7/mq_overview.7:232
1698 msgid "These fields are as follows:"
1699 msgstr "各フィールドの詳細は以下の通りである:"
1702 #: build/C/man7/mq_overview.7:232
1708 #: build/C/man7/mq_overview.7:235
1709 msgid "Number of bytes of data in all messages in the queue."
1710 msgstr "キューに入っている全メッセージの合計バイト数。"
1713 #: build/C/man7/mq_overview.7:235
1715 msgid "B<NOTIFY_PID>"
1716 msgstr "B<NOTIFY_PID>"
1719 #: build/C/man7/mq_overview.7:241
1721 "If this is nonzero, then the process with this PID has used B<mq_notify>(3) "
1722 "to register for asynchronous message notification, and the remaining fields "
1723 "describe how notification occurs."
1725 "この値が 0 以外の場合、この値の PID を持つプロセスが B<mq_notify>(3) を使っ"
1726 "て、非同期のメッセージ通知を行うように設定したことを示す。 どのように通知が行"
1727 "われるかは、以下のフィールドにより決定される。"
1730 #: build/C/man7/mq_overview.7:241
1736 #: build/C/man7/mq_overview.7:251
1738 "Notification method: 0 is B<SIGEV_SIGNAL>; 1 is B<SIGEV_NONE>; and 2 is "
1741 "通知方法: 0 は B<SIGEV_SIGNAL>; 1 は B<SIGEV_NONE>; 2 は B<SIGEV_THREAD>"
1744 #: build/C/man7/mq_overview.7:251
1750 #: build/C/man7/mq_overview.7:255
1751 msgid "Signal number to be used for B<SIGEV_SIGNAL>."
1752 msgstr "B<SIGEV_SIGNAL> に使用されるシグナル番号。"
1755 #: build/C/man7/mq_overview.7:255
1757 msgid "Polling message queue descriptors"
1758 msgstr "メッセージキュー記述子のポーリング"
1761 #: build/C/man7/mq_overview.7:263
1763 "On Linux, a message queue descriptor is actually a file descriptor, and can "
1764 "be monitored using B<select>(2), B<poll>(2), or B<epoll>(7). This is not "
1767 "Linux では、メッセージキュー記述子は実際はファイル記述子 (file descriptor) "
1768 "であり、 B<select>(2), B<poll>(2), B<epoll>(7) を使って監視することができ"
1772 #: build/C/man7/mq_overview.7:275
1774 "System V message queues (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2), etc.) are "
1775 "an older API for exchanging messages between processes. POSIX message "
1776 "queues provide a better designed interface than System V message queues; on "
1777 "the other hand POSIX message queues are less widely available (especially on "
1778 "older systems) than System V message queues."
1780 "System V メッセージキュー (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2) など) は"
1781 "プロセス間でメッセージをやり取りするための古い API である。 POSIX メッセージ"
1782 "キューは System V メッセージキューよりもうまく 設計されたインタフェースを提供"
1783 "している。 一方で、POSIX メッセージキューは System V メッセージキューと比べる"
1784 "と 利用できるシステムが少ない (特に、古いシステムでは少ない)。"
1787 #: build/C/man7/mq_overview.7:278
1789 "Linux does not currently (2.6.26) support the use of access control lists "
1790 "(ACLs) for POSIX message queues."
1792 "現在のことろ (バージョン 2.6.26 時点)、 Linux は POSIX メッセージキューに対す"
1793 "るアクセス制御リスト (ACL) に 対応していない。"
1796 #: build/C/man7/mq_overview.7:281
1798 "An example of the use of various message queue functions is shown in "
1801 "各種のメッセージキュー関数を使用した例が B<mq_notify>(3) に記載されている。"
1804 #: build/C/man7/mq_overview.7:294
1806 "B<getrlimit>(2), B<mq_getsetattr>(2), B<poll>(2), B<select>(2), B<mq_close>"
1807 "(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
1808 "B<mq_send>(3), B<mq_unlink>(3), B<epoll>(7)"
1810 "B<getrlimit>(2), B<mq_getsetattr>(2), B<poll>(2), B<select>(2), B<mq_close>"
1811 "(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
1812 "B<mq_send>(3), B<mq_unlink>(3), B<epoll>(7)"
1815 #: build/C/man3/mq_receive.3:26
1821 #: build/C/man3/mq_receive.3:26 build/C/man3/mq_send.3:26
1827 #: build/C/man3/mq_receive.3:29
1828 msgid "mq_receive, mq_timedreceive - receive a message from a message queue"
1829 msgstr "mq_receive, mq_timedreceive - メッセージキューからメッセージを受信する"
1832 #: build/C/man3/mq_receive.3:35
1835 "B<ssize_t mq_receive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1836 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<);>\n"
1838 "B<ssize_t mq_receive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1839 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<);>\n"
1842 #: build/C/man3/mq_receive.3:38 build/C/man3/mq_send.3:38
1845 "B<#include E<lt>time.hE<gt>>\n"
1846 "B<#include E<lt>mqueue.hE<gt>>\n"
1848 "B<#include E<lt>time.hE<gt>>\n"
1849 "B<#include E<lt>mqueue.hE<gt>>\n"
1852 #: build/C/man3/mq_receive.3:42
1855 "B<ssize_t mq_timedreceive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1856 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<,>\n"
1857 "B< const struct timespec *>I<abs_timeout>B<);>\n"
1859 "B<ssize_t mq_timedreceive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1860 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<,>\n"
1861 "B< const struct timespec *>I<abs_timeout>B<);>\n"
1864 #: build/C/man3/mq_receive.3:50 build/C/man3/mq_send.3:50
1866 "Feature Test Macro Requirements for glibc (see B<feature_test_macros>(7)):"
1867 msgstr "glibc 向けの機能検査マクロの要件 (B<feature_test_macros>(7) 参照):"
1870 #: build/C/man3/mq_receive.3:53
1871 msgid "B<mq_timedreceive>():"
1872 msgstr "B<mq_timedreceive>():"
1875 #: build/C/man3/mq_receive.3:55 build/C/man3/mq_send.3:55
1876 msgid "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L"
1877 msgstr "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L"
1880 #: build/C/man3/mq_receive.3:76
1882 "B<mq_receive>() removes the oldest message with the highest priority from "
1883 "the message queue referred to by the descriptor I<mqdes>, and places it in "
1884 "the buffer pointed to by I<msg_ptr>. The I<msg_len> argument specifies the "
1885 "size of the buffer pointed to by I<msg_ptr>; this must be greater than the "
1886 "I<mq_msgsize> attribute of the queue (see B<mq_getattr>(3)). If I<prio> is "
1887 "not NULL, then the buffer to which it points is used to return the priority "
1888 "associated with the received message."
1890 "B<mq_receive>() は、記述子 I<mqdes> で参照されるメッセージキューから最も高い"
1891 "優先度を持つ 最も古いメッセージを削除し、そのメッセージを I<msg_ptr> が指す"
1892 "バッファに格納する。 I<msg_len> 引き数は、 I<msg_ptr> が指すバッファの大きさ"
1893 "を示す。この値はキューの I<mq_msgsize> 属性よりも大きくなければならない "
1894 "(B<mq_getattr>(3) 参照)。 I<prio> が NULL 以外の場合、 I<prio> が指すバッ"
1895 "ファに受信したメッセージの優先度が格納される。"
1898 #: build/C/man3/mq_receive.3:86
1900 "If the queue is empty, then, by default, B<mq_receive>() blocks until a "
1901 "message becomes available, or the call is interrupted by a signal handler. "
1902 "If the B<O_NONBLOCK> flag is enabled for the message queue description, then "
1903 "the call instead fails immediately with the error B<EAGAIN>."
1905 "キューが空の場合、デフォルトでは、 B<mq_receive>() は、新しいメッセージが届"
1906 "くか、関数呼び出しがシグナルハンドラにより 中断されるまで、停止 (block) す"
1907 "る。 メッセージキュー記述 (message queue description) で B<O_NONBLOCK> フラグ"
1908 "が有効になっている場合は、 B<mq_receive>() はエラー B<EAGAIN> ですぐに失敗す"
1912 #: build/C/man3/mq_receive.3:99
1914 "B<mq_timedreceive>() behaves just like B<mq_receive>(), except that if the "
1915 "queue is empty and the B<O_NONBLOCK> flag is not enabled for the message "
1916 "queue description, then I<abs_timeout> points to a structure which specifies "
1917 "a ceiling on the time for which the call will block. This ceiling is an "
1918 "absolute timeout in seconds and nanoseconds since the Epoch, 1970-01-01 "
1919 "00:00:00 +0000 (UTC), and it is specified in the following structure:"
1921 "B<mq_timedreceive>() は B<mq_receive>() と全く同じ動作をするが、 メッセージ"
1922 "キューが空で、メッセージキュー記述で B<O_NONBLOCK> フラグが有効になっていない"
1923 "場合に、この呼び出しが停止する時間の上限を I<abs_timeout> が指す構造体で指定"
1924 "する点が異なる。この上限は、タイムアウトの時刻を、 時刻紀元 (Epoch; "
1925 "1970-01-01 00:00:00 +0000 (UTC)) からの経過時間 (秒とナノ秒の組) で指定する。"
1926 "タイムアウト時刻は以下の構造体で指定する:"
1929 #: build/C/man3/mq_receive.3:106 build/C/man3/mq_send.3:112
1932 "struct timespec {\n"
1933 " time_t tv_sec; /* seconds */\n"
1934 " long tv_nsec; /* nanoseconds */\n"
1937 "struct timespec {\n"
1938 " time_t tv_sec; /* 秒 */\n"
1939 " long tv_nsec; /* ナノ秒 */\n"
1943 #: build/C/man3/mq_receive.3:113
1945 "If no message is available, and the timeout has already expired by the time "
1946 "of the call, B<mq_timedreceive>() returns immediately."
1948 "メッセージがキューになく、関数呼び出し時にすでにタイムアウト時刻が 過ぎている"
1949 "場合、 B<mq_timedreceive>() はすぐに返る。"
1952 #: build/C/man3/mq_receive.3:122
1954 "On success, B<mq_receive>() and B<mq_timedreceive>() return the number of "
1955 "bytes in the received message; on error, -1 is returned, with I<errno> set "
1956 "to indicate the error."
1958 "成功すると、 B<mq_receive>() と B<mq_timedreceive>() は受信したメッセージの"
1959 "バイト数を返す。 エラーの場合、-1 を返し、 I<errno> にエラーを示す値を設定す"
1963 #: build/C/man3/mq_receive.3:123 build/C/man3/mq_send.3:128
1964 #: build/C/man2/msgop.2:310 build/C/man2/msgop.2:365
1970 #: build/C/man3/mq_receive.3:129
1972 "The queue was empty, and the B<O_NONBLOCK> flag was set for the message "
1973 "queue description referred to by I<mqdes>."
1975 "キューが空で、かつ I<mqdes> で参照されるメッセージキュー記述で B<O_NONBLOCK> "
1979 #: build/C/man3/mq_receive.3:134 build/C/man3/mq_send.3:139
1980 msgid "The descriptor specified in I<mqdes> was invalid."
1981 msgstr "I<mqdes> で指定された記述子が不正である。"
1984 #: build/C/man3/mq_receive.3:134 build/C/man3/mq_send.3:139
1985 #: build/C/man2/msgop.2:326 build/C/man2/msgop.2:380
1991 #: build/C/man3/mq_receive.3:138 build/C/man3/mq_send.3:143
1992 msgid "The call was interrupted by a signal handler; see B<signal>(7)."
1993 msgstr "関数呼び出しがシグナルハンドラにより中断された。 B<signal>(7) 参照。"
1996 #: build/C/man3/mq_receive.3:147 build/C/man3/mq_send.3:152
1998 "The call would have blocked, and I<abs_timeout> was invalid, either because "
1999 "I<tv_sec> was less than zero, or because I<tv_nsec> was less than zero or "
2000 "greater than 1000 million."
2002 "関数呼び出しは停止するはずであったが、 I<abs_timeout> が不正であった。 "
2003 "I<abs_timeout> が不正とは、 I<tv_sec> が 0 未満、もしくは I<tv_nsec> が 0 未"
2004 "満か 1,000,000,000 より大きい、ということである。"
2007 #: build/C/man3/mq_receive.3:147 build/C/man3/mq_send.3:152
2010 msgstr "B<EMSGSIZE>"
2013 #: build/C/man3/mq_receive.3:153
2015 "I<msg_len> was less than the I<mq_msgsize> attribute of the message queue."
2016 msgstr "I<msg_len> がメッセージキューの I<mq_msgsize> 属性よりも小さかった。"
2019 #: build/C/man3/mq_receive.3:153 build/C/man3/mq_send.3:158
2021 msgid "B<ETIMEDOUT>"
2022 msgstr "B<ETIMEDOUT>"
2025 #: build/C/man3/mq_receive.3:156 build/C/man3/mq_send.3:161
2026 msgid "The call timed out before a message could be transferred."
2027 msgstr "メッセージが転送される前に関数呼び出しがタイムアウトした。"
2030 #: build/C/man3/mq_receive.3:164
2032 "On Linux, B<mq_timedreceive>() is a system call, and B<mq_receive>() is a "
2033 "library function layered on top of that system call."
2035 "Linux では、 B<mq_timedreceive>() はシステムコールである。 B<mq_receive>() "
2036 "はライブラリ関数で、 B<mq_timedreceive>() システムコールを用いて実装されてい"
2040 #: build/C/man3/mq_receive.3:173
2042 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_send>"
2043 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2045 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_send>"
2046 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2049 #: build/C/man3/mq_send.3:26
2055 #: build/C/man3/mq_send.3:29
2056 msgid "mq_send, mq_timedsend - send a message to a message queue"
2057 msgstr "mq_send, mq_timedsend - メッセージキューにメッセージを送信する"
2060 #: build/C/man3/mq_send.3:35
2063 "B<int mq_send(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2064 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<);>\n"
2066 "B<int mq_send(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2067 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<);>\n"
2070 #: build/C/man3/mq_send.3:42
2073 "B<int mq_timedsend(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2074 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<,>\n"
2075 "B< const struct timespec *>I<abs_timeout>B<);>\n"
2077 "B<int mq_timedsend(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2078 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<,>\n"
2079 "B< const struct timespec *>I<abs_timeout>B<);>\n"
2082 #: build/C/man3/mq_send.3:53
2083 msgid "B<mq_timedsend>():"
2084 msgstr "B<mq_timedsend>():"
2087 #: build/C/man3/mq_send.3:71
2089 "B<mq_send>() adds the message pointed to by I<msg_ptr> to the message queue "
2090 "referred to by the descriptor I<mqdes>. The I<msg_len> argument specifies "
2091 "the length of the message pointed to by I<msg_ptr>; this length must be less "
2092 "than or equal to the queue's I<mq_msgsize> attribute. Zero-length messages "
2095 "B<mq_send>() は、記述子 I<mqdes> で参照されるメッセージキューに I<msg_ptr> "
2096 "が指すメッセージを追加する。 I<msg_len> 引き数は、 I<msg_ptr> が指すメッセー"
2097 "ジの長さを示す。この長さはキューの I<mq_msgsize> 属性以下でなければならな"
2098 "い。 長さが 0 のメッセージも認められている。"
2101 #: build/C/man3/mq_send.3:79
2103 "The I<msg_prio> argument is a nonnegative integer that specifies the "
2104 "priority of this message. Messages are placed on the queue in decreasing "
2105 "order of priority, with newer messages of the same priority being placed "
2106 "after older messages with the same priority."
2108 "I<msg_prio> 引き数は、メッセージの優先度を指定する負でない整数である。 メッ"
2109 "セージは優先度の降順でキューに格納され、同じ優先度の新しいメッセージは 同じ優"
2110 "先度の古いメッセージの後ろに格納される。"
2113 #: build/C/man3/mq_send.3:92
2115 "If the message queue is already full (i.e., the number of messages on the "
2116 "queue equals the queue's I<mq_maxmsg> attribute), then, by default, "
2117 "B<mq_send>() blocks until sufficient space becomes available to allow the "
2118 "message to be queued, or until the call is interrupted by a signal handler. "
2119 "If the B<O_NONBLOCK> flag is enabled for the message queue description, then "
2120 "the call instead fails immediately with the error B<EAGAIN>."
2122 "メッセージキューがすでに一杯の場合 (すなわち、キューに入っているメッセージ数"
2123 "がキューの I<mq_maxmsg> 属性と等しい場合)、デフォルトでは、 B<mq_send ()> "
2124 "は、メッセージをキューイングするのに十分な空間ができるか、 関数呼び出しがシグ"
2125 "ナルハンドラにより中断されるまで、停止 (block) する。 メッセージキュー記述 "
2126 "(message queue description) で B<O_NONBLOCK> フラグが有効になっている場合"
2127 "は、 B<mq_send>() はエラー B<EAGAIN> ですぐに失敗する。"
2130 #: build/C/man3/mq_send.3:105
2132 "B<mq_timedsend>() behaves just like B<mq_send>(), except that if the queue "
2133 "is full and the B<O_NONBLOCK> flag is not enabled for the message queue "
2134 "description, then I<abs_timeout> points to a structure which specifies a "
2135 "ceiling on the time for which the call will block. This ceiling is an "
2136 "absolute timeout in seconds and nanoseconds since the Epoch, 1970-01-01 "
2137 "00:00:00 +0000 (UTC), and it is specified in the following structure:"
2139 "B<mq_timedsend>() は B<mq_send>() と全く同じ動作をするが、 メッセージキュー"
2140 "が一杯で、メッセージキュー記述で B<O_NONBLOCK> フラグが有効になっていない場合"
2141 "に、この呼び出しが停止する時間の上限を I<abs_timeout> が指す構造体で指定する"
2142 "点が異なる。この上限は、タイムアウトの時刻を 時刻紀元 (Epoch; 1970-01-01 "
2143 "00:00:00 +0000 (UTC)) からの経過時間 (秒とナノ秒の組) で指定する。タイムアウ"
2147 #: build/C/man3/mq_send.3:119
2149 "If the message queue is full, and the timeout has already expired by the "
2150 "time of the call, B<mq_timedsend>() returns immediately."
2152 "メッセージキューが一杯で、関数呼び出し時にすでにタイムアウト時刻が 過ぎている"
2153 "場合、 B<mq_timedsend>() はすぐに返る。"
2156 #: build/C/man3/mq_send.3:127
2158 "On success, B<mq_send>() and B<mq_timedsend>() return zero; on error, -1 "
2159 "is returned, with I<errno> set to indicate the error."
2161 "成功すると、 B<mq_send>() と B<mq_timedsend>() は 0 を返す。 エラーの場"
2162 "合、-1 を返し、 I<errno> にエラーを示す値を設定する。"
2165 #: build/C/man3/mq_send.3:134
2167 "The queue was full, and the B<O_NONBLOCK> flag was set for the message queue "
2168 "description referred to by I<mqdes>."
2170 "キューが一杯で、かつ I<mqdes> で参照されるメッセージキュー記述で "
2171 "B<O_NONBLOCK> フラグがセットされていた。"
2174 #: build/C/man3/mq_send.3:158
2176 "I<msg_len> was greater than the I<mq_msgsize> attribute of the message queue."
2177 msgstr "I<msg_len> がメッセージキューの I<mq_msgsize> 属性よりも大きかった。"
2180 #: build/C/man3/mq_send.3:169
2182 "On Linux, B<mq_timedsend>() is a system call, and B<mq_send>() is a "
2183 "library function layered on top of that system call."
2185 "Linux では、 B<mq_timedsend>() はシステムコールである。 B<mq_send>() はライ"
2186 "ブラリ関数で、 B<mq_timedsend>() システムコールを用いて実装されている。"
2189 #: build/C/man3/mq_send.3:178
2191 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2192 "B<mq_receive>(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2194 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2195 "B<mq_receive>(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2198 #: build/C/man3/mq_unlink.3:26
2204 #: build/C/man3/mq_unlink.3:29
2205 msgid "mq_unlink - remove a message queue"
2206 msgstr "mq_unlink - メッセージキューを削除する"
2209 #: build/C/man3/mq_unlink.3:34
2211 msgid "B<int mq_unlink(const char *>I<name>B<);>\n"
2212 msgstr "B<int mq_unlink(const char *>I<name>B<);>\n"
2215 #: build/C/man3/mq_unlink.3:44
2217 "B<mq_unlink>() removes the specified message queue I<name>. The message "
2218 "queue name is removed immediately. The queue itself is destroyed once any "
2219 "other processes that have the queue open close their descriptors referring "
2222 "B<mq_unlink>() は指定されたメッセージキュー I<name> を削除する。 メッセージ"
2223 "キュー名は直ちに削除される。 キュー自体は、そのキューをオープンした他のすべて"
2224 "のプロセスが そのキューを参照する記述子をクローズした時点で破棄される。"
2227 #: build/C/man3/mq_unlink.3:50
2229 "On success B<mq_unlink>() returns 0; on error, -1 is returned, with "
2230 "I<errno> set to indicate the error."
2232 "成功すると、 B<mq_unlink>() は 0 を返す。エラーの場合、-1 を返し、 I<errno> "
2236 #: build/C/man3/mq_unlink.3:54
2237 msgid "The caller does not have permission to unlink this message queue."
2239 "呼び出し元プロセスがこのメッセージキューを削除 (unlink) する 許可を持たない。"
2242 #: build/C/man3/mq_unlink.3:62
2243 msgid "There is no message queue with the given I<name>."
2244 msgstr "指定された名前 I<name> を持つメッセージキューが存在しない。"
2247 #: build/C/man3/mq_unlink.3:72
2249 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2250 "B<mq_receive>(3), B<mq_send>(3), B<mq_overview>(7)"
2252 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2253 "B<mq_receive>(3), B<mq_send>(3), B<mq_overview>(7)"
2256 #: build/C/man2/msgctl.2:35
2262 #: build/C/man2/msgctl.2:35
2268 #: build/C/man2/msgctl.2:38
2269 msgid "msgctl - message control operations"
2270 msgstr "msgctl - メッセージ制御操作"
2273 #: build/C/man2/msgctl.2:43 build/C/man2/msgget.2:41 build/C/man2/msgop.2:46
2276 "B<#include E<lt>sys/types.hE<gt>>\n"
2277 "B<#include E<lt>sys/ipc.hE<gt>>\n"
2278 "B<#include E<lt>sys/msg.hE<gt>>\n"
2280 "B<#include E<lt>sys/types.hE<gt>>\n"
2281 "B<#include E<lt>sys/ipc.hE<gt>>\n"
2282 "B<#include E<lt>sys/msg.hE<gt>>\n"
2285 #: build/C/man2/msgctl.2:45
2287 msgid "B<int msgctl(int >I<msqid>B<, int >I<cmd>B<, struct msqid_ds *>I<buf>B<);>\n"
2288 msgstr "B<int msgctl(int >I<msqid>B<, int >I<cmd>B<, struct msqid_ds *>I<buf>B<);>\n"
2291 #: build/C/man2/msgctl.2:52
2293 "B<msgctl>() performs the control operation specified by I<cmd> on the "
2294 "message queue with identifier I<msqid>."
2296 "B<msgctl>() はメッセージ・キュー識別子 I<msqid> で指定されたメッセージ・"
2297 "キュー (message queue) に対して I<cmd> で指定された制御操作を行なう。"
2300 #: build/C/man2/msgctl.2:56
2302 "The I<msqid_ds> data structure is defined in I<E<lt>sys/msg.hE<gt>> as "
2305 "I<msqid_ds> データ構造体は I<E<lt>sys/msg.hE<gt>> で以下のように定義されてい"
2309 #: build/C/man2/msgctl.2:73
2312 "struct msqid_ds {\n"
2313 " struct ipc_perm msg_perm; /* Ownership and permissions */\n"
2314 " time_t msg_stime; /* Time of last msgsnd(2) */\n"
2315 " time_t msg_rtime; /* Time of last msgrcv(2) */\n"
2316 " time_t msg_ctime; /* Time of last change */\n"
2317 " unsigned long __msg_cbytes; /* Current number of bytes in\n"
2318 " queue (nonstandard) */\n"
2319 " msgqnum_t msg_qnum; /* Current number of messages\n"
2321 " msglen_t msg_qbytes; /* Maximum number of bytes\n"
2322 " allowed in queue */\n"
2323 " pid_t msg_lspid; /* PID of last msgsnd(2) */\n"
2324 " pid_t msg_lrpid; /* PID of last msgrcv(2) */\n"
2327 "struct msqid_ds {\n"
2328 " struct ipc_perm msg_perm; /* 所有権と許可 */\n"
2329 " time_t msg_stime; /* 最後の msgsnd(2) の時刻 */\n"
2330 " time_t msg_rtime; /* 最後の msgrcv(2) の時刻 */\n"
2331 " time_t msg_ctime; /* 最後に変更が行われた時刻 */\n"
2332 " unsigned long __msg_cbytes; /* キューにある現在のバイト数\n"
2334 " msgqnum_t msg_qnum; /* キューにある現在入っている\n"
2336 " msglen_t msg_qbytes; /* キューに許可されている\n"
2338 " pid_t msg_lspid; /* 最後の msgsnd(2) の PID */\n"
2339 " pid_t msg_lrpid; /* 最後の msgrcv(2) の PID */\n"
2343 #: build/C/man2/msgctl.2:81
2345 "The I<ipc_perm> structure is defined in I<E<lt>sys/ipc.hE<gt>> as follows "
2346 "(the highlighted fields are settable using B<IPC_SET>):"
2348 "I<ipc_perm> 構造体は I<E<lt>sys/ipc.hE<gt>> で以下のように定義されている (強"
2349 "調されたフィールドは B<IPC_SET> を使って設定可能である):"
2352 #: build/C/man2/msgctl.2:93
2355 "struct ipc_perm {\n"
2356 " key_t __key; /* Key supplied to msgget(2) */\n"
2357 " uid_t B<uid>; /* Effective UID of owner */\n"
2358 " gid_t B<gid>; /* Effective GID of owner */\n"
2359 " uid_t cuid; /* Effective UID of creator */\n"
2360 " gid_t cgid; /* Effective GID of creator */\n"
2361 " unsigned short B<mode>; /* Permissions */\n"
2362 " unsigned short __seq; /* Sequence number */\n"
2365 "struct ipc_perm {\n"
2366 " key_t __key; /* msgget(2) に与えるキー */\n"
2367 " uid_t B<uid>; /* 所有者の実効 UID */\n"
2368 " gid_t B<gid>; /* 所有者の実効 GID */\n"
2369 " uid_t cuid; /* 作成者の実効 UID */\n"
2370 " gid_t cgid; /* 作成者の実効 GID */\n"
2371 " unsigned short B<mode>; /* 許可 */\n"
2372 " unsigned short __seq; /* シーケンス番号 */\n"
2376 #: build/C/man2/msgctl.2:99
2377 msgid "Valid values for I<cmd> are:"
2378 msgstr "I<cmd> として有効な値は:"
2381 #: build/C/man2/msgctl.2:99
2384 msgstr "B<IPC_STAT>"
2387 #: build/C/man2/msgctl.2:108
2389 "Copy information from the kernel data structure associated with I<msqid> "
2390 "into the I<msqid_ds> structure pointed to by I<buf>. The caller must have "
2391 "read permission on the message queue."
2393 "I<msqid> に関連づけられたメッセージ・キュー・データ構造体から、ポインタ "
2394 "I<buf> が指し示す I<msqid_ds> 構造体に情報をコピーする。 呼び出し側はメッセー"
2395 "ジ・キューに対する読み込み許可を持っていなければならない。"
2398 #: build/C/man2/msgctl.2:108
2404 #: build/C/man2/msgctl.2:135
2406 "Write the values of some members of the I<msqid_ds> structure pointed to by "
2407 "I<buf> to the kernel data structure associated with this message queue, "
2408 "updating also its I<msg_ctime> member. The following members of the "
2409 "structure are updated: I<msg_qbytes>, I<msg_perm.uid>, I<msg_perm.gid>, and "
2410 "(the least significant 9 bits of) I<msg_perm.mode>. The effective UID of "
2411 "the calling process must match the owner (I<msg_perm.uid>) or creator "
2412 "(I<msg_perm.cuid>) of the message queue, or the caller must be privileged. "
2413 "Appropriate privilege (Linux: the B<CAP_IPC_RESOURCE> capability) is "
2414 "required to raise the I<msg_qbytes> value beyond the system parameter "
2417 "ポインタ I<buf> が指し示す I<msqid_ds> 構造体のメンバーの値を、メッセージ・"
2418 "キューに関連づけられた カーネル・データ構造体に書き込み、 I<msg_ctime> メン"
2419 "バーも更新する。 構造体のメンバーのうち、更新されるものを以下に示す: "
2420 "I<msg_qbytes>, I<msg_perm.uid>, I<msg_perm.gid>, I<msg_perm.mode> (の下位 9 "
2421 "ビット)。 呼び出したプロセスの実効ユーザ ID が、メッセージ・キューの所有者 "
2422 "(I<msg_perm.uid>) または作成者 (I<msg_perm.cuid>) と一致するか、呼び出し元"
2423 "が特権を持たなければならない。 I<msg_qbytes> をシステム・パラメータの "
2424 "B<MSGMNB> を超えて設定するには、適切な特権 (Linux では B<CAP_IPC_RESOURCE> "
2425 "ケーパビリティ (capability)) が必要である。"
2428 #: build/C/man2/msgctl.2:135
2431 msgstr "B<IPC_RMID>"
2434 #: build/C/man2/msgctl.2:146
2436 "Immediately remove the message queue, awakening all waiting reader and "
2437 "writer processes (with an error return and I<errno> set to B<EIDRM>). The "
2438 "calling process must have appropriate privileges or its effective user ID "
2439 "must be either that of the creator or owner of the message queue."
2441 "メッセージ・キューをただちに削除する。 同時にその構造体の読み書きの待ち状態に"
2442 "あったプロセスに通知する (エラーが返り、 I<errno> が B<EIDRM> に設定され"
2443 "る)。 呼び出したプロセスが適切な特権を持っているか、 呼び出したプロセスの実効"
2444 "ユーザ ID がメッセージ・キューの作成者か 所有者の実効ユーザ ID でなければなら"
2448 #: build/C/man2/msgctl.2:146
2450 msgid "B<IPC_INFO> (Linux-specific)"
2451 msgstr "B<IPC_INFO> (Linux 固有)"
2454 #: build/C/man2/msgctl.2:159
2456 "Returns information about system-wide message queue limits and parameters in "
2457 "the structure pointed to by I<buf>. This structure is of type I<msginfo> "
2458 "(thus, a cast is required), defined in I<E<lt>sys/msg.hE<gt>> if the "
2459 "B<_GNU_SOURCE> feature test macro is defined:"
2461 "システム全体でのメッセージ・キューの制限とパラメータに関する情報を、 I<buf> "
2462 "が指す構造体に入れて返す。 この構造体は I<msginfo> 型である (そのためキャスト"
2463 "が必要である)。 I<msginfo> は B<_GNU_SOURCE> 機能検査マクロが定義された場合"
2464 "に I<E<lt>sys/msg.hE<gt>> で以下のように定義される:"
2467 #: build/C/man2/msgctl.2:183
2470 "struct msginfo {\n"
2471 " int msgpool; /* Size in kibibytes of buffer pool\n"
2472 " used to hold message data;\n"
2473 " unused within kernel */\n"
2474 " int msgmap; /* Maximum number of entries in message\n"
2475 " map; unused within kernel */\n"
2476 " int msgmax; /* Maximum number of bytes that can be\n"
2477 " written in a single message */\n"
2478 " int msgmnb; /* Maximum number of bytes that can be\n"
2479 " written to queue; used to initialize\n"
2480 " msg_qbytes during queue creation\n"
2482 " int msgmni; /* Maximum number of message queues */\n"
2483 " int msgssz; /* Message segment size;\n"
2484 " unused within kernel */\n"
2485 " int msgtql; /* Maximum number of messages on all queues\n"
2486 " in system; unused within kernel */\n"
2487 " unsigned short int msgseg;\n"
2488 " /* Maximum number of segments;\n"
2489 " unused within kernel */\n"
2492 "struct msginfo {\n"
2493 " int msgpool; /* メッセージ・データの保持に使用される\n"
2494 " バッファ・プールの大きさ (1024 バイト単位);\n"
2496 " int msgmap; /* メッセージ・マップの最大エントリ数;\n"
2498 " int msgmax; /* 一つのメッセージに書き込み可能な\n"
2500 " int msgmnb; /* 一つのキューに書き込み可能な最大バイト数;\n"
2501 " (msgget(2) での) キュー作成中の msg_qbytes\n"
2503 " int msgmni; /* メッセージ・キューの数の最大値 */\n"
2504 " int msgssz; /* メッセージ・セグメントのサイズ;\n"
2506 " int msgtql; /* システム上の全キューの最大メッセージ数;\n"
2508 " unsigned short int msgseg;\n"
2509 " /* 最大セグメント数; カーネル内では未使用 */\n"
2513 #: build/C/man2/msgctl.2:196
2515 "The I<msgmni>, I<msgmax>, and I<msgmnb> settings can be changed via I</proc> "
2516 "files of the same name; see B<proc>(5) for details."
2518 "設定 I<msgmni ,> I<msgmax ,> I<msgmnb> は I</proc> にある同じ名前のファイル経"
2519 "由で変更可能である。 詳しくは B<proc>(5) を参照。"
2522 #: build/C/man2/msgctl.2:196
2524 msgid "B<MSG_INFO> (Linux-specific)"
2525 msgstr "B<MSG_INFO> (Linux 固有)"
2528 #: build/C/man2/msgctl.2:213
2530 "Returns a I<msginfo> structure containing the same information as for "
2531 "B<IPC_INFO>, except that the following fields are returned with information "
2532 "about system resources consumed by message queues: the I<msgpool> field "
2533 "returns the number of message queues that currently exist on the system; the "
2534 "I<msgmap> field returns the total number of messages in all queues on the "
2535 "system; and the I<msgtql> field returns the total number of bytes in all "
2536 "messages in all queues on the system."
2538 "B<IPC_INFO> のときと同じ情報を格納した I<msginfo> 構造体を返す。 但し、以下の"
2539 "フィールドにはメッセージ・キューが 消費しているシステム資源に関する情報が格納"
2540 "される点が異なる。 I<msgpool> フィールドは現在システム上に存在するメッセー"
2541 "ジ・キューの数を返す。 I<msgmap> フィールドはシステム上の全てのキューに入って"
2542 "いるメッセージ総数を返す。 I<msgtql> フィールドはシステム上の全てのキューに"
2543 "入っている全メッセージの 総バイト数を返す。"
2546 #: build/C/man2/msgctl.2:213
2548 msgid "B<MSG_STAT> (Linux-specific)"
2549 msgstr "B<MSG_STAT> (Linux 固有)"
2552 #: build/C/man2/msgctl.2:224
2554 "Returns a I<msqid_ds> structure as for B<IPC_STAT>. However, the I<msqid> "
2555 "argument is not a queue identifier, but instead an index into the kernel's "
2556 "internal array that maintains information about all message queues on the "
2559 "B<IPC_STAT> と同じく I<msqid_ds> 構造体を返す。 但し、 I<msqid> 引き数は、"
2560 "キュー識別子ではなく、システム上の全てのメッセージ・キュー に関する情報を管理"
2561 "するカーネルの内部配列へのインデックスである。"
2564 #: build/C/man2/msgctl.2:245
2566 "On success, B<IPC_STAT>, B<IPC_SET>, and B<IPC_RMID> return 0. A successful "
2567 "B<IPC_INFO> or B<MSG_INFO> operation returns the index of the highest used "
2568 "entry in the kernel's internal array recording information about all message "
2569 "queues. (This information can be used with repeated B<MSG_STAT> operations "
2570 "to obtain information about all queues on the system.) A successful "
2571 "B<MSG_STAT> operation returns the identifier of the queue whose index was "
2572 "given in I<msqid>."
2574 "成功すると、 B<IPC_STAT>, B<IPC_SET>, B<IPC_RMID> は 0 を返す。 B<IPC_INFO> "
2575 "と B<MSG_INFO> 操作は、成功すると、全てのメッセージ・キューに関する情報を 管"
2576 "理しているカーネルの内部配列の使用中エントリのインデックスの うち最大値を返"
2577 "す (この情報は、システムの全てのメッセージ・キューに関する情報を 取得するため"
2578 "に、 B<MSG_STAT> 操作を繰り返し実行する際に使用できる)。 B<MSG_STAT> 操作は、"
2579 "成功すると、 I<msqid> で指定されたインデックスを持つメッセージ・キューの識別"
2583 #: build/C/man2/msgctl.2:249
2584 msgid "On error, -1 is returned with I<errno> indicating the error."
2585 msgstr "エラーの場合は -1 を返し、 I<errno> を適切に設定する。"
2588 #: build/C/man2/msgctl.2:253
2589 msgid "On failure, I<errno> is set to one of the following:"
2590 msgstr "失敗した場合、 I<errno> は以下の値の中のどれか一つに設定される:"
2593 #: build/C/man2/msgctl.2:266
2595 "The argument I<cmd> is equal to B<IPC_STAT> or B<MSG_STAT>, but the calling "
2596 "process does not have read permission on the message queue I<msqid>, and "
2597 "does not have the B<CAP_IPC_OWNER> capability."
2599 "引き数 I<cmd> が B<IPC_STAT> または B<MSG_STAT> に等しいが、呼び出したプロセ"
2600 "スがメッセージ・キュー I<msqid> に対する読み込み許可を持っておらず、かつ "
2601 "B<CAP_IPC_OWNER> ケーパビリティを持っていない。"
2604 #: build/C/man2/msgctl.2:266 build/C/man2/msgop.2:318 build/C/man2/msgop.2:371
2610 #: build/C/man2/msgctl.2:277
2612 "The argument I<cmd> has the value B<IPC_SET> or B<IPC_STAT>, but the address "
2613 "pointed to by I<buf> isn't accessible."
2615 "引き数 I<cmd> が B<IPC_SET> か B<IPC_STAT> で、ポインタ I<buf> で指されている"
2619 #: build/C/man2/msgctl.2:277 build/C/man2/msgop.2:323 build/C/man2/msgop.2:376
2625 #: build/C/man2/msgctl.2:280 build/C/man2/msgop.2:326
2626 msgid "The message queue was removed."
2627 msgstr "メッセージ・キューが削除された。"
2630 #: build/C/man2/msgctl.2:291
2632 "Invalid value for I<cmd> or I<msqid>. Or: for a B<MSG_STAT> operation, the "
2633 "index value specified in I<msqid> referred to an array slot that is "
2636 "I<cmd> または I<msqid> に不正な値が設定された。 もしくは、 B<MSG_STAT> 操作の"
2637 "場合に、 I<msqid> で指定されたインデックス値が現在未使用の配列のスロットを参"
2641 #: build/C/man2/msgctl.2:291
2647 #: build/C/man2/msgctl.2:309
2649 "The argument I<cmd> has the value B<IPC_SET> or B<IPC_RMID>, but the "
2650 "effective user ID of the calling process is not the creator (as found in "
2651 "I<msg_perm.cuid>) or the owner (as found in I<msg_perm.uid>) of the "
2652 "message queue, and the process is not privileged (Linux: it does not have "
2653 "the B<CAP_SYS_ADMIN> capability)."
2655 "引き数 I<cmd> が B<IPC_SET> か B<IPC_RMID> であるが、呼び出したプロセスの実効"
2656 "ユーザ ID がメッセージキューの (I<msg_perm.cuid> として見つかる) 作成者 と "
2657 "(I<msg_perm.uid> として見つかる) 所有者のいずれでもなく、 かつ呼び出したプロ"
2658 "セスに特権 (Linux では B<CAP_SYS_ADMIN> ケーパビリティ) がない。"
2661 #: build/C/man2/msgctl.2:312 build/C/man2/msgget.2:183
2662 #: build/C/man2/msgop.2:399
2663 msgid "SVr4, POSIX.1-2001."
2664 msgstr "SVr4, POSIX.1-2001."
2667 #: build/C/man2/msgctl.2:323
2669 "The B<IPC_INFO>, B<MSG_STAT> and B<MSG_INFO> operations are used by the "
2670 "B<ipcs>(1) program to provide information on allocated resources. In the "
2671 "future these may modified or moved to a /proc file system interface."
2673 "B<IPC_INFO>, B<MSG_STAT>, B<MSG_INFO> 操作は、 B<ipcs>(1) プログラムで割り当"
2674 "て済の資源に関する情報を提供するために 使用されている。将来、これらの操作は変"
2675 "更されたり、 /proc ファイルシステムのインタフェースに移動されるかもしれない。"
2678 #: build/C/man2/msgctl.2:337
2680 "Various fields in the I<struct msqid_ds> were typed as I<short> under Linux "
2681 "2.2 and have become I<long> under Linux 2.4. To take advantage of this, a "
2682 "recompilation under glibc-2.1.91 or later should suffice. (The kernel "
2683 "distinguishes old and new calls by an B<IPC_64> flag in I<cmd>.)"
2685 "I<struct msqid_ds> 内の多くのフィールドは、 Linux 2.2 では I<short> だった"
2686 "が、Linux 2.4 では I<long> になった。 この利点を生かすには、glibc-2.1.91 以降"
2687 "の環境下で 再コンパイルすれば十分である。 (カーネルは新しい形式の呼び出しと古"
2688 "い形式の呼び出しを I<cmd> 内の B<IPC_64> フラグで区別する。)"
2691 #: build/C/man2/msgctl.2:344
2693 "B<msgget>(2), B<msgrcv>(2), B<msgsnd>(2), B<capabilities>(7), B<mq_overview>"
2696 "B<msgget>(2), B<msgrcv>(2), B<msgsnd>(2), B<capabilities>(7), B<mq_overview>"
2700 #: build/C/man2/msgget.2:33
2706 #: build/C/man2/msgget.2:33
2712 #: build/C/man2/msgget.2:36
2713 msgid "msgget - get a message queue identifier"
2714 msgstr "msgget - メッセージ・キュー識別子を取得する"
2717 #: build/C/man2/msgget.2:43
2719 msgid "B<int msgget(key_t >I<key>B<, int >I<msgflg>B<);>\n"
2720 msgstr "B<int msgget(key_t >I<key>B<, int >I<msgflg>B<);>\n"
2723 #: build/C/man2/msgget.2:65
2725 "The B<msgget>() system call returns the message queue identifier associated "
2726 "with the value of the I<key> argument. A new message queue is created if "
2727 "I<key> has the value B<IPC_PRIVATE> or I<key> isn't B<IPC_PRIVATE>, no "
2728 "message queue with the given key I<key> exists, and B<IPC_CREAT> is "
2729 "specified in I<msgflg>."
2731 "B<msgget>() システムコールは I<key> 引き数の値に対応するメッセージ・キューの"
2732 "識別子を返す。 I<key> の値が B<IPC_PRIVATE> の場合、または I<key> が "
2733 "B<IPC_PRIVATE> でなくても、 I<key> に対応するメッセージ・キューが存在せず、 "
2734 "I<msgflg> に B<IPC_CREAT> が指定されている場合、 新しいメッセージ・キューが作"
2738 #: build/C/man2/msgget.2:84
2740 "If I<msgflg> specifies both B<IPC_CREAT> and B<IPC_EXCL> and a message queue "
2741 "already exists for I<key>, then B<msgget>() fails with I<errno> set to "
2742 "B<EEXIST>. (This is analogous to the effect of the combination B<O_CREAT | "
2743 "O_EXCL> for B<open>(2).)"
2745 "I<msgflg> に B<IPC_CREAT> と B<IPC_EXCL> の両方が指定された場合、 I<key> に対"
2746 "応するメッセージ・キューが既に存在すると、 B<msgget>() は失敗し、 I<errno> "
2747 "に B<EEXIST> が設定される。 (これは B<open>(2) に B<O_CREAT | O_EXCL> を指定"
2751 #: build/C/man2/msgget.2:94
2753 "Upon creation, the least significant bits of the argument I<msgflg> define "
2754 "the permissions of the message queue. These permission bits have the same "
2755 "format and semantics as the permissions specified for the I<mode> argument "
2756 "of B<open>(2). (The execute permissions are not used.)"
2758 "メッセージ・キューの作成時に、 I<msgflg> 引き数の下位 9 ビットは、 そのメッ"
2759 "セージ・キューのアクセス許可の定義として使用される。 これらの許可ビットは "
2760 "B<open>(2) の引き数 I<mode> と同じ形式で同じ意味である。 や B<creat>(2) シ"
2761 "ステム・コールのアクセス許可パラメータと同じ形式で、同じ意味を持つ。 (但し、"
2762 "実行 (execute) 許可は使用されない。)"
2765 #: build/C/man2/msgget.2:101
2767 "If a new message queue is created, then its associated data structure "
2768 "I<msqid_ds> (see B<msgctl>(2)) is initialized as follows:"
2770 "新規のメッセージ・キューを作成する際、 B<msgget>() システム・コールはメッ"
2771 "セージ・キューのデータ構造体 I<msqid_ds> を以下のように初期化する "
2772 "(I<msqid_ds> については B<msgctl>(2) を参照):"
2775 #: build/C/man2/msgget.2:106
2777 "I<msg_perm.cuid> and I<msg_perm.uid> are set to the effective user ID of the "
2780 "I<msg_perm.cuid> と I<msg_perm.uid> に呼び出し元プロセスの実効 (effective) "
2784 #: build/C/man2/msgget.2:111
2786 "I<msg_perm.cgid> and I<msg_perm.gid> are set to the effective group ID of "
2787 "the calling process."
2789 "I<msg_perm.cgid> と I<msg_perm.gid> に呼び出し元プロセスの実効 (effective) グ"
2793 #: build/C/man2/msgget.2:116
2795 "The least significant 9 bits of I<msg_perm.mode> are set to the least "
2796 "significant 9 bits of I<msgflg>."
2798 "I<msg_perm.mode> の下位 9 ビットは I<msgflg> の下位 9 ビットを設定する。"
2801 #: build/C/man2/msgget.2:124
2803 "I<msg_qnum>, I<msg_lspid>, I<msg_lrpid>, I<msg_stime> and I<msg_rtime> are "
2806 "I<msg_qnum>, I<msg_lspid>, I<msg_lrpid>, I<msg_stime>, I<msg_rtime> に 0 を設"
2810 #: build/C/man2/msgget.2:127
2811 msgid "I<msg_ctime> is set to the current time."
2812 msgstr "I<msg_ctime> に現在の時刻を設定する。"
2815 #: build/C/man2/msgget.2:131
2816 msgid "I<msg_qbytes> is set to the system limit B<MSGMNB>."
2818 "I<msg_qbytes> に、システムで決められたメッセージ・キューの最大サイズ "
2822 #: build/C/man2/msgget.2:135
2824 "If the message queue already exists the permissions are verified, and a "
2825 "check is made to see if it is marked for destruction."
2827 "メッセージ・キューがすでに存在する場合は、アクセス許可の検査と、 破棄 "
2828 "(destruction) マークがないかの確認が行われる。"
2831 #: build/C/man2/msgget.2:141
2833 "If successful, the return value will be the message queue identifier (a "
2834 "nonnegative integer), otherwise -1 with I<errno> indicating the error."
2836 "成功した場合、返り値はメッセージ・キュー識別子 (非負の整数) となる。 失敗した"
2837 "場合は -1 が返され、 I<errno> にそのエラーが示される。"
2840 #: build/C/man2/msgget.2:145
2841 msgid "On failure, I<errno> is set to one of the following values:"
2842 msgstr "失敗した場合、 I<errno> に以下の値のいずれか一つが設定される:"
2845 #: build/C/man2/msgget.2:153
2847 "A message queue exists for I<key>, but the calling process does not have "
2848 "permission to access the queue, and does not have the B<CAP_IPC_OWNER> "
2851 "I<key> に対応するメッセージ・キューは存在するが、 呼び出し元プロセスはその"
2852 "キューに対するアクセス許可がなく、 B<CAP_IPC_OWNER> ケーパビリティも持ってい"
2856 #: build/C/man2/msgget.2:163
2858 "A message queue exists for I<key> and I<msgflg> specified both B<IPC_CREAT> "
2861 "I<key> に対応するメッセージ・キューが存在し、 I<msgflg> に B<IPC_CREAT> と "
2862 "B<IPC_EXCL> が指定されていた。"
2865 #: build/C/man2/msgget.2:171
2867 "No message queue exists for I<key> and I<msgflg> did not specify "
2870 "I<key> に対応するメッセージ・キューが存在せず、 I<msgflg> に B<IPC_CREAT> が"
2874 #: build/C/man2/msgget.2:175
2876 "A message queue has to be created but the system does not have enough memory "
2877 "for the new data structure."
2879 "メッセージ・キューを作成しようとしたが、新しいデータ構造体を作成 するのに十分"
2883 #: build/C/man2/msgget.2:181
2885 "A message queue has to be created but the system limit for the maximum "
2886 "number of message queues (B<MSGMNI>) would be exceeded."
2888 "メッセージ・キューを作成しようとしたが、作成すると システム全体のメッセージ・"
2889 "キュー数の最大値 (B<MSGMNI>) を超えてしまう。"
2892 #: build/C/man2/msgget.2:193
2894 "B<IPC_PRIVATE> isn't a flag field but a I<key_t> type. If this special "
2895 "value is used for I<key>, the system call ignores everything but the least "
2896 "significant 9 bits of I<msgflg> and creates a new message queue (on success)."
2898 "B<IPC_PRIVATE> はフラグではなく、 I<key_t> 型である。 この特別な値が I<key> "
2899 "として使用された場合、 B<msgget>() システムコールは I<msgflg> の下位 9 ビッ"
2900 "ト以外の全てを無視して (成功した場合は) 新しいメッセージ・キューを作成する。"
2903 #: build/C/man2/msgget.2:197
2905 "The following is a system limit on message queue resources affecting a "
2908 "B<msgget>() システムコールに影響を及ぼすメッセージ・キューの資源の システム"
2912 #: build/C/man2/msgget.2:197
2918 #: build/C/man2/msgget.2:203
2920 "System wide maximum number of message queues: policy dependent (on Linux, "
2921 "this limit can be read and modified via I</proc/sys/kernel/msgmni>)."
2923 "システム全体のメッセージ・キュー数の最大値: 方針依存 (Linux では、この制限値"
2924 "は I</proc/sys/kernel/msgmni> 経由で参照したり、変更したりできる)。"
2927 #: build/C/man2/msgget.2:203
2933 #: build/C/man2/msgget.2:209
2935 "Until version 2.3.20 Linux would return B<EIDRM> for a B<msgget>() on a "
2936 "message queue scheduled for deletion."
2938 "Linux 2.3.20 までは、削除が予定されているメッセージ・キューに対して B<msgget>"
2939 "() を行うと B<EIDRM> がエラーとして返されるようになっていた。"
2942 #: build/C/man2/msgget.2:215
2944 "The name choice B<IPC_PRIVATE> was perhaps unfortunate, B<IPC_NEW> would "
2945 "more clearly show its function."
2947 "B<IPC_PRIVATE> という名前を選んだのはおそらく失敗であろう。 B<IPC_NEW> の方が"
2948 "より明確にその機能を表しているだろう。"
2951 #: build/C/man2/msgget.2:223
2953 "B<msgctl>(2), B<msgrcv>(2), B<msgsnd>(2), B<ftok>(3), B<capabilities>(7), "
2954 "B<mq_overview>(7), B<svipc>(7)"
2956 "B<msgctl>(2), B<msgrcv>(2), B<msgsnd>(2), B<ftok>(3), B<capabilities>(7), "
2957 "B<mq_overview>(7), B<svipc>(7)"
2960 #: build/C/man2/msgop.2:38
2966 #: build/C/man2/msgop.2:38
2972 #: build/C/man2/msgop.2:41
2973 msgid "msgrcv, msgsnd - message operations"
2974 msgstr "msgrcv, msgsnd - メッセージ操作"
2977 #: build/C/man2/msgop.2:49
2979 msgid "B<int msgsnd(int >I<msqid>B<, const void *>I<msgp>B<, size_t >I<msgsz>B<, int >I<msgflg>B<);>\n"
2980 msgstr "B<int msgsnd(int >I<msqid>B<, const void *>I<msgp>B<, size_t >I<msgsz>B<, int >I<msgflg>B<);>\n"
2983 #: build/C/man2/msgop.2:53
2986 "B<ssize_t msgrcv(int >I<msqid>B<, void *>I<msgp>B<, size_t >I<msgsz>B<, long >I<msgtyp>B<,>\n"
2987 "B< int >I<msgflg>B<);>\n"
2989 "B<ssize_t msgrcv(int >I<msqid>B<, void *>I<msgp>B<, size_t >I<msgsz>B<, long >I<msgtyp>B<,>\n"
2990 "B< int >I<msgflg>B<);>\n"
2993 #: build/C/man2/msgop.2:63
2995 "The B<msgsnd>() and B<msgrcv>() system calls are used, respectively, to "
2996 "send messages to, and receive messages from, a message queue. The calling "
2997 "process must have write permission on the message queue in order to send a "
2998 "message, and read permission to receive a message."
3000 "システムコール B<msgsnd>() と B<msgrcv>() はそれぞれ、メッセージ・キューへ"
3001 "のメッセージの送信と、 メッセージの受信に使用される。呼び出し元プロセスは、 "
3002 "メッセージを送信するためにはメッセージ・キューに対する書き込み許可を、 メッ"
3003 "セージを受信するためには読み出し許可を持っていなければならない。"
3006 #: build/C/man2/msgop.2:68
3008 "The I<msgp> argument is a pointer to caller-defined structure of the "
3009 "following general form:"
3011 "呼び出し元プロセスは以下に示す構造体を用意し、この構造体への ポインタを "
3015 #: build/C/man2/msgop.2:75
3019 " long mtype; /* message type, must be E<gt> 0 */\n"
3020 " char mtext[1]; /* message data */\n"
3024 " long mtype; /* message type, must be E<gt> 0 */\n"
3025 " char mtext[1]; /* message data */\n"
3029 #: build/C/man2/msgop.2:94
3031 "The I<mtext> field is an array (or other structure) whose size is specified "
3032 "by I<msgsz>, a nonnegative integer value. Messages of zero length (i.e., no "
3033 "I<mtext> field) are permitted. The I<mtype> field must have a strictly "
3034 "positive integer value. This value can be used by the receiving process for "
3035 "message selection (see the description of B<msgrcv>() below)."
3037 "I<mtext> フィールドは配列 (または他の構造体) で、その大きさは 非負の整数であ"
3038 "る I<msgsz> で指定される。 長さ 0 のメッセージ (つまり I<mtext> フィールドが"
3039 "ないメッセージ) も認められている。 B<mtype> フィールドは厳密に正の整数でなけ"
3040 "ればならない。 この値は、メッセージを受信するプロセスでメッセージを選択するた"
3041 "めに 使用される (下記の B<msgrcv>() の説明を参照のこと)。"
3044 #: build/C/man2/msgop.2:94
3050 #: build/C/man2/msgop.2:102
3052 "The B<msgsnd>() system call appends a copy of the message pointed to by "
3053 "I<msgp> to the message queue whose identifier is specified by I<msqid>."
3055 "B<msgsnd>() システムコールは I<msgp> 引き数で指定されたメッセージのコピーを "
3056 "I<msqid> で指定された識別子を持つメッセージ・キューへ追加する。"
3059 #: build/C/man2/msgop.2:123
3061 "If sufficient space is available in the queue, B<msgsnd>() succeeds "
3062 "immediately. (The queue capacity is defined by the I<msg_qbytes> field in "
3063 "the associated data structure for the message queue. During queue creation "
3064 "this field is initialized to B<MSGMNB> bytes, but this limit can be modified "
3065 "using B<msgctl>(2).) If insufficient space is available in the queue, then "
3066 "the default behavior of B<msgsnd>() is to block until space becomes "
3067 "available. If B<IPC_NOWAIT> is specified in I<msgflg>, then the call "
3068 "instead fails with the error B<EAGAIN>."
3070 "キューに十分な空き容量がある場合、 B<msgsnd>() は直ちに成功する。 (キューの"
3071 "容量は、メッセージ・キューのデータ構造体の I<msg_qbytes> フィールドで定義され"
3072 "る。 キュー作成時にこのフィールドは B<MSGMNB> に初期化されるが、この制限は "
3073 "B<msgctl>(2) を使って変更できる。) キューに十分な空き容量がない場合、 デ"
3074 "フォルトでは B<msgsnd>() は空き容量ができるまで停止 (block) する。 "
3075 "I<msgflg> に B<IPC_NOWAIT> が指定された場合は、エラー B<EAGAIN> で失敗する。"
3078 #: build/C/man2/msgop.2:127
3079 msgid "A blocked B<msgsnd>() call may also fail if:"
3080 msgstr "停止している B<msgsnd>() は以下の場合にも失敗する。"
3083 #: build/C/man2/msgop.2:127 build/C/man2/msgop.2:134 build/C/man2/msgop.2:196
3084 #: build/C/man2/msgop.2:201 build/C/man2/msgop.2:215 build/C/man2/msgop.2:254
3085 #: build/C/man2/msgop.2:256 build/C/man2/msgop.2:262
3091 #: build/C/man2/msgop.2:134
3093 "the queue is removed, in which case the system call fails with I<errno> set "
3095 msgstr "キューが削除された。 この場合、 I<errno> は B<EIDRM> に設定される。"
3098 #: build/C/man2/msgop.2:146
3100 "a signal is caught, in which case the system call fails with I<errno> set to "
3101 "B<EINTR>;B<see> B<signal>(7). (B<msgsnd>() is never automatically "
3102 "restarted after being interrupted by a signal handler, regardless of the "
3103 "setting of the B<SA_RESTART> flag when establishing a signal handler.)"
3105 "シグナルが捕捉された。 この場合、 I<errno> は B<EINTR> に設定される。 "
3106 "B<signal>(7) 参照。 (B<msgsnd>() は、たとえシグナルハンドラの設定時に "
3107 "B<SA_RESTART> を指定していたとしても、シグナルハンドラによって割り込まれた後"
3108 "で 自動的に再スタートすることは決してない。)"
3111 #: build/C/man2/msgop.2:149 build/C/man2/msgop.2:276
3113 "Upon successful completion the message queue data structure is updated as "
3116 "正常に終了した場合、メッセージ・キューのデータ構造体は以下のように 更新され"
3120 #: build/C/man2/msgop.2:152
3121 msgid "I<msg_lspid> is set to the process ID of the calling process."
3122 msgstr "I<msg_lspid> には呼び出し元プロセスのプロセス ID が設定される。"
3125 #: build/C/man2/msgop.2:155
3126 msgid "I<msg_qnum> is incremented by 1."
3127 msgstr "I<msg_qnum> は 1 増加する。"
3130 #: build/C/man2/msgop.2:158
3131 msgid "I<msg_stime> is set to the current time."
3132 msgstr "I<msg_stime> には現在時刻が設定される。"
3135 #: build/C/man2/msgop.2:158
3141 #: build/C/man2/msgop.2:166
3143 "The B<msgrcv>() system call removes a message from the queue specified by "
3144 "I<msqid> and places it in the buffer pointed to by I<msgp>."
3146 "B<msgrcv>() システムコールは I<msqid> で指定されたキューからメッセージを削除"
3147 "し、 I<msgp> で指定されたバッファにそのメッセージを格納する。"
3150 #: build/C/man2/msgop.2:192
3152 "The argument I<msgsz> specifies the maximum size in bytes for the member "
3153 "I<mtext> of the structure pointed to by the I<msgp> argument. If the "
3154 "message text has length greater than I<msgsz>, then the behavior depends on "
3155 "whether B<MSG_NOERROR> is specified in I<msgflg>. If B<MSG_NOERROR> is "
3156 "specified, then the message text will be truncated (and the truncated part "
3157 "will be lost); if B<MSG_NOERROR> is not specified, then the message isn't "
3158 "removed from the queue and the system call fails returning -1 with I<errno> "
3161 "I<msgsz> 引き数には I<msgp> 引き数で指定された構造体の I<mtext> メンバーの最"
3162 "大のバイト数を指定する。 メッセージのテキストの長さが I<msgsz> より大きい場合"
3163 "の動作は、 I<msgflg> に B<MSG_NOERROR> が指定されているかどうかで決まる。 "
3164 "B<MSG_NOERROR> が指定されていれば、メッセージのテキストは切り詰められる (切り"
3165 "捨てられた部分は失われる)。 B<MSG_NOERROR> が指定されていなければ、メッセージ"
3166 "はキューから削除されず、 システムコールは -1 を返して失敗し、 I<errno> に "
3170 #: build/C/man2/msgop.2:196
3172 "The argument I<msgtyp> specifies the type of message requested as follows:"
3174 "I<msgtyp> 引き数には要求するメッセージの型を指定する。 型は以下のように指定す"
3178 #: build/C/man2/msgop.2:201
3179 msgid "If I<msgtyp> is 0, then the first message in the queue is read."
3180 msgstr "I<msgtyp> が 0 ならば、キューの最初にあるメッセージが読み込まれる。"
3183 #: build/C/man2/msgop.2:215
3185 "If I<msgtyp> is greater than 0, then the first message in the queue of type "
3186 "I<msgtyp> is read, unless B<MSG_EXCEPT> was specified in I<msgflg>, in which "
3187 "case the first message in the queue of type not equal to I<msgtyp> will be "
3190 "I<msgtyp> が 0 より大きい場合、 I<msgflg> に B<MSG_EXCEPT> が指定されていなけ"
3191 "れば、 I<msgtyp> 型のキューの最初のメッセージが読み込まれる。 B<MSG_EXCEPT> "
3192 "が指定された場合は、 I<msgtyp> 型以外のキューの最初のメッセージが読み込まれ"
3196 #: build/C/man2/msgop.2:223
3198 "If I<msgtyp> is less than 0, then the first message in the queue with the "
3199 "lowest type less than or equal to the absolute value of I<msgtyp> will be "
3202 "I<msgtyp> が 0 より小さければ、 I<msgtyp> の絶対値以下で最も小さい型を持つ"
3203 "キューの最初のメッセージが読み込まれる。"
3206 #: build/C/man2/msgop.2:228
3208 "The I<msgflg> argument is a bit mask constructed by ORing together zero or "
3209 "more of the following flags:"
3211 "I<msgflg> 引き数には、以下のフラグを任意の数だけ (0個も可)、これらの OR で指"
3215 #: build/C/man2/msgop.2:228
3217 msgid "B<IPC_NOWAIT>"
3218 msgstr "B<IPC_NOWAIT>"
3221 #: build/C/man2/msgop.2:235
3223 "Return immediately if no message of the requested type is in the queue. The "
3224 "system call fails with I<errno> set to B<ENOMSG>."
3226 "キューに要求された型のメッセージがない場合には直ちに返る。 システムコールは失"
3227 "敗し、 I<errno> には B<ENOMSG> が設定される。"
3230 #: build/C/man2/msgop.2:235
3232 msgid "B<MSG_EXCEPT>"
3233 msgstr "B<MSG_EXCEPT>"
3236 #: build/C/man2/msgop.2:243
3238 "Used with I<msgtyp> greater than 0 to read the first message in the queue "
3239 "with message type that differs from I<msgtyp>."
3241 "0 より大きな I<msgtyp> と一緒に使用して、 I<msgtyp> 以外のキューの最初のメッ"
3245 #: build/C/man2/msgop.2:243
3247 msgid "B<MSG_NOERROR>"
3248 msgstr "B<MSG_NOERROR>"
3251 #: build/C/man2/msgop.2:248
3252 msgid "To truncate the message text if longer than I<msgsz> bytes."
3253 msgstr "I<msgsz> バイトよりも長かった場合はメッセージのテキストを切り詰める。"
3256 #: build/C/man2/msgop.2:254
3258 "If no message of the requested type is available and B<IPC_NOWAIT> isn't "
3259 "specified in I<msgflg>, the calling process is blocked until one of the "
3260 "following conditions occurs:"
3262 "要求された型のメッセージが存在せず、 I<msgflg> に B<IPC_NOWAIT> が指定されて"
3263 "いなかった場合、呼び出し元プロセスは 以下のいずれかの状況になるまで停止 "
3267 #: build/C/man2/msgop.2:256
3268 msgid "A message of the desired type is placed in the queue."
3269 msgstr "要求している型のメッセージがキューへ入れられた。"
3272 #: build/C/man2/msgop.2:262
3274 "The message queue is removed from the system. In this case the system call "
3275 "fails with I<errno> set to B<EIDRM>."
3277 "メッセージ・キューがシステムから削除された。 この場合、システムコールは失敗"
3278 "し、 I<errno> に B<EIDRM> が設定される。"
3281 #: build/C/man2/msgop.2:273
3283 "The calling process catches a signal. In this case the system call fails "
3284 "with I<errno> set to B<EINTR>. (B<msgrcv>() is never automatically "
3285 "restarted after being interrupted by a signal handler, regardless of the "
3286 "setting of the B<SA_RESTART> flag when establishing a signal handler.)"
3288 "呼び出し元プロセスがシグナルを捕獲した。 この場合、システムコールは失敗し、 "
3289 "I<errno> に B<EINTR> が設定される。 (B<msgrcv>() は、たとえシグナルハンドラ"
3290 "の設定時に B<SA_RESTART> を指定していたとしても、シグナルハンドラによって割り"
3291 "込まれた後で 自動的に再スタートすることは決してない。)"
3294 #: build/C/man2/msgop.2:279
3295 msgid "I<msg_lrpid> is set to the process ID of the calling process."
3296 msgstr "I<msg_lrpid> には呼び出し元プロセスのプロセス ID が設定される。"
3299 #: build/C/man2/msgop.2:282
3300 msgid "I<msg_qnum> is decremented by 1."
3301 msgstr "I<msg_qnum> は 1 減算される。"
3304 #: build/C/man2/msgop.2:285
3305 msgid "I<msg_rtime> is set to the current time."
3306 msgstr "I<msg_rtime> には現在の時刻が設定される。"
3309 #: build/C/man2/msgop.2:298
3311 "On failure both functions return -1 with I<errno> indicating the error, "
3312 "otherwise B<msgsnd>() returns 0 and B<msgrcv>() returns the number of "
3313 "bytes actually copied into the I<mtext> array."
3315 "失敗した場合は、どちらの関数も -1 を返し、エラーを I<errno> に表示する。成功"
3316 "した場合、 B<msgsnd>() は 0 を返し、 B<msgrcv>() は I<mtext> 配列に実際にコ"
3320 #: build/C/man2/msgop.2:304
3322 "When B<msgsnd>() fails, I<errno> will be set to one among the following "
3325 "B<msgsnd>() が失敗した場合、 B<errno> に以下の値のいずれかが設定される:"
3328 #: build/C/man2/msgop.2:310
3330 "The calling process does not have write permission on the message queue, and "
3331 "does not have the B<CAP_IPC_OWNER> capability."
3333 "呼び出し元プロセスにはメッセージ・キューに対する書き込み許可がなく、 "
3334 "B<CAP_IPC_OWNER> ケーパビリティもない。"
3337 #: build/C/man2/msgop.2:318
3339 "The message can't be sent due to the I<msg_qbytes> limit for the queue and "
3340 "B<IPC_NOWAIT> was specified in I<msgflg>."
3342 "I<msg_qbytes> がキューの制限を超えていたため、メッセージを送ることができず、"
3343 "かつ I<msgflg> に B<IPC_NOWAIT> が指定されていた。"
3346 #: build/C/man2/msgop.2:323 build/C/man2/msgop.2:376
3347 msgid "The address pointed to by I<msgp> isn't accessible."
3348 msgstr "I<msgp> が指しているアドレスがアクセス可能でない。"
3351 #: build/C/man2/msgop.2:329
3353 "Sleeping on a full message queue condition, the process caught a signal."
3355 "メッセージ・キューが要求した条件を満たすまで停止している時に、 プロセスがシグ"
3359 #: build/C/man2/msgop.2:340
3361 "Invalid I<msqid> value, or nonpositive I<mtype> value, or invalid I<msgsz> "
3362 "value (less than 0 or greater than the system value B<MSGMAX>)."
3364 "I<msqid> が不適切な値であるか、 I<mtype> が正の値でないか、 I<msgsz> が不適切"
3365 "な値 (0 以下か、システムで決まる値 B<MSGMAX> よりも大きい値) である。"
3368 #: build/C/man2/msgop.2:345
3370 "The system does not have enough memory to make a copy of the message pointed "
3373 "I<msgp> が指すメッセージのコピーを作成するのに十分なメモリがシステムに存在し"
3377 #: build/C/man2/msgop.2:351
3379 "When B<msgrcv>() fails, I<errno> will be set to one among the following "
3382 "B<msgrcv>() が失敗した場合には I<errno> に以下の値のいずれかが設定される:"
3385 #: build/C/man2/msgop.2:351
3391 #: build/C/man2/msgop.2:359
3393 "The message text length is greater than I<msgsz> and B<MSG_NOERROR> isn't "
3394 "specified in I<msgflg>."
3396 "メッセージのテキストの長さが I<msgsz> よりも大きく、 I<msgflg> に "
3397 "B<MSG_NOERROR> が設定されていなかった。"
3400 #: build/C/man2/msgop.2:365
3402 "The calling process does not have read permission on the message queue, and "
3403 "does not have the B<CAP_IPC_OWNER> capability."
3405 "呼び出し元プロセスにはメッセージ・キューに対する読み込み許可がなく、 "
3406 "B<CAP_IPC_OWNER> ケーパビリティもない。"
3409 #: build/C/man2/msgop.2:371
3411 "No message was available in the queue and B<IPC_NOWAIT> was specified in "
3413 msgstr "キューにはメッセージがなく、 I<msgflg> に B<IPC_NOWAIT> が指定された。"
3416 #: build/C/man2/msgop.2:380
3418 "While the process was sleeping to receive a message, the message queue was "
3421 "メッセージを受信するためにプロセスが停止している間に、 メッセージ・キューが削"
3425 #: build/C/man2/msgop.2:385
3427 "While the process was sleeping to receive a message, the process caught a "
3428 "signal; see B<signal>(7)."
3430 "メッセージを受けるためにプロセスが停止している間に、 プロセスがシグナルを捕獲"
3431 "した。 B<signal>(7) 参照。"
3434 #: build/C/man2/msgop.2:391
3435 msgid "I<msgqid> was invalid, or I<msgsz> was less than 0."
3436 msgstr "I<msgqid> が不正か、 I<msgsz> が 0 より小さい。"
3439 #: build/C/man2/msgop.2:391
3445 #: build/C/man2/msgop.2:397
3447 "B<IPC_NOWAIT> was specified in I<msgflg> and no message of the requested "
3448 "type existed on the message queue."
3450 "I<msgflg> に B<IPC_NOWAIT> が設定されており、 メッセージ・キューに要求された"
3454 #: build/C/man2/msgop.2:406
3456 "The I<msgp> argument is declared as I<struct msgbuf *> with libc4, libc5, "
3457 "glibc 2.0, glibc 2.1. It is declared as I<void *> with glibc 2.2 and later, "
3458 "as required by SUSv2 and SUSv3."
3460 "I<msgp> 引き数は、 libc4, libc5, glibc 2.0, glibc 2.1 では I<struct msgbuf "
3461 "*> と宣言されている。glibc 2.2 以降では、 SUSv2 と SUSv3 の要求通り、I<void "
3465 #: build/C/man2/msgop.2:410
3467 "The following limits on message queue resources affect the B<msgsnd>() call:"
3468 msgstr "以下は B<msgsnd> システムコールに影響するシステム制限である:"
3471 #: build/C/man2/msgop.2:410
3477 #: build/C/man2/msgop.2:415
3479 "Maximum size for a message text: 8192 bytes (on Linux, this limit can be "
3480 "read and modified via I</proc/sys/kernel/msgmax>)."
3482 "メッセージのテキストの最大サイズ: 8192 バイト (Linux では、この制限値は I</"
3483 "proc/sys/kernel/msgmax> 経由で読み出したり変更したりできる)。"
3486 #: build/C/man2/msgop.2:415
3492 #: build/C/man2/msgop.2:425
3494 "Default maximum size in bytes of a message queue: 16384 bytes (on Linux, "
3495 "this limit can be read and modified via I</proc/sys/kernel/msgmnb>). The "
3496 "superuser can increase the size of a message queue beyond B<MSGMNB> by a "
3497 "B<msgctl>(2) system call."
3499 "バイト単位でのメッセージ・キューのデフォルトの最大サイズ : 16384 バイト。 "
3500 "(Linux では、この制限値は I</proc/sys/kernel/msgmnb> 経由で読み出したり変更し"
3501 "たりできる)。 スーパーユーザーは B<msgctl>(2) システムコールでメッセージ・"
3502 "キューのサイズを B<MSGMNB> よりも大きい値に増やすことができる。"
3505 #: build/C/man2/msgop.2:431
3507 "The implementation has no intrinsic limits for the system wide maximum "
3508 "number of message headers (B<MSGTQL>) and for the system wide maximum size "
3509 "in bytes of the message pool (B<MSGPOOL>)."
3511 "現在の実装では、システム全体のメッセージ・ヘッダーの最大数 (B<MSGTQL>) と、"
3512 "システム全体のメッセージ・プールの最大バイト数 (B<MSGPOOL>) に関して実装依存"
3516 #: build/C/man2/msgop.2:437
3518 "B<msgctl>(2), B<msgget>(2), B<capabilities>(7), B<mq_overview>(7), B<svipc>"
3521 "B<msgctl>(2), B<msgget>(2), B<capabilities>(7), B<mq_overview>(7), B<svipc>"