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: 2013-03-22 01:06+0900\n"
10 "PO-Revision-Date: 2012-05-28 07:45+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/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:37
37 #: build/C/man2/msgget.2:35 build/C/man2/msgop.2:40
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:37
48 #: build/C/man2/msgget.2:35 build/C/man2/msgop.2:40
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:38
59 #: build/C/man2/msgget.2:36 build/C/man2/msgop.2:41
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:40 build/C/man2/msgget.2:38 build/C/man2/msgop.2:43
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:40 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:48
107 #: build/C/man2/msgget.2:46 build/C/man2/msgop.2:56
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:226
135 #: build/C/man2/msgget.2:137 build/C/man2/msgop.2:287
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:251
154 #: build/C/man2/msgget.2:143 build/C/man2/msgop.2:300
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:50 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:311
179 #: build/C/man2/msgget.2:183 build/C/man2/msgop.2:399
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:52 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:314 build/C/man2/msgget.2:185
197 #: build/C/man2/msgop.2:401
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:56 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:352
217 #: build/C/man2/msgget.2:230 build/C/man2/msgop.2:446
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:59 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:359
237 #: build/C/man2/msgget.2:238 build/C/man2/msgop.2:452
243 #: build/C/man3/mq_close.3:80 build/C/man3/mq_getattr.3:162
244 #: build/C/man2/mq_getsetattr.2:66 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:366
248 #: build/C/man2/msgget.2:245 build/C/man2/msgop.2:459
251 #| "This page is part of release 3.41 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.50 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.41 の一部\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:282
396 #: build/C/man2/msgop.2:331 build/C/man2/msgop.2:387
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:26
438 #: build/C/man2/mq_getsetattr.2:29
439 msgid "mq_getsetattr - get/set message queue attributes"
440 msgstr "mq_getsetattr - メッセージキューの属性を設定/取得する"
443 #: build/C/man2/mq_getsetattr.2:33
446 "B<#include E<lt>sys/types.hE<gt>>\n"
447 "B<#include E<lt>mqueue.hE<gt>>\n"
449 "B<#include E<lt>sys/types.hE<gt>>\n"
450 "B<#include E<lt>mqueue.hE<gt>>\n"
453 #: build/C/man2/mq_getsetattr.2:36
456 "B<int mq_getsetattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
457 "B< struct mq_attr *>I<oldattr>B<);>\n"
459 "B<int mq_getsetattr(mqd_t >I<mqdes>B<, struct mq_attr *>I<newattr>B<,>\n"
460 "B< struct mq_attr *>I<oldattr>B<);>\n"
463 #: build/C/man2/mq_getsetattr.2:40
464 msgid "I<Note>: There is no glibc wrapper for this system call; see NOTES."
468 #: build/C/man2/mq_getsetattr.2:42
469 msgid "Do not use this system call."
470 msgstr "このシステムコールを使用しないこと。"
473 #: build/C/man2/mq_getsetattr.2:50
475 "This is the low-level system call used to implement B<mq_getattr>(3) and "
476 "B<mq_setattr>(3). For an explanation of how this system call operates, see "
477 "the description of B<mq_setattr>(3)."
479 "B<mq_getattr>(3) と B<mq_setattr>(3) の実装に使用される低レベルのシステム"
480 "コールである。 このシステムコールがどのように動作するかは B<mq_setattr>(3) "
484 #: build/C/man2/mq_getsetattr.2:52
485 msgid "This interface is nonstandard; avoid its use."
486 msgstr "このインタフェースは非標準である。使用を避けること。"
489 #: build/C/man2/mq_getsetattr.2:56
491 "Glibc does not provide a wrapper for this system call; call it using "
492 "B<syscall>(2). (Actually, never call it unless you are writing a C library!)"
494 "glibc はこのシステムコールに対するラッパー関数を提供していない。 B<syscall>"
495 "(2) を使って呼び出すこと。 (実のところ、C ライブラリを書いているのでない限"
496 "り、 決してこのシステムコールを呼び出さないこと!)"
499 #: build/C/man2/mq_getsetattr.2:59
500 msgid "B<mq_getattr>(3), B<mq_overview>(7)"
501 msgstr "B<mq_getattr>(3), B<mq_overview>(7)"
504 #: build/C/man3/mq_notify.3:26
510 #: build/C/man3/mq_notify.3:26
516 #: build/C/man3/mq_notify.3:29
517 msgid "mq_notify - register for notification when a message is available"
518 msgstr "mq_notify - メッセージ到着時に通知を行うよう登録する"
521 #: build/C/man3/mq_notify.3:34
523 msgid "B<int mq_notify(mqd_t >I<mqdes>B<, const struct sigevent *>I<sevp>B<);>\n"
524 msgstr "B<int mq_notify(mqd_t >I<mqdes>B<, const struct sigevent *>I<notification>B<);>\n"
527 #: build/C/man3/mq_notify.3:43
529 "B<mq_notify>() allows the calling process to register or unregister for "
530 "delivery of an asynchronous notification when a new message arrives on the "
531 "empty message queue referred to by the descriptor I<mqdes>."
533 "B<mq_notify>() を使うと、ディスクリプタ I<mqdes> で参照される空のメッセージ"
534 "キューに新しくメッセージが到着した時に 非同期の通知 (notification) の配送が行"
535 "われるように登録したり、 その解除を行ったりできる。"
538 #: build/C/man3/mq_notify.3:51
540 "The I<sevp> argument is a pointer to a I<sigevent> structure. For the "
541 "definition and general details of this structure, see B<sigevent>(7)."
543 "I<sevp> 引き数は I<sigevent> 構造体へのポインタである。 この構造体の定義と一"
544 "般的な詳細については B<sigevent>(7) を参照。"
547 #: build/C/man3/mq_notify.3:65
549 "If I<sevp> is a non-NULL pointer, then B<mq_notify>() registers the calling "
550 "process to receive message notification. The I<sigev_notify> field of the "
551 "I<sigevent> structure to which I<sevp> points specifies how notification is "
552 "to be performed. This field has one of the following values:"
554 "I<sevp> が NULL でないポインタであれば、 B<mq_notify>() はメッセージ通知を受"
555 "け取るように呼び出し元のプロセスを登録する。 I<sevp> が指す I<sigevent> 構造"
556 "体の I<sigev_notify> フィールドは、どのような通知を行うのかを指定する。 この"
557 "フィールドは以下の値のいずれかを持つ。"
560 #: build/C/man3/mq_notify.3:65
562 msgid "B<SIGEV_NONE>"
563 msgstr "B<SIGEV_NONE>"
565 #. When is SIGEV_NONE useful?
567 #: build/C/man3/mq_notify.3:70
569 "A \"null\" notification: the calling process is registered as the target for "
570 "notification, but when a message arrives, no notification is sent."
572 "「空の (null)」の通知: 呼び出し元のプロセスを通知の宛先として登録するが、 実"
573 "際にはメッセージが到着した時に通知は送られない。"
576 #: build/C/man3/mq_notify.3:70
578 msgid "B<SIGEV_SIGNAL>"
579 msgstr "B<SIGEV_SIGNAL>"
581 #. I don't know of other implementations that set
582 #. si_pid and si_uid -- MTK
584 #: build/C/man3/mq_notify.3:90
586 "Notify the process by sending the signal specified in I<sigev_signo>. See "
587 "B<sigevent>(7) for general details. The I<si_code> field of the "
588 "I<siginfo_t> structure will be set to B<SI_MESGQ>. In addition, I<si_pid> "
589 "will be set to the PID of the process that sent the message, and I<si_uid> "
590 "will be set to the real user ID of the sending process."
592 "I<sigev_signo> で指定されたシグナルを送って、プロセスに通知する。 一般的な詳"
593 "細については B<sigevent>(7) を参照。 I<siginfo_t> 構造体の I<si_code> フィー"
594 "ルドには B<SI_MESGQ> が設定される。 さらに、 I<si_pid> にはメッセージを送信し"
595 "たプロセスの PID が、 I<si_uid> には送信プロセスの実ユーザ ID が設定される。"
598 #: build/C/man3/mq_notify.3:90
600 msgid "B<SIGEV_THREAD>"
601 msgstr "B<SIGEV_THREAD>"
604 #: build/C/man3/mq_notify.3:98
606 "Upon message delivery, invoke I<sigev_notify_function> as if it were the "
607 "start function of a new thread. See B<sigevent>(7) for details."
609 "メッセージの配送時には、 I<sigev_notify_function> があたかも新しいスレッドの"
610 "開始関数であるかのように起動される。 詳細は B<sigevent>(7) を参照。"
613 #: build/C/man3/mq_notify.3:101
615 "Only one process can be registered to receive notification from a message "
618 "一つのメッセージキューから通知を受信するように登録できるプロセスは 一つだけで"
622 #: build/C/man3/mq_notify.3:108
624 "If I<sevp> is NULL, and the calling process is currently registered to "
625 "receive notifications for this message queue, then the registration is "
626 "removed; another process can then register to receive a message notification "
629 "I<sevp> が NULL で、かつ呼び出し元のプロセスがこのメッセージキューからの 通知"
630 "を受信するに現在登録している場合、登録を削除する。 これ以降、別のプロセスがこ"
631 "のメッセージキューから通知を受信するように 登録できるようになる。"
634 #: build/C/man3/mq_notify.3:115
636 "Message notification only occurs when a new message arrives and the queue "
637 "was previously empty. If the queue was not empty at the time B<mq_notify>"
638 "() was called, then a notification will only occur after the queue is "
639 "emptied and a new message arrives."
641 "メッセージ通知は、それまで空のキューに新しいメッセージが到着した 場合にのみ行"
642 "われる。 B<mq_notify>() が呼び出された時にそのキューが空でない場合、 その"
643 "キューが空になり、その後新しいメッセージが到着した時に 初めて通知が行われるこ"
647 #: build/C/man3/mq_notify.3:123
649 "If another process or thread is waiting to read a message from an empty "
650 "queue using B<mq_receive>(3), then any message notification registration is "
651 "ignored: the message is delivered to the process or thread calling "
652 "B<mq_receive>(3), and the message notification registration remains in "
655 "別のプロセスやスレッドが B<mq_receive>(3) を使って、空のキューからメッセージ"
656 "の読み出しを待っている場合、 メッセージ通知の登録は全て無視される。 メッセー"
657 "ジは B<mq_receive>(3) を呼び出しているプロセスやスレッドに配送され、 メッ"
658 "セージ通知の登録は効力を持ったままとなる。"
661 #: build/C/man3/mq_notify.3:134
663 "Notification occurs once: after a notification is delivered, the "
664 "notification registration is removed, and another process can register for "
665 "message notification. If the notified process wishes to receive the next "
666 "notification, it can use B<mq_notify>() to request a further notification. "
667 "This should be done before emptying all unread messages from the queue. "
668 "(Placing the queue in nonblocking mode is useful for emptying the queue of "
669 "messages without blocking once it is empty.)"
671 "通知は一度だけ行われる。通知が送られた後は、通知要求の登録は削除され、 別のプ"
672 "ロセスがメッセージ通知を受信するように登録できるようになる。 通知を受けたプロ"
673 "セスが次の通知も受信したい場合は、 B<mq_notify>() を使ってその後の通知も受け"
674 "るように要求することができる。 B<mq_notify>() を再度呼び出すのは、読み出して"
675 "いないメッセージを全部読み出して キューが空になる前にすべきである (キューから"
676 "のメッセージ読み出しをキューが空になった時に 停止 (block) せずに行うには、"
677 "キューを非停止モード (non-blocking mode) に設定しておくとよい)。"
680 #: build/C/man3/mq_notify.3:140
682 "On success B<mq_notify>() returns 0; on error, -1 is returned, with "
683 "I<errno> set to indicate the error."
685 "成功すると、 B<mq_notify>() は 0 を返す。エラーの場合、-1 を返し、 I<errno> "
689 #: build/C/man3/mq_notify.3:146
695 #: build/C/man3/mq_notify.3:150
697 "Another process has already registered to receive notification for this "
700 "別のプロセスがすでに このメッセージキューに対する通知を受信するように登録して"
704 #: build/C/man3/mq_notify.3:160
706 "I<sevp-E<gt>sigev_notify> is not one of the permitted values; or I<sevp-"
707 "E<gt>sigev_notify> is B<SIGEV_SIGNAL> and I<sevp-E<gt>sigev_signo> is not a "
708 "valid signal number."
710 "I<sevp-E<gt>sigev_notify> が許可された値のいずれでもない。もしくは I<sevp-"
711 "E<gt>sigev_notify> が B<SIGEV_SIGNAL> だが I<sevp-E<gt>sigev_signo> が有効な"
715 #: build/C/man3/mq_notify.3:160 build/C/man3/mq_open.3:214
716 #: build/C/man2/msgget.2:173 build/C/man2/msgop.2:342
722 #: build/C/man3/mq_notify.3:163 build/C/man3/mq_open.3:217
723 msgid "Insufficient memory."
726 #. Linux does not do this
728 #: build/C/man3/mq_notify.3:174
730 "POSIX.1-2008 says that an implementation I<may> generate an B<EINVAL> error "
731 "if I<sevp> is NULL, and the caller is not currently registered to receive "
732 "notifications for the queue I<mqdes>."
734 "POSIX.1-2008 では、 I<sevp> が NULL で、呼び出し元のプロセスがキュー "
735 "I<mqdes> に関する通知を受信するように登録されていない場合、エラー B<EINVAL> "
736 "を生成するような実装を行っても「よい」ことになっている。"
739 #: build/C/man3/mq_notify.3:176 build/C/man7/mq_overview.7:278
745 #: build/C/man3/mq_notify.3:182
747 "The following program registers a notification request for the message queue "
748 "named in its command-line argument. Notification is performed by creating a "
749 "thread. The thread executes a function which reads one message from the "
750 "queue and then terminates the process."
752 "以下のプログラムは、 コマンドライン引き数で指定された名前のメッセージキューへ"
753 "の 通知要求を登録し、通知はスレッドの作成によって行われる。 そのスレッドは、"
754 "そのキューからメッセージを一つ読み出してから、 プロセスを終了する関数を実行す"
758 #: build/C/man3/mq_notify.3:189
761 "#include E<lt>pthread.hE<gt>\n"
762 "#include E<lt>mqueue.hE<gt>\n"
763 "#include E<lt>stdio.hE<gt>\n"
764 "#include E<lt>stdlib.hE<gt>\n"
765 "#include E<lt>unistd.hE<gt>\n"
767 "#include E<lt>pthread.hE<gt>\n"
768 "#include E<lt>mqueue.hE<gt>\n"
769 "#include E<lt>stdio.hE<gt>\n"
770 "#include E<lt>stdlib.hE<gt>\n"
771 "#include E<lt>unistd.hE<gt>\n"
774 #: build/C/man3/mq_notify.3:192
777 "#define handle_error(msg) \\e\n"
778 " do { perror(msg); exit(EXIT_FAILURE); } while (0)\n"
780 "#define handle_error(msg) \\e\n"
781 " do { perror(msg); exit(EXIT_FAILURE); } while (0)\n"
784 #: build/C/man3/mq_notify.3:200
787 "static void /* Thread start function */\n"
788 "tfunc(union sigval sv)\n"
790 " struct mq_attr attr;\n"
793 " mqd_t mqdes = *((mqd_t *) sv.sival_ptr);\n"
795 "static void /* スレッド開始関数 */\n"
796 "tfunc(union sigval sv)\n"
798 " struct mq_attr attr;\n"
801 " mqd_t mqdes = *((mqd_t *) sv.sival_ptr);\n"
804 #: build/C/man3/mq_notify.3:202
806 msgid " /* Determine max. msg size; allocate buffer to receive msg */\n"
808 " /* 最大メッセージサイズを決定し、\n"
809 " メッセージ受信用のバッファを確保する */\n"
812 #: build/C/man3/mq_notify.3:208
815 " if (mq_getattr(mqdes, &attr) == -1)\n"
816 " handle_error(\"mq_getattr\");\n"
817 " buf = malloc(attr.mq_msgsize);\n"
818 " if (buf == NULL)\n"
819 " handle_error(\"malloc\");\n"
821 " if (mq_getattr(mqdes, &attr) == -1)\n"
822 " handle_error(\"mq_getattr\");\n"
823 " buf = malloc(attr.mq_msgsize);\n"
824 " if (buf == NULL)\n"
825 " handle_error(\"malloc\");\n"
828 #: build/C/man3/mq_notify.3:212
831 " nr = mq_receive(mqdes, buf, attr.mq_msgsize, NULL);\n"
833 " handle_error(\"mq_receive\");\n"
835 " nr = mq_receive(mqdes, buf, attr.mq_msgsize, NULL);\n"
837 " handle_error(\"mq_receive\");\n"
840 #: build/C/man3/mq_notify.3:217
843 " printf(\"Read %ld bytes from MQ\\en\", (long) nr);\n"
845 " exit(EXIT_SUCCESS); /* Terminate the process */\n"
848 " printf(\"Read %ld bytes from MQ\\en\", (long) nr);\n"
850 " exit(EXIT_SUCCESS); /* プロセスを終了する */\n"
854 #: build/C/man3/mq_notify.3:223
858 "main(int argc, char *argv[])\n"
861 " struct sigevent sev;\n"
864 "main(int argc, char *argv[])\n"
867 " struct sigevent sev;\n"
870 #: build/C/man3/mq_notify.3:228
873 " if (argc != 2) {\n"
874 "\tfprintf(stderr, \"Usage: %s E<lt>mq-nameE<gt>\\en\", argv[0]);\n"
875 "\texit(EXIT_FAILURE);\n"
878 " if (argc != 2) {\n"
879 "\tfprintf(stderr, \"Usage: %s E<lt>mq-nameE<gt>\\en\", argv[0]);\n"
880 "\texit(EXIT_FAILURE);\n"
884 #: build/C/man3/mq_notify.3:232
887 " mqdes = mq_open(argv[1], O_RDONLY);\n"
888 " if (mqdes == (mqd_t) -1)\n"
889 " handle_error(\"mq_open\");\n"
891 " mqdes = mq_open(argv[1], O_RDONLY);\n"
892 " if (mqdes == (mqd_t) -1)\n"
893 " handle_error(\"mq_open\");\n"
896 #: build/C/man3/mq_notify.3:239
899 " sev.sigev_notify = SIGEV_THREAD;\n"
900 " sev.sigev_notify_function = tfunc;\n"
901 " sev.sigev_notify_attributes = NULL;\n"
902 " sev.sigev_value.sival_ptr = &mqdes; /* Arg. to thread func. */\n"
903 " if (mq_notify(mqdes, &sev) == -1)\n"
904 " handle_error(\"mq_notify\");\n"
906 " sev.sigev_notify = SIGEV_THREAD;\n"
907 " sev.sigev_notify_function = tfunc;\n"
908 " sev.sigev_notify_attributes = NULL;\n"
909 " sev.sigev_value.sival_ptr = &mqdes; /* スレッド関数に渡す引き数 */\n"
910 " if (mq_notify(mqdes, &sev) == -1)\n"
911 " handle_error(\"mq_notify\");\n"
914 #: build/C/man3/mq_notify.3:242
917 " pause(); /* Process will be terminated by thread function */\n"
920 " pause(); /* プロセスはスレッド関数により終了される */\n"
924 #: build/C/man3/mq_notify.3:252
926 "B<mq_close>(3), B<mq_getattr>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
927 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<sigevent>(7)"
929 "B<mq_close>(3), B<mq_getattr>(3), B<mq_open>(3), B<mq_receive>(3), B<mq_send>"
930 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<sigevent>(7)"
933 #: build/C/man3/mq_open.3:26
939 #: build/C/man3/mq_open.3:26
945 #: build/C/man3/mq_open.3:29
946 msgid "mq_open - open a message queue"
947 msgstr "mq_open - メッセージキューをオープンする"
950 #: build/C/man3/mq_open.3:34
953 "B<#include E<lt>fcntl.hE<gt>> /* For O_* constants */\n"
954 "B<#include E<lt>sys/stat.hE<gt>> /* For mode constants */\n"
955 "B<#include E<lt>mqueue.hE<gt>>\n"
957 "B<#include E<lt>fcntl.hE<gt>> /* For O_* constants */\n"
958 "B<#include E<lt>sys/stat.hE<gt>> /* For mode constants */\n"
959 "B<#include E<lt>mqueue.hE<gt>>\n"
962 #: build/C/man3/mq_open.3:38
965 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<);>\n"
966 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<, mode_t >I<mode>B<,>\n"
967 "B< struct mq_attr *>I<attr>B<);>\n"
969 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<);>\n"
970 "B<mqd_t mq_open(const char *>I<name>B<, int >I<oflag>B<, mode_t >I<mode>B<,>\n"
971 "B< struct mq_attr *>I<attr>B<);>\n"
974 #: build/C/man3/mq_open.3:50
976 "B<mq_open>() creates a new POSIX message queue or opens an existing queue. "
977 "The queue is identified by I<name>. For details of the construction of "
978 "I<name>, see B<mq_overview>(7)."
980 "B<mq_open>() は、新しい POSIX メッセージキューを作成するか、既存のキューを "
981 "オープンする。キューは I<name> で識別される。 I<name> の構成の詳細については "
982 "B<mq_overview (7)> を参照。"
985 #: build/C/man3/mq_open.3:58
987 "The I<oflag> argument specifies flags that control the operation of the "
988 "call. (Definitions of the flags values can be obtained by including "
989 "I<E<lt>fcntl.hE<gt>>.) Exactly one of the following must be specified in "
992 "I<oflag> 引き数には、関数呼び出しの操作を制御するフラグを指定する (oflag の値"
993 "の定義は I<E<lt>fcntl.hE<gt>> のインクルードにより得られる)。 I<oflag> には、"
994 "以下のうちいずれか一つを必ず指定しなければならない。"
997 #: build/C/man3/mq_open.3:58
1000 msgstr "B<O_RDONLY>"
1003 #: build/C/man3/mq_open.3:61
1004 msgid "Open the queue to receive messages only."
1005 msgstr "メッセージの受信専用としてキューをオープンする。"
1008 #: build/C/man3/mq_open.3:61
1011 msgstr "B<O_WRONLY>"
1014 #: build/C/man3/mq_open.3:64
1015 msgid "Open the queue to send messages only."
1016 msgstr "メッセージの送信専用としてキューをオープンする。"
1019 #: build/C/man3/mq_open.3:64
1025 #: build/C/man3/mq_open.3:67
1026 msgid "Open the queue to both send and receive messages."
1027 msgstr "メッセージの送受信両用としてキューをオープンする。"
1030 #: build/C/man3/mq_open.3:72
1032 "Zero or more of the following flags can additionally be I<OR>ed in I<oflag>:"
1034 "0 個以上の下記のフラグを、ビット単位の OR (論理和) で I<oflag> に追加で指定で"
1038 #: build/C/man3/mq_open.3:72
1040 msgid "B<O_NONBLOCK>"
1041 msgstr "B<O_NONBLOCK>"
1044 #: build/C/man3/mq_open.3:81
1046 "Open the queue in nonblocking mode. In circumstances where B<mq_receive>"
1047 "(3) and B<mq_send>(3) would normally block, these functions instead fail "
1048 "with the error B<EAGAIN>."
1050 "非停止 (nonblocking) モードでキューをオープンする。 B<mq_receive>(3) と "
1051 "B<mq_send>(3) は、通常は停止 (block) する状況において、エラー B<EAGAIN> で失"
1055 #: build/C/man3/mq_open.3:81
1060 #. In reality the file system IDs are used on Linux.
1062 #: build/C/man3/mq_open.3:89
1064 "Create the message queue if it does not exist. The owner (user ID) of the "
1065 "message queue is set to the effective user ID of the calling process. The "
1066 "group ownership (group ID) is set to the effective group ID of the calling "
1069 "存在しない場合、メッセージキューを作成する。 メッセージキューの所有者 (ユー"
1070 "ザ ID) とグループ所有権 (グループ ID) は、 それぞれ呼び出し元プロセスの実効"
1071 "ユーザ ID と実効グループ ID に設定される。"
1074 #: build/C/man3/mq_open.3:89
1080 #: build/C/man3/mq_open.3:99
1082 "If B<O_CREAT> was specified in I<oflag>, and a queue with the given I<name> "
1083 "already exists, then fail with the error B<EEXIST>."
1085 "B<O_CREAT> が I<oflag> に指定され、かつ指定された名前 I<name> を持つキューが"
1086 "すでに存在する場合、エラー B<EEXIST> で失敗する。"
1089 #: build/C/man3/mq_open.3:123
1091 "If B<O_CREAT> is specified in I<oflag>, then two additional arguments must "
1092 "be supplied. The I<mode> argument specifies the permissions to be placed on "
1093 "the new queue, as for B<open>(2). (Symbolic definitions for the permissions "
1094 "bits can be obtained by including I<E<lt>sys/stat.hE<gt>>.) The permissions "
1095 "settings are masked against the process umask. The I<attr> argument "
1096 "specifies attributes for the queue. See B<mq_getattr>(3) for details. If "
1097 "I<attr> is NULL, then the queue is created with implementation-defined "
1098 "default attributes."
1100 "I<oflag> に B<O_CREAT> を指定する場合、追加で 2つの引き数を与える必要があ"
1101 "る。 I<mode> 引き数は、新しいキューに適用される許可設定 (permission) を、 "
1102 "B<open>(2) と同じように指定する (許可ビットのシンボル定義は I<E<lt>sys/stat."
1103 "hE<gt>> のインクルードにより得られる)。 許可設定はプロセスの umask でマスクさ"
1104 "れる。 I<attr> 引き数は、キューの属性を指定する。詳細は、 B<mq_getattr>(3) "
1105 "を参照。 I<attr> が NULL の場合、キューは実装で定義されたデフォルト属性で作成"
1109 #: build/C/man3/mq_open.3:135
1111 "On success, B<mq_open>() returns a message queue descriptor for use by "
1112 "other message queue functions. On error, B<mq_open>() returns I<(mqd_t)\\ "
1113 "-1>, with I<errno> set to indicate the error."
1115 "成功すると、 B<mq_open>() はメッセージキュー記述子 (message queue "
1116 "descriptor) を返す。 メッセージキュー記述子は他のメッセージキュー関連の関数で"
1117 "使用される。 エラーの場合、 B<mq_open>() は I<(mqd_t)\\ -1> を返し、 "
1118 "I<errno> にエラーを示す値を設定する。"
1121 #: build/C/man3/mq_open.3:136 build/C/man3/mq_open.3:140
1122 #: build/C/man3/mq_unlink.3:51 build/C/man2/msgctl.2:255
1123 #: build/C/man2/msgget.2:147 build/C/man2/msgop.2:306 build/C/man2/msgop.2:361
1129 #: build/C/man3/mq_open.3:140
1131 "The queue exists, but the caller does not have permission to open it in the "
1134 "キューは存在するが、呼び出し元が指定されたモードでそのキュー をオープンする許"
1137 #. Note that this isn't consistent with the same case for sem_open()
1139 #: build/C/man3/mq_open.3:145
1140 msgid "I<name> contained more than one slash."
1141 msgstr "I<name> にスラッシュが 2 個以上含まれていた。"
1144 #: build/C/man3/mq_open.3:145 build/C/man2/msgget.2:155
1150 #: build/C/man3/mq_open.3:156
1152 "Both B<O_CREAT> and B<O_EXCL> were specified in I<oflag>, but a queue with "
1153 "this I<name> already exists."
1155 "I<oflag> に B<O_CREAT> と B<O_EXCL> の両方が指定されたが、指定された名前 "
1156 "I<name> を持つキューがすでに存在する。"
1159 #: build/C/man3/mq_open.3:188
1161 "B<O_CREAT> was specified in I<oflag>, and I<attr> was not NULL, but I<attr-"
1162 "E<gt>mq_maxmsg> or I<attr-E<gt>mq_msqsize> was invalid. Both of these "
1163 "fields must be greater than zero. In a process that is unprivileged (does "
1164 "not have the B<CAP_SYS_RESOURCE> capability), I<attr-E<gt>mq_maxmsg> must be "
1165 "less than or equal to the I<msg_max> limit, and I<attr-E<gt>mq_msgsize> must "
1166 "be less than or equal to the I<msgsize_max> limit. In addition, even in a "
1167 "privileged process, I<attr-E<gt>mq_maxmsg> cannot exceed the B<HARD_MAX> "
1168 "limit. (See B<mq_overview>(7) for details of these limits.)"
1170 "I<oflag> に B<O_CREAT> が指定され、かつ I<attr> が NULL 以外だが、 I<attr-"
1171 "E<gt>mq_maxmsg> か I<attr-E<gt>mq_msqsize> が不正であった。 これらのフィール"
1172 "ドは両方とも 0 より大きくなければならない。 プロセスが特権を持たない "
1173 "(B<CAP_SYS_RESOURCE> ケーパビリティを持たない) 場合、 I<attr-E<gt>mq_maxmsg> "
1174 "と I<attr-E<gt>mq_msgsize> は、それぞれ上限 I<msg_max>、 I<msgsize_max> 以下"
1175 "でなければならない。 また、特権プロセスの場合でも、 I<attr-E<gt>mq_maxmsg> "
1176 "は B<HARD_MAX> 上限を超えることはできない。 (これらの上限に関する詳細は "
1177 "B<mq_overview>(7) を参照。)"
1180 #: build/C/man3/mq_open.3:188
1186 #: build/C/man3/mq_open.3:192
1188 "The process already has the maximum number of files and message queues open."
1190 "そのプロセスがオープンしているファイルとメッセージキューの数が プロセス毎の上"
1194 #: build/C/man3/mq_open.3:192 build/C/man3/mq_unlink.3:54
1196 msgid "B<ENAMETOOLONG>"
1197 msgstr "B<ENAMETOOLONG>"
1200 #: build/C/man3/mq_open.3:196 build/C/man3/mq_unlink.3:58
1201 msgid "I<name> was too long."
1202 msgstr "I<name> が長過ぎる。"
1205 #: build/C/man3/mq_open.3:196
1211 #: build/C/man3/mq_open.3:200
1213 "The system limit on the total number of open files and message queues has "
1216 "システム全体でオープンしているファイルとメッセージキューの合計数が システム上"
1220 #: build/C/man3/mq_open.3:200 build/C/man3/mq_open.3:209
1221 #: build/C/man3/mq_unlink.3:58 build/C/man2/msgget.2:165
1227 #: build/C/man3/mq_open.3:209
1229 "The B<O_CREAT> flag was not specified in I<oflag>, and no queue with this "
1232 "B<O_CREAT> フラグが I<oflag> に指定されなかったが、指定された名前 I<name> を"
1235 #. Note that this isn't consistent with the same case for sem_open()
1237 #: build/C/man3/mq_open.3:214
1238 msgid "I<name> was just \"/\" followed by no other characters."
1239 msgstr "I<name> が \"/\" だけで、その後ろに他の文字が続いていなかった。"
1242 #: build/C/man3/mq_open.3:217 build/C/man2/msgget.2:177
1248 #: build/C/man3/mq_open.3:224
1250 "Insufficient space for the creation of a new message queue. This probably "
1251 "occurred because the I<queues_max> limit was encountered; see B<mq_overview>"
1254 "新しいメッセージキューを作成するのに十分な空間がない。 このエラーはおそらく "
1255 "I<queues_max> 上限に抵触したため起こったのだろう。 B<mq_overview>(7) を参"
1259 #: build/C/man3/mq_open.3:226 build/C/man2/msgget.2:224
1265 #: build/C/man3/mq_open.3:230
1267 "In kernels before 2.6.14, the process umask was not applied to the "
1268 "permissions specified in I<mode>."
1270 "2.6.14 より前のカーネルには、 プロセスの umask が I<mode> で指定された許可設"
1274 #: build/C/man3/mq_open.3:238
1276 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_receive>(3), "
1277 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
1279 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_receive>(3), "
1280 "B<mq_send>(3), B<mq_unlink>(3), B<mq_overview>(7)"
1283 #: build/C/man7/mq_overview.7:26
1286 msgstr "MQ_OVERVIEW"
1289 #: build/C/man7/mq_overview.7:26
1295 #: build/C/man7/mq_overview.7:29
1297 #| msgid "mq_overview - Overview of POSIX message queues"
1298 msgid "mq_overview - overview of POSIX message queues"
1299 msgstr "mq_overview - POSIX メッセージキューの概要"
1302 #: build/C/man7/mq_overview.7:37
1304 "POSIX message queues allow processes to exchange data in the form of "
1305 "messages. This API is distinct from that provided by System V message "
1306 "queues (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2), etc.), but provides "
1307 "similar functionality."
1309 "POSIX メッセージキューを使用すると、プロセス間で メッセージの形でのデータのや"
1310 "り取りを行うことができる。 この API は System V メッセージキューの API "
1311 "(B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2) など) とは異なるものだが、同様の機"
1315 #: build/C/man7/mq_overview.7:52
1317 "Message queues are created and opened using B<mq_open>(3); this function "
1318 "returns a I<message queue descriptor> (I<mqd_t>), which is used to refer to "
1319 "the open message queue in later calls. Each message queue is identified by "
1320 "a name of the form I</somename>; that is, a null-terminated string of up to "
1321 "B<NAME_MAX> (i.e., 255) characters consisting of an initial slash, followed "
1322 "by one or more characters, none of which are slashes. Two processes can "
1323 "operate on the same queue by passing the same name to B<mq_open>(3)."
1325 "メッセージキューの作成とオープンは B<mq_open>(3) を使って行う。この関数は I<"
1326 "メッセージキュー記述子 (message queue descriptor)> (I<mqd_t>) を返す。これ以"
1327 "降のコールでは、オープンされたメッセージキューは I<メッセージキュー記述子> を"
1328 "使って参照される。 各メッセージキューは I</somename> の形の名前で区別すること"
1329 "ができる。 その名前は、最大で B<NAME_MAX> (すなわち 255) 文字の NULL 終端され"
1330 "た文字列で、 スラッシュで始まり、スラッシュ以外の文字が 1 文字以上続く形式で"
1331 "ある。 B<mq_open>(3) に同じ名前を渡すことで、2つのプロセスで同一のキューを "
1335 #: build/C/man7/mq_overview.7:68
1337 "Messages are transferred to and from a queue using B<mq_send>(3) and "
1338 "B<mq_receive>(3). When a process has finished using the queue, it closes it "
1339 "using B<mq_close>(3), and when the queue is no longer required, it can be "
1340 "deleted using B<mq_unlink>(3). Queue attributes can be retrieved and (in "
1341 "some cases) modified using B<mq_getattr>(3) and B<mq_setattr>(3). A "
1342 "process can request asynchronous notification of the arrival of a message on "
1343 "a previously empty queue using B<mq_notify>(3)."
1345 "メッセージのキューへの送受信は B<mq_send>(3) と B<mq_receive>(3) を使って行"
1346 "う。プロセスがキューの使用を終えるときには、 B<mq_close>(3) を使ってキューを"
1347 "クローズする。キューがもはや不要となった場合には、 B<mq_unlink>(3) を使って"
1348 "キューを削除できる。キューの属性は B<mq_getattr>(3) で取得でき、 (制限はある"
1349 "が) B<mq_setattr>(3) で変更できる。 B<mq_notify>(3) を使うことで、空の"
1350 "キューへのメッセージ到着を非同期で 通知するように要求することもできる。"
1353 #: build/C/man7/mq_overview.7:81
1355 "A message queue descriptor is a reference to an I<open message queue "
1356 "description> (cf. B<open>(2)). After a B<fork>(2), a child inherits copies "
1357 "of its parent's message queue descriptors, and these descriptors refer to "
1358 "the same open message queue descriptions as the corresponding descriptors in "
1359 "the parent. Corresponding descriptors in the two processes share the flags "
1360 "(I<mq_flags>) that are associated with the open message queue description."
1362 "メッセージキュー記述子は I<オープンメッセージキュー記述 (open message queue "
1363 "description)> への参照である (B<open>(2) も参照)。 B<fork>(2) 実行後は、子"
1364 "プロセスは親プロセスのメッセージキュー記述子のコピーを継承する。 これらの記述"
1365 "子は、親プロセスの対応する記述子と同じオープンメッセージキュー 記述を参照して"
1366 "いる。親プロセスと子プロセスの対応する記述子は、フラグ (I<mq_flags>) を共有"
1367 "する。なぜなら、フラグはオープンメッセージキュー記述に 関連付けられているから"
1371 #: build/C/man7/mq_overview.7:94
1373 "Each message has an associated I<priority>, and messages are always "
1374 "delivered to the receiving process highest priority first. Message "
1375 "priorities range from 0 (low) to I<sysconf(_SC_MQ_PRIO_MAX)\\ -\\ 1> "
1376 "(high). On Linux, I<sysconf(_SC_MQ_PRIO_MAX)> returns 32768, but "
1377 "POSIX.1-2001 only requires an implementation to support priorities in the "
1378 "range 0 to 31; some implementations only provide this range."
1380 "各メッセージにはそれぞれ I<優先度 (priority)> があり、メッセージの受信プロセ"
1381 "スへの配送は常に 優先度の高いメッセージから順に行われる。 メッセージの優先度"
1382 "は 0 (低優先) から I<sysconf(_SC_MQ_PRIO_MAX)\\ -\\ 1> (高優先) の値を持つ。 "
1383 "Linux では、 I<sysconf(_SC_MQ_PRIO_MAX)> は 32768 を返すが、 POSIX.1-2001 で"
1384 "要求されているのは 0 から 31 までの優先度を 実装することだけであり、実装に"
1385 "よってはこの範囲の優先度しか 対応していない。"
1388 #: build/C/man7/mq_overview.7:97
1390 "The remainder of this section describes some specific details of the Linux "
1391 "implementation of POSIX message queues."
1393 "この節の残りでは、POSIX メッセージキューの Linux の実装の詳細 について説明す"
1397 #: build/C/man7/mq_overview.7:97
1399 msgid "Library interfaces and system calls"
1400 msgstr "ライブラリインタフェースとシステムコール"
1403 #: build/C/man7/mq_overview.7:103
1405 "In most cases the B<mq_*()> library interfaces listed above are implemented "
1406 "on top of underlying system calls of the same name. Deviations from this "
1407 "scheme are indicated in the following table:"
1409 "ほとんどの場合、上記の B<mq_*()> ライブラリインタフェースは、同じ名前の下位層"
1410 "のシステムコールを 使って実装されている。この枠組みにあてはまらないものを 以"
1414 #: build/C/man7/mq_overview.7:107
1416 msgid "Library interface\tSystem call\n"
1417 msgstr "Library interface\tSystem call\n"
1420 #: build/C/man7/mq_overview.7:108
1422 msgid "mq_close(3)\tclose(2)\n"
1423 msgstr "mq_close(3)\tclose(2)\n"
1426 #: build/C/man7/mq_overview.7:109
1428 msgid "mq_getattr(3)\tmq_getsetattr(2)\n"
1429 msgstr "mq_getattr(3)\tmq_getsetattr(2)\n"
1432 #: build/C/man7/mq_overview.7:110
1434 msgid "mq_notify(3)\tmq_notify(2)\n"
1435 msgstr "mq_notify(3)\tmq_notify(2)\n"
1438 #: build/C/man7/mq_overview.7:111
1440 msgid "mq_open(3)\tmq_open(2)\n"
1441 msgstr "mq_open(3)\tmq_open(2)\n"
1444 #: build/C/man7/mq_overview.7:112
1446 msgid "mq_receive(3)\tmq_timedreceive(2)\n"
1447 msgstr "mq_receive(3)\tmq_timedreceive(2)\n"
1450 #: build/C/man7/mq_overview.7:113
1452 msgid "mq_send(3)\tmq_timedsend(2)\n"
1453 msgstr "mq_send(3)\tmq_timedsend(2)\n"
1456 #: build/C/man7/mq_overview.7:114
1458 msgid "mq_setattr(3)\tmq_getsetattr(2)\n"
1459 msgstr "mq_setattr(3)\tmq_getsetattr(2)\n"
1462 #: build/C/man7/mq_overview.7:115
1464 msgid "mq_timedreceive(3)\tmq_timedreceive(2)\n"
1465 msgstr "mq_timedreceive(3)\tmq_timedreceive(2)\n"
1468 #: build/C/man7/mq_overview.7:116
1470 msgid "mq_timedsend(3)\tmq_timedsend(2)\n"
1471 msgstr "mq_timedsend(3)\tmq_timedsend(2)\n"
1474 #: build/C/man7/mq_overview.7:117
1476 msgid "mq_unlink(3)\tmq_unlink(2)\n"
1477 msgstr "mq_unlink(3)\tmq_unlink(2)\n"
1480 #: build/C/man7/mq_overview.7:120
1486 #: build/C/man7/mq_overview.7:123
1488 "POSIX message queues have been supported on Linux since kernel 2.6.6. Glibc "
1489 "support has been provided since version 2.3.4."
1491 "Linux では POSIX メッセージキューはカーネル 2.6.6 以降でサポートされている。 "
1492 "glibc ではバージョン 2.3.4 以降でサポートされている。"
1495 #: build/C/man7/mq_overview.7:123
1497 msgid "Kernel configuration"
1501 #: build/C/man7/mq_overview.7:128
1503 "Support for POSIX message queues is configurable via the "
1504 "B<CONFIG_POSIX_MQUEUE> kernel configuration option. This option is enabled "
1507 "POSIX メッセージキューのサポートは、カーネルの設定 (configuration) オプショ"
1508 "ン B<CONFIG_POSIX_MQUEUE> で設定可能である。このオプションはデフォルトでは有"
1512 #: build/C/man7/mq_overview.7:128
1518 #: build/C/man7/mq_overview.7:133
1520 "POSIX message queues have kernel persistence: if not removed by B<mq_unlink>"
1521 "(3), a message queue will exist until the system is shut down."
1523 "POSIX メッセージキューはカーネル内で保持される。 B<mq_unlink>(3) で削除され"
1524 "なければ、メッセージキューは システムがシャットダウンされるまで存在し続ける。"
1527 #: build/C/man7/mq_overview.7:133
1533 #: build/C/man7/mq_overview.7:138
1535 "Programs using the POSIX message queue API must be compiled with I<cc -lrt> "
1536 "to link against the real-time library, I<librt>."
1538 "POSIX メッセージキュー API を使用したプログラムは I<cc -lrt> でコンパイルし、"
1539 "リアルタイムライブラリ I<librt> とリンクしなければならない。"
1542 #: build/C/man7/mq_overview.7:138
1544 msgid "/proc interfaces"
1545 msgstr "/proc インタフェース"
1548 #: build/C/man7/mq_overview.7:141
1550 "The following interfaces can be used to limit the amount of kernel memory "
1551 "consumed by POSIX message queues:"
1553 "以下のインタフェースを使って、POSIX メッセージキューが消費するカーネル メモリ"
1557 #: build/C/man7/mq_overview.7:141
1559 msgid "I</proc/sys/fs/mqueue/msg_max>"
1560 msgstr "I</proc/sys/fs/mqueue/msg_max>"
1563 #: build/C/man7/mq_overview.7:162
1565 "This file can be used to view and change the ceiling value for the maximum "
1566 "number of messages in a queue. This value acts as a ceiling on the I<attr-"
1567 "E<gt>mq_maxmsg> argument given to B<mq_open>(3). The default value for "
1568 "I<msg_max> is 10. The minimum value is 1 (10 in kernels before 2.6.28). "
1569 "The upper limit is B<HARD_MAX>: I<(131072\\ /\\ sizeof(void\\ *))> (32768 on "
1570 "Linux/86). This limit is ignored for privileged processes "
1571 "(B<CAP_SYS_RESOURCE>), but the B<HARD_MAX> ceiling is nevertheless imposed."
1573 "このファイルを使って、一つのキューに入れられるメッセージの最大数の 上限値を参"
1574 "照したり変更したりできる。この値は、 B<mq_open>(3) に渡す I<attr-"
1575 "E<gt>mq_maxmsg> 引き数に対する上限値として機能する。 I<msg_max> のデフォルト"
1576 "値は 10 で、 最小値は 1 (2.6.28 より前のカーネルでは 10) である。 上限は「埋"
1577 "め込みの固定値」 (B<HARD_MAX>) で I<(131072\\ /\\ sizeof(void\\ *))> "
1578 "(Linux/86 では 32768) である。 この上限は特権プロセス (B<CAP_SYS_RESOURCE>) "
1579 "では無視されるが、埋め込みの固定値による上限は どんな場合にでも適用される。"
1582 #: build/C/man7/mq_overview.7:162
1584 msgid "I</proc/sys/fs/mqueue/msgsize_max>"
1585 msgstr "I</proc/sys/fs/mqueue/msgsize_max>"
1588 #: build/C/man7/mq_overview.7:181
1590 "This file can be used to view and change the ceiling on the maximum message "
1591 "size. This value acts as a ceiling on the I<attr-E<gt>mq_msgsize> argument "
1592 "given to B<mq_open>(3). The default value for I<msgsize_max> is 8192 "
1593 "bytes. The minimum value is 128 (8192 in kernels before 2.6.28). The upper "
1594 "limit for I<msgsize_max> is 1,048,576 (in kernels before 2.6.28, the upper "
1595 "limit was B<INT_MAX>; that is, 2,147,483,647 on Linux/86). This limit is "
1596 "ignored for privileged processes (B<CAP_SYS_RESOURCE>)."
1598 "このファイルを使って、メッセージの最大サイズの上限値を\t 参照したり変更したり"
1599 "できる。\t この値は、\t B<mq_open>(3)\t に渡す\t I<attr-E<gt>mq_msgsize> 引き"
1600 "数に対する上限値として機能する。\t I<msgsize_max\t> のデフォルト値は 8192 バ"
1601 "イトで、 最小値は 128 (2.6.28 より前のカーネルでは 8192) である。 "
1602 "I<msgsize_max> の上限は 1,048,576 である (2.6.28 より前のカーネルでは、上限"
1603 "は B<INT_MAX> (Linux/86 では 2,147,483,647) であった)。 この上限は特権プロセ"
1604 "ス\t (B<CAP_SYS_RESOURCE>)\t では無視される。"
1607 #: build/C/man7/mq_overview.7:181
1609 msgid "I</proc/sys/fs/mqueue/queues_max>"
1610 msgstr "I</proc/sys/fs/mqueue/queues_max>"
1613 #: build/C/man7/mq_overview.7:191
1615 "This file can be used to view and change the system-wide limit on the number "
1616 "of message queues that can be created. Only privileged processes "
1617 "(B<CAP_SYS_RESOURCE>) can create new message queues once this limit has "
1618 "been reached. The default value for I<queues_max> is 256; it can be changed "
1619 "to any value in the range 0 to INT_MAX."
1621 "このファイルを使って、作成することができるメッセージキューの数に\t 対するシス"
1622 "テム全体での制限を参照したり変更したりできる。\t 一度この上限に達すると、新し"
1623 "いメッセージキューを作成できるのは\t 特権プロセス\t (B<CAP_SYS_RESOURCE>)\t "
1624 "だけとなる。\t I<queues_max\t> のデフォルト値は 256 であり、\t 0 から "
1625 "INT_MAX の範囲の任意の値に変更することができる。"
1628 #: build/C/man7/mq_overview.7:191
1630 msgid "Resource limit"
1634 #: build/C/man7/mq_overview.7:198
1636 "The B<RLIMIT_MSGQUEUE> resource limit, which places a limit on the amount of "
1637 "space that can be consumed by all of the message queues belonging to a "
1638 "process's real user ID, is described in B<getrlimit>(2)."
1640 "リソース上限 B<RLIMIT_MSGQUEUE> は、プロセスの実 UID に対応する全メッセージ"
1641 "キューが消費する メモリ空間の量に対して上限を設定する。 B<getrlimit>(2) を参"
1645 #: build/C/man7/mq_overview.7:198
1647 msgid "Mounting the message queue file system"
1648 msgstr "メッセージキュー・ファイルシステムのマウント"
1651 #: build/C/man7/mq_overview.7:204
1653 "On Linux, message queues are created in a virtual file system. (Other "
1654 "implementations may also provide such a feature, but the details are likely "
1655 "to differ.) This file system can be mounted (by the superuser) using the "
1656 "following commands:"
1658 "Linux では、メッセージキューは仮想ファイルシステム内に作成される (他の実装で"
1659 "も同様の機能が提供されているものもあるが、 詳細は違っているだろう)。 以下のコ"
1660 "マンドを使うことで (スーパーユーザは) このファイルシステムをマウントできる:"
1663 #: build/C/man7/mq_overview.7:209
1666 "#B< mkdir /dev/mqueue>\n"
1667 "#B< mount -t mqueue none /dev/mqueue>\n"
1669 "#B< mkdir /dev/mqueue>\n"
1670 "#B< mount -t mqueue none /dev/mqueue>\n"
1673 #: build/C/man7/mq_overview.7:213
1674 msgid "The sticky bit is automatically enabled on the mount directory."
1676 "マウントしたディレクトリのスティッキービット (sticky bit) は 自動的にオンとな"
1680 #: build/C/man7/mq_overview.7:220
1682 "After the file system has been mounted, the message queues on the system can "
1683 "be viewed and manipulated using the commands usually used for files (e.g., "
1684 "B<ls>(1) and B<rm>(1))."
1686 "メッセージキュー・ファイルシステムのマウント後は、ファイルに対して 通常使うコ"
1687 "マンド (例えば B<ls>(1) や B<rm>(1)) を使って、システム上のメッセージキュー"
1691 #: build/C/man7/mq_overview.7:223
1693 "The contents of each file in the directory consist of a single line "
1694 "containing information about the queue:"
1696 "ディレクトリ内の各ファイルの内容は 1行であり、 キューに関する情報が表示され"
1700 #: build/C/man7/mq_overview.7:228
1703 "$B< cat /dev/mqueue/mymq>\n"
1704 "QSIZE:129 NOTIFY:2 SIGNO:0 NOTIFY_PID:8260\n"
1706 "$B< cat /dev/mqueue/mymq>\n"
1707 "QSIZE:129 NOTIFY:2 SIGNO:0 NOTIFY_PID:8260\n"
1710 #: build/C/man7/mq_overview.7:232
1711 msgid "These fields are as follows:"
1712 msgstr "各フィールドの詳細は以下の通りである:"
1715 #: build/C/man7/mq_overview.7:232
1721 #: build/C/man7/mq_overview.7:235
1722 msgid "Number of bytes of data in all messages in the queue."
1723 msgstr "キューに入っている全メッセージの合計バイト数。"
1726 #: build/C/man7/mq_overview.7:235
1728 msgid "B<NOTIFY_PID>"
1729 msgstr "B<NOTIFY_PID>"
1732 #: build/C/man7/mq_overview.7:241
1734 "If this is nonzero, then the process with this PID has used B<mq_notify>(3) "
1735 "to register for asynchronous message notification, and the remaining fields "
1736 "describe how notification occurs."
1738 "この値が 0 以外の場合、この値の PID を持つプロセスが B<mq_notify>(3) を使っ"
1739 "て、非同期のメッセージ通知を行うように設定したことを示す。 どのように通知が行"
1740 "われるかは、以下のフィールドにより決定される。"
1743 #: build/C/man7/mq_overview.7:241
1749 #: build/C/man7/mq_overview.7:251
1751 "Notification method: 0 is B<SIGEV_SIGNAL>; 1 is B<SIGEV_NONE>; and 2 is "
1754 "通知方法: 0 は B<SIGEV_SIGNAL>; 1 は B<SIGEV_NONE>; 2 は B<SIGEV_THREAD>"
1757 #: build/C/man7/mq_overview.7:251
1763 #: build/C/man7/mq_overview.7:255
1764 msgid "Signal number to be used for B<SIGEV_SIGNAL>."
1765 msgstr "B<SIGEV_SIGNAL> に使用されるシグナル番号。"
1768 #: build/C/man7/mq_overview.7:255
1770 msgid "Polling message queue descriptors"
1771 msgstr "メッセージキュー記述子のポーリング"
1774 #: build/C/man7/mq_overview.7:263
1776 "On Linux, a message queue descriptor is actually a file descriptor, and can "
1777 "be monitored using B<select>(2), B<poll>(2), or B<epoll>(7). This is not "
1780 "Linux では、メッセージキュー記述子は実際はファイル記述子 (file descriptor) "
1781 "であり、 B<select>(2), B<poll>(2), B<epoll>(7) を使って監視することができ"
1785 #: build/C/man7/mq_overview.7:275
1787 "System V message queues (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2), etc.) are "
1788 "an older API for exchanging messages between processes. POSIX message "
1789 "queues provide a better designed interface than System V message queues; on "
1790 "the other hand POSIX message queues are less widely available (especially on "
1791 "older systems) than System V message queues."
1793 "System V メッセージキュー (B<msgget>(2), B<msgsnd>(2), B<msgrcv>(2) など) は"
1794 "プロセス間でメッセージをやり取りするための古い API である。 POSIX メッセージ"
1795 "キューは System V メッセージキューよりもうまく 設計されたインタフェースを提供"
1796 "している。 一方で、POSIX メッセージキューは System V メッセージキューと比べる"
1797 "と 利用できるシステムが少ない (特に、古いシステムでは少ない)。"
1800 #: build/C/man7/mq_overview.7:278
1802 "Linux does not currently (2.6.26) support the use of access control lists "
1803 "(ACLs) for POSIX message queues."
1805 "現在のことろ (バージョン 2.6.26 時点)、 Linux は POSIX メッセージキューに対す"
1806 "るアクセス制御リスト (ACL) に 対応していない。"
1809 #: build/C/man7/mq_overview.7:281
1811 "An example of the use of various message queue functions is shown in "
1814 "各種のメッセージキュー関数を使用した例が B<mq_notify>(3) に記載されている。"
1817 #: build/C/man7/mq_overview.7:294
1819 "B<getrlimit>(2), B<mq_getsetattr>(2), B<poll>(2), B<select>(2), B<mq_close>"
1820 "(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
1821 "B<mq_send>(3), B<mq_unlink>(3), B<epoll>(7)"
1823 "B<getrlimit>(2), B<mq_getsetattr>(2), B<poll>(2), B<select>(2), B<mq_close>"
1824 "(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_receive>(3), "
1825 "B<mq_send>(3), B<mq_unlink>(3), B<epoll>(7)"
1828 #: build/C/man3/mq_receive.3:26
1834 #: build/C/man3/mq_receive.3:26 build/C/man3/mq_send.3:26
1840 #: build/C/man3/mq_receive.3:29
1841 msgid "mq_receive, mq_timedreceive - receive a message from a message queue"
1842 msgstr "mq_receive, mq_timedreceive - メッセージキューからメッセージを受信する"
1845 #: build/C/man3/mq_receive.3:35
1848 "B<ssize_t mq_receive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1849 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<);>\n"
1851 "B<ssize_t mq_receive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1852 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<);>\n"
1855 #: build/C/man3/mq_receive.3:38 build/C/man3/mq_send.3:38
1858 "B<#include E<lt>time.hE<gt>>\n"
1859 "B<#include E<lt>mqueue.hE<gt>>\n"
1861 "B<#include E<lt>time.hE<gt>>\n"
1862 "B<#include E<lt>mqueue.hE<gt>>\n"
1865 #: build/C/man3/mq_receive.3:42
1868 "B<ssize_t mq_timedreceive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1869 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<,>\n"
1870 "B< const struct timespec *>I<abs_timeout>B<);>\n"
1872 "B<ssize_t mq_timedreceive(mqd_t >I<mqdes>B<, char *>I<msg_ptr>B<,>\n"
1873 "B< size_t >I<msg_len>B<, unsigned *>I<msg_prio>B<,>\n"
1874 "B< const struct timespec *>I<abs_timeout>B<);>\n"
1877 #: build/C/man3/mq_receive.3:50 build/C/man3/mq_send.3:50
1879 "Feature Test Macro Requirements for glibc (see B<feature_test_macros>(7)):"
1880 msgstr "glibc 向けの機能検査マクロの要件 (B<feature_test_macros>(7) 参照):"
1883 #: build/C/man3/mq_receive.3:53
1884 msgid "B<mq_timedreceive>():"
1885 msgstr "B<mq_timedreceive>():"
1888 #: build/C/man3/mq_receive.3:55 build/C/man3/mq_send.3:55
1889 msgid "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L"
1890 msgstr "_XOPEN_SOURCE\\ E<gt>=\\ 600 || _POSIX_C_SOURCE\\ E<gt>=\\ 200112L"
1893 #: build/C/man3/mq_receive.3:76
1896 #| "B<mq_receive>() removes the oldest message with the highest priority "
1897 #| "from the message queue referred to by the descriptor I<mqdes>, and places "
1898 #| "it in the buffer pointed to by I<msg_ptr>. The I<msg_len> argument "
1899 #| "specifies the size of the buffer pointed to by I<msg_ptr>; this must be "
1900 #| "greater than the I<mq_msgsize> attribute of the queue (see B<mq_getattr>"
1901 #| "(3)). If I<prio> is not NULL, then the buffer to which it points is used "
1902 #| "to return the priority associated with the received message."
1904 "B<mq_receive>() removes the oldest message with the highest priority from "
1905 "the message queue referred to by the descriptor I<mqdes>, and places it in "
1906 "the buffer pointed to by I<msg_ptr>. The I<msg_len> argument specifies the "
1907 "size of the buffer pointed to by I<msg_ptr>; this must be greater than the "
1908 "I<mq_msgsize> attribute of the queue (see B<mq_getattr>(3)). If I<msg_prio> "
1909 "is not NULL, then the buffer to which it points is used to return the "
1910 "priority associated with the received message."
1912 "B<mq_receive>() は、記述子 I<mqdes> で参照されるメッセージキューから最も高い"
1913 "優先度を持つ 最も古いメッセージを削除し、そのメッセージを I<msg_ptr> が指す"
1914 "バッファに格納する。 I<msg_len> 引き数は、 I<msg_ptr> が指すバッファの大きさ"
1915 "を示す。この値はキューの I<mq_msgsize> 属性よりも大きくなければならない "
1916 "(B<mq_getattr>(3) 参照)。 I<prio> が NULL 以外の場合、 I<prio> が指すバッ"
1917 "ファに受信したメッセージの優先度が格納される。"
1920 #: build/C/man3/mq_receive.3:86
1922 "If the queue is empty, then, by default, B<mq_receive>() blocks until a "
1923 "message becomes available, or the call is interrupted by a signal handler. "
1924 "If the B<O_NONBLOCK> flag is enabled for the message queue description, then "
1925 "the call instead fails immediately with the error B<EAGAIN>."
1927 "キューが空の場合、デフォルトでは、 B<mq_receive>() は、新しいメッセージが届"
1928 "くか、関数呼び出しがシグナルハンドラにより 中断されるまで、停止 (block) す"
1929 "る。 メッセージキュー記述 (message queue description) で B<O_NONBLOCK> フラグ"
1930 "が有効になっている場合は、 B<mq_receive>() はエラー B<EAGAIN> ですぐに失敗す"
1934 #: build/C/man3/mq_receive.3:99
1936 "B<mq_timedreceive>() behaves just like B<mq_receive>(), except that if the "
1937 "queue is empty and the B<O_NONBLOCK> flag is not enabled for the message "
1938 "queue description, then I<abs_timeout> points to a structure which specifies "
1939 "a ceiling on the time for which the call will block. This ceiling is an "
1940 "absolute timeout in seconds and nanoseconds since the Epoch, 1970-01-01 "
1941 "00:00:00 +0000 (UTC), and it is specified in the following structure:"
1943 "B<mq_timedreceive>() は B<mq_receive>() と全く同じ動作をするが、 メッセージ"
1944 "キューが空で、メッセージキュー記述で B<O_NONBLOCK> フラグが有効になっていない"
1945 "場合に、この呼び出しが停止する時間の上限を I<abs_timeout> が指す構造体で指定"
1946 "する点が異なる。この上限は、タイムアウトの時刻を、 時刻紀元 (Epoch; "
1947 "1970-01-01 00:00:00 +0000 (UTC)) からの経過時間 (秒とナノ秒の組) で指定する。"
1948 "タイムアウト時刻は以下の構造体で指定する:"
1951 #: build/C/man3/mq_receive.3:106 build/C/man3/mq_send.3:112
1954 "struct timespec {\n"
1955 " time_t tv_sec; /* seconds */\n"
1956 " long tv_nsec; /* nanoseconds */\n"
1959 "struct timespec {\n"
1960 " time_t tv_sec; /* 秒 */\n"
1961 " long tv_nsec; /* ナノ秒 */\n"
1965 #: build/C/man3/mq_receive.3:113
1967 "If no message is available, and the timeout has already expired by the time "
1968 "of the call, B<mq_timedreceive>() returns immediately."
1970 "メッセージがキューになく、関数呼び出し時にすでにタイムアウト時刻が 過ぎている"
1971 "場合、 B<mq_timedreceive>() はすぐに返る。"
1974 #: build/C/man3/mq_receive.3:122
1976 "On success, B<mq_receive>() and B<mq_timedreceive>() return the number of "
1977 "bytes in the received message; on error, -1 is returned, with I<errno> set "
1978 "to indicate the error."
1980 "成功すると、 B<mq_receive>() と B<mq_timedreceive>() は受信したメッセージの"
1981 "バイト数を返す。 エラーの場合、-1 を返し、 I<errno> にエラーを示す値を設定す"
1985 #: build/C/man3/mq_receive.3:123 build/C/man3/mq_send.3:128
1986 #: build/C/man2/msgop.2:312 build/C/man2/msgop.2:367
1992 #: build/C/man3/mq_receive.3:129
1994 "The queue was empty, and the B<O_NONBLOCK> flag was set for the message "
1995 "queue description referred to by I<mqdes>."
1997 "キューが空で、かつ I<mqdes> で参照されるメッセージキュー記述で B<O_NONBLOCK> "
2001 #: build/C/man3/mq_receive.3:134 build/C/man3/mq_send.3:139
2002 msgid "The descriptor specified in I<mqdes> was invalid."
2003 msgstr "I<mqdes> で指定された記述子が不正である。"
2006 #: build/C/man3/mq_receive.3:134 build/C/man3/mq_send.3:139
2007 #: build/C/man2/msgop.2:328 build/C/man2/msgop.2:382
2013 #: build/C/man3/mq_receive.3:138 build/C/man3/mq_send.3:143
2014 msgid "The call was interrupted by a signal handler; see B<signal>(7)."
2015 msgstr "関数呼び出しがシグナルハンドラにより中断された。 B<signal>(7) 参照。"
2018 #: build/C/man3/mq_receive.3:147 build/C/man3/mq_send.3:152
2020 "The call would have blocked, and I<abs_timeout> was invalid, either because "
2021 "I<tv_sec> was less than zero, or because I<tv_nsec> was less than zero or "
2022 "greater than 1000 million."
2024 "関数呼び出しは停止するはずであったが、 I<abs_timeout> が不正であった。 "
2025 "I<abs_timeout> が不正とは、 I<tv_sec> が 0 未満、もしくは I<tv_nsec> が 0 未"
2026 "満か 1,000,000,000 より大きい、ということである。"
2029 #: build/C/man3/mq_receive.3:147 build/C/man3/mq_send.3:152
2032 msgstr "B<EMSGSIZE>"
2035 #: build/C/man3/mq_receive.3:153
2037 "I<msg_len> was less than the I<mq_msgsize> attribute of the message queue."
2038 msgstr "I<msg_len> がメッセージキューの I<mq_msgsize> 属性よりも小さかった。"
2041 #: build/C/man3/mq_receive.3:153 build/C/man3/mq_send.3:158
2043 msgid "B<ETIMEDOUT>"
2044 msgstr "B<ETIMEDOUT>"
2047 #: build/C/man3/mq_receive.3:156 build/C/man3/mq_send.3:161
2048 msgid "The call timed out before a message could be transferred."
2049 msgstr "メッセージが転送される前に関数呼び出しがタイムアウトした。"
2052 #: build/C/man3/mq_receive.3:164
2054 "On Linux, B<mq_timedreceive>() is a system call, and B<mq_receive>() is a "
2055 "library function layered on top of that system call."
2057 "Linux では、 B<mq_timedreceive>() はシステムコールである。 B<mq_receive>() "
2058 "はライブラリ関数で、 B<mq_timedreceive>() システムコールを用いて実装されてい"
2062 #: build/C/man3/mq_receive.3:173
2064 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_send>"
2065 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2067 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), B<mq_send>"
2068 "(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2071 #: build/C/man3/mq_send.3:26
2077 #: build/C/man3/mq_send.3:29
2078 msgid "mq_send, mq_timedsend - send a message to a message queue"
2079 msgstr "mq_send, mq_timedsend - メッセージキューにメッセージを送信する"
2082 #: build/C/man3/mq_send.3:35
2085 "B<int mq_send(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2086 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<);>\n"
2088 "B<int mq_send(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2089 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<);>\n"
2092 #: build/C/man3/mq_send.3:42
2095 "B<int mq_timedsend(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2096 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<,>\n"
2097 "B< const struct timespec *>I<abs_timeout>B<);>\n"
2099 "B<int mq_timedsend(mqd_t >I<mqdes>B<, const char *>I<msg_ptr>B<,>\n"
2100 "B< size_t >I<msg_len>B<, unsigned >I<msg_prio>B<,>\n"
2101 "B< const struct timespec *>I<abs_timeout>B<);>\n"
2104 #: build/C/man3/mq_send.3:53
2105 msgid "B<mq_timedsend>():"
2106 msgstr "B<mq_timedsend>():"
2109 #: build/C/man3/mq_send.3:71
2111 "B<mq_send>() adds the message pointed to by I<msg_ptr> to the message queue "
2112 "referred to by the descriptor I<mqdes>. The I<msg_len> argument specifies "
2113 "the length of the message pointed to by I<msg_ptr>; this length must be less "
2114 "than or equal to the queue's I<mq_msgsize> attribute. Zero-length messages "
2117 "B<mq_send>() は、記述子 I<mqdes> で参照されるメッセージキューに I<msg_ptr> "
2118 "が指すメッセージを追加する。 I<msg_len> 引き数は、 I<msg_ptr> が指すメッセー"
2119 "ジの長さを示す。この長さはキューの I<mq_msgsize> 属性以下でなければならな"
2120 "い。 長さが 0 のメッセージも認められている。"
2123 #: build/C/man3/mq_send.3:79
2125 "The I<msg_prio> argument is a nonnegative integer that specifies the "
2126 "priority of this message. Messages are placed on the queue in decreasing "
2127 "order of priority, with newer messages of the same priority being placed "
2128 "after older messages with the same priority."
2130 "I<msg_prio> 引き数は、メッセージの優先度を指定する負でない整数である。 メッ"
2131 "セージは優先度の降順でキューに格納され、同じ優先度の新しいメッセージは 同じ優"
2132 "先度の古いメッセージの後ろに格納される。"
2135 #: build/C/man3/mq_send.3:92
2137 "If the message queue is already full (i.e., the number of messages on the "
2138 "queue equals the queue's I<mq_maxmsg> attribute), then, by default, "
2139 "B<mq_send>() blocks until sufficient space becomes available to allow the "
2140 "message to be queued, or until the call is interrupted by a signal handler. "
2141 "If the B<O_NONBLOCK> flag is enabled for the message queue description, then "
2142 "the call instead fails immediately with the error B<EAGAIN>."
2144 "メッセージキューがすでに一杯の場合 (すなわち、キューに入っているメッセージ数"
2145 "がキューの I<mq_maxmsg> 属性と等しい場合)、デフォルトでは、 B<mq_send ()> "
2146 "は、メッセージをキューイングするのに十分な空間ができるか、 関数呼び出しがシグ"
2147 "ナルハンドラにより中断されるまで、停止 (block) する。 メッセージキュー記述 "
2148 "(message queue description) で B<O_NONBLOCK> フラグが有効になっている場合"
2149 "は、 B<mq_send>() はエラー B<EAGAIN> ですぐに失敗する。"
2152 #: build/C/man3/mq_send.3:105
2154 "B<mq_timedsend>() behaves just like B<mq_send>(), except that if the queue "
2155 "is full and the B<O_NONBLOCK> flag is not enabled for the message queue "
2156 "description, then I<abs_timeout> points to a structure which specifies a "
2157 "ceiling on the time for which the call will block. This ceiling is an "
2158 "absolute timeout in seconds and nanoseconds since the Epoch, 1970-01-01 "
2159 "00:00:00 +0000 (UTC), and it is specified in the following structure:"
2161 "B<mq_timedsend>() は B<mq_send>() と全く同じ動作をするが、 メッセージキュー"
2162 "が一杯で、メッセージキュー記述で B<O_NONBLOCK> フラグが有効になっていない場合"
2163 "に、この呼び出しが停止する時間の上限を I<abs_timeout> が指す構造体で指定する"
2164 "点が異なる。この上限は、タイムアウトの時刻を 時刻紀元 (Epoch; 1970-01-01 "
2165 "00:00:00 +0000 (UTC)) からの経過時間 (秒とナノ秒の組) で指定する。タイムアウ"
2169 #: build/C/man3/mq_send.3:119
2171 "If the message queue is full, and the timeout has already expired by the "
2172 "time of the call, B<mq_timedsend>() returns immediately."
2174 "メッセージキューが一杯で、関数呼び出し時にすでにタイムアウト時刻が 過ぎている"
2175 "場合、 B<mq_timedsend>() はすぐに返る。"
2178 #: build/C/man3/mq_send.3:127
2180 "On success, B<mq_send>() and B<mq_timedsend>() return zero; on error, -1 "
2181 "is returned, with I<errno> set to indicate the error."
2183 "成功すると、 B<mq_send>() と B<mq_timedsend>() は 0 を返す。 エラーの場"
2184 "合、-1 を返し、 I<errno> にエラーを示す値を設定する。"
2187 #: build/C/man3/mq_send.3:134
2189 "The queue was full, and the B<O_NONBLOCK> flag was set for the message queue "
2190 "description referred to by I<mqdes>."
2192 "キューが一杯で、かつ I<mqdes> で参照されるメッセージキュー記述で "
2193 "B<O_NONBLOCK> フラグがセットされていた。"
2196 #: build/C/man3/mq_send.3:158
2198 "I<msg_len> was greater than the I<mq_msgsize> attribute of the message queue."
2199 msgstr "I<msg_len> がメッセージキューの I<mq_msgsize> 属性よりも大きかった。"
2202 #: build/C/man3/mq_send.3:169
2204 "On Linux, B<mq_timedsend>() is a system call, and B<mq_send>() is a "
2205 "library function layered on top of that system call."
2207 "Linux では、 B<mq_timedsend>() はシステムコールである。 B<mq_send>() はライ"
2208 "ブラリ関数で、 B<mq_timedsend>() システムコールを用いて実装されている。"
2211 #: build/C/man3/mq_send.3:178
2213 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2214 "B<mq_receive>(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2216 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2217 "B<mq_receive>(3), B<mq_unlink>(3), B<mq_overview>(7), B<time>(7)"
2220 #: build/C/man3/mq_unlink.3:26
2226 #: build/C/man3/mq_unlink.3:29
2227 msgid "mq_unlink - remove a message queue"
2228 msgstr "mq_unlink - メッセージキューを削除する"
2231 #: build/C/man3/mq_unlink.3:34
2233 msgid "B<int mq_unlink(const char *>I<name>B<);>\n"
2234 msgstr "B<int mq_unlink(const char *>I<name>B<);>\n"
2237 #: build/C/man3/mq_unlink.3:44
2239 "B<mq_unlink>() removes the specified message queue I<name>. The message "
2240 "queue name is removed immediately. The queue itself is destroyed once any "
2241 "other processes that have the queue open close their descriptors referring "
2244 "B<mq_unlink>() は指定されたメッセージキュー I<name> を削除する。 メッセージ"
2245 "キュー名は直ちに削除される。 キュー自体は、そのキューをオープンした他のすべて"
2246 "のプロセスが そのキューを参照する記述子をクローズした時点で破棄される。"
2249 #: build/C/man3/mq_unlink.3:50
2251 "On success B<mq_unlink>() returns 0; on error, -1 is returned, with "
2252 "I<errno> set to indicate the error."
2254 "成功すると、 B<mq_unlink>() は 0 を返す。エラーの場合、-1 を返し、 I<errno> "
2258 #: build/C/man3/mq_unlink.3:54
2259 msgid "The caller does not have permission to unlink this message queue."
2261 "呼び出し元プロセスがこのメッセージキューを削除 (unlink) する 許可を持たない。"
2264 #: build/C/man3/mq_unlink.3:62
2265 msgid "There is no message queue with the given I<name>."
2266 msgstr "指定された名前 I<name> を持つメッセージキューが存在しない。"
2269 #: build/C/man3/mq_unlink.3:72
2271 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2272 "B<mq_receive>(3), B<mq_send>(3), B<mq_overview>(7)"
2274 "B<mq_close>(3), B<mq_getattr>(3), B<mq_notify>(3), B<mq_open>(3), "
2275 "B<mq_receive>(3), B<mq_send>(3), B<mq_overview>(7)"
2278 #: build/C/man2/msgctl.2:37
2284 #: build/C/man2/msgctl.2:37 build/C/man2/msgget.2:35 build/C/man2/msgop.2:40
2286 #| msgid "2004-05-27"
2291 #: build/C/man2/msgctl.2:40
2292 msgid "msgctl - message control operations"
2293 msgstr "msgctl - メッセージ制御操作"
2296 #: build/C/man2/msgctl.2:45 build/C/man2/msgget.2:43 build/C/man2/msgop.2:48
2299 "B<#include E<lt>sys/types.hE<gt>>\n"
2300 "B<#include E<lt>sys/ipc.hE<gt>>\n"
2301 "B<#include E<lt>sys/msg.hE<gt>>\n"
2303 "B<#include E<lt>sys/types.hE<gt>>\n"
2304 "B<#include E<lt>sys/ipc.hE<gt>>\n"
2305 "B<#include E<lt>sys/msg.hE<gt>>\n"
2308 #: build/C/man2/msgctl.2:47
2310 msgid "B<int msgctl(int >I<msqid>B<, int >I<cmd>B<, struct msqid_ds *>I<buf>B<);>\n"
2311 msgstr "B<int msgctl(int >I<msqid>B<, int >I<cmd>B<, struct msqid_ds *>I<buf>B<);>\n"
2314 #: build/C/man2/msgctl.2:54
2316 "B<msgctl>() performs the control operation specified by I<cmd> on the "
2317 "message queue with identifier I<msqid>."
2319 "B<msgctl>() はメッセージ・キュー識別子 I<msqid> で指定されたメッセージ・"
2320 "キュー (message queue) に対して I<cmd> で指定された制御操作を行なう。"
2323 #: build/C/man2/msgctl.2:58
2325 "The I<msqid_ds> data structure is defined in I<E<lt>sys/msg.hE<gt>> as "
2328 "I<msqid_ds> データ構造体は I<E<lt>sys/msg.hE<gt>> で以下のように定義されてい"
2332 #: build/C/man2/msgctl.2:75
2335 "struct msqid_ds {\n"
2336 " struct ipc_perm msg_perm; /* Ownership and permissions */\n"
2337 " time_t msg_stime; /* Time of last msgsnd(2) */\n"
2338 " time_t msg_rtime; /* Time of last msgrcv(2) */\n"
2339 " time_t msg_ctime; /* Time of last change */\n"
2340 " unsigned long __msg_cbytes; /* Current number of bytes in\n"
2341 " queue (nonstandard) */\n"
2342 " msgqnum_t msg_qnum; /* Current number of messages\n"
2344 " msglen_t msg_qbytes; /* Maximum number of bytes\n"
2345 " allowed in queue */\n"
2346 " pid_t msg_lspid; /* PID of last msgsnd(2) */\n"
2347 " pid_t msg_lrpid; /* PID of last msgrcv(2) */\n"
2350 "struct msqid_ds {\n"
2351 " struct ipc_perm msg_perm; /* 所有権と許可 */\n"
2352 " time_t msg_stime; /* 最後の msgsnd(2) の時刻 */\n"
2353 " time_t msg_rtime; /* 最後の msgrcv(2) の時刻 */\n"
2354 " time_t msg_ctime; /* 最後に変更が行われた時刻 */\n"
2355 " unsigned long __msg_cbytes; /* キューにある現在のバイト数\n"
2357 " msgqnum_t msg_qnum; /* キューにある現在入っている\n"
2359 " msglen_t msg_qbytes; /* キューに許可されている\n"
2361 " pid_t msg_lspid; /* 最後の msgsnd(2) の PID */\n"
2362 " pid_t msg_lrpid; /* 最後の msgrcv(2) の PID */\n"
2366 #: build/C/man2/msgctl.2:83
2369 #| "The I<ipc_perm> structure is defined in I<E<lt>sys/ipc.hE<gt>> as follows "
2370 #| "(the highlighted fields are settable using B<IPC_SET>):"
2372 "The I<ipc_perm> structure is defined as follows (the highlighted fields are "
2373 "settable using B<IPC_SET>):"
2375 "I<ipc_perm> 構造体は I<E<lt>sys/ipc.hE<gt>> で以下のように定義されている (強"
2376 "調されたフィールドは B<IPC_SET> を使って設定可能である):"
2379 #: build/C/man2/msgctl.2:95
2382 "struct ipc_perm {\n"
2383 " key_t __key; /* Key supplied to msgget(2) */\n"
2384 " uid_t B<uid>; /* Effective UID of owner */\n"
2385 " gid_t B<gid>; /* Effective GID of owner */\n"
2386 " uid_t cuid; /* Effective UID of creator */\n"
2387 " gid_t cgid; /* Effective GID of creator */\n"
2388 " unsigned short B<mode>; /* Permissions */\n"
2389 " unsigned short __seq; /* Sequence number */\n"
2392 "struct ipc_perm {\n"
2393 " key_t __key; /* msgget(2) に与えるキー */\n"
2394 " uid_t B<uid>; /* 所有者の実効 UID */\n"
2395 " gid_t B<gid>; /* 所有者の実効 GID */\n"
2396 " uid_t cuid; /* 作成者の実効 UID */\n"
2397 " gid_t cgid; /* 作成者の実効 GID */\n"
2398 " unsigned short B<mode>; /* 許可 */\n"
2399 " unsigned short __seq; /* シーケンス番号 */\n"
2403 #: build/C/man2/msgctl.2:101
2404 msgid "Valid values for I<cmd> are:"
2405 msgstr "I<cmd> として有効な値は:"
2408 #: build/C/man2/msgctl.2:101
2411 msgstr "B<IPC_STAT>"
2414 #: build/C/man2/msgctl.2:110
2416 "Copy information from the kernel data structure associated with I<msqid> "
2417 "into the I<msqid_ds> structure pointed to by I<buf>. The caller must have "
2418 "read permission on the message queue."
2420 "I<msqid> に関連づけられたメッセージ・キュー・データ構造体から、ポインタ "
2421 "I<buf> が指し示す I<msqid_ds> 構造体に情報をコピーする。 呼び出し側はメッセー"
2422 "ジ・キューに対する読み込み許可を持っていなければならない。"
2425 #: build/C/man2/msgctl.2:110
2431 #: build/C/man2/msgctl.2:137
2433 "Write the values of some members of the I<msqid_ds> structure pointed to by "
2434 "I<buf> to the kernel data structure associated with this message queue, "
2435 "updating also its I<msg_ctime> member. The following members of the "
2436 "structure are updated: I<msg_qbytes>, I<msg_perm.uid>, I<msg_perm.gid>, and "
2437 "(the least significant 9 bits of) I<msg_perm.mode>. The effective UID of "
2438 "the calling process must match the owner (I<msg_perm.uid>) or creator "
2439 "(I<msg_perm.cuid>) of the message queue, or the caller must be privileged. "
2440 "Appropriate privilege (Linux: the B<CAP_IPC_RESOURCE> capability) is "
2441 "required to raise the I<msg_qbytes> value beyond the system parameter "
2444 "ポインタ I<buf> が指し示す I<msqid_ds> 構造体のメンバーの値を、メッセージ・"
2445 "キューに関連づけられた カーネル・データ構造体に書き込み、 I<msg_ctime> メン"
2446 "バーも更新する。 構造体のメンバーのうち、更新されるものを以下に示す: "
2447 "I<msg_qbytes>, I<msg_perm.uid>, I<msg_perm.gid>, I<msg_perm.mode> (の下位 9 "
2448 "ビット)。 呼び出したプロセスの実効ユーザ ID が、メッセージ・キューの所有者 "
2449 "(I<msg_perm.uid>) または作成者 (I<msg_perm.cuid>) と一致するか、呼び出し元"
2450 "が特権を持たなければならない。 I<msg_qbytes> をシステム・パラメータの "
2451 "B<MSGMNB> を超えて設定するには、適切な特権 (Linux では B<CAP_IPC_RESOURCE> "
2452 "ケーパビリティ (capability)) が必要である。"
2455 #: build/C/man2/msgctl.2:137
2458 msgstr "B<IPC_RMID>"
2461 #: build/C/man2/msgctl.2:148
2463 "Immediately remove the message queue, awakening all waiting reader and "
2464 "writer processes (with an error return and I<errno> set to B<EIDRM>). The "
2465 "calling process must have appropriate privileges or its effective user ID "
2466 "must be either that of the creator or owner of the message queue."
2468 "メッセージ・キューをただちに削除する。 同時にその構造体の読み書きの待ち状態に"
2469 "あったプロセスに通知する (エラーが返り、 I<errno> が B<EIDRM> に設定され"
2470 "る)。 呼び出したプロセスが適切な特権を持っているか、 呼び出したプロセスの実効"
2471 "ユーザ ID がメッセージ・キューの作成者か 所有者の実効ユーザ ID でなければなら"
2475 #: build/C/man2/msgctl.2:148
2477 msgid "B<IPC_INFO> (Linux-specific)"
2478 msgstr "B<IPC_INFO> (Linux 固有)"
2481 #: build/C/man2/msgctl.2:161
2483 "Returns information about system-wide message queue limits and parameters in "
2484 "the structure pointed to by I<buf>. This structure is of type I<msginfo> "
2485 "(thus, a cast is required), defined in I<E<lt>sys/msg.hE<gt>> if the "
2486 "B<_GNU_SOURCE> feature test macro is defined:"
2488 "システム全体でのメッセージ・キューの制限とパラメータに関する情報を、 I<buf> "
2489 "が指す構造体に入れて返す。 この構造体は I<msginfo> 型である (そのためキャスト"
2490 "が必要である)。 I<msginfo> は B<_GNU_SOURCE> 機能検査マクロが定義された場合"
2491 "に I<E<lt>sys/msg.hE<gt>> で以下のように定義される:"
2494 #: build/C/man2/msgctl.2:185
2497 "struct msginfo {\n"
2498 " int msgpool; /* Size in kibibytes of buffer pool\n"
2499 " used to hold message data;\n"
2500 " unused within kernel */\n"
2501 " int msgmap; /* Maximum number of entries in message\n"
2502 " map; unused within kernel */\n"
2503 " int msgmax; /* Maximum number of bytes that can be\n"
2504 " written in a single message */\n"
2505 " int msgmnb; /* Maximum number of bytes that can be\n"
2506 " written to queue; used to initialize\n"
2507 " msg_qbytes during queue creation\n"
2509 " int msgmni; /* Maximum number of message queues */\n"
2510 " int msgssz; /* Message segment size;\n"
2511 " unused within kernel */\n"
2512 " int msgtql; /* Maximum number of messages on all queues\n"
2513 " in system; unused within kernel */\n"
2514 " unsigned short int msgseg;\n"
2515 " /* Maximum number of segments;\n"
2516 " unused within kernel */\n"
2519 "struct msginfo {\n"
2520 " int msgpool; /* メッセージ・データの保持に使用される\n"
2521 " バッファ・プールの大きさ (1024 バイト単位);\n"
2523 " int msgmap; /* メッセージ・マップの最大エントリ数;\n"
2525 " int msgmax; /* 一つのメッセージに書き込み可能な\n"
2527 " int msgmnb; /* 一つのキューに書き込み可能な最大バイト数;\n"
2528 " (msgget(2) での) キュー作成中の msg_qbytes\n"
2530 " int msgmni; /* メッセージ・キューの数の最大値 */\n"
2531 " int msgssz; /* メッセージ・セグメントのサイズ;\n"
2533 " int msgtql; /* システム上の全キューの最大メッセージ数;\n"
2535 " unsigned short int msgseg;\n"
2536 " /* 最大セグメント数; カーネル内では未使用 */\n"
2540 #: build/C/man2/msgctl.2:198
2542 "The I<msgmni>, I<msgmax>, and I<msgmnb> settings can be changed via I</proc> "
2543 "files of the same name; see B<proc>(5) for details."
2545 "設定 I<msgmni ,> I<msgmax ,> I<msgmnb> は I</proc> にある同じ名前のファイル経"
2546 "由で変更可能である。 詳しくは B<proc>(5) を参照。"
2549 #: build/C/man2/msgctl.2:198
2551 msgid "B<MSG_INFO> (Linux-specific)"
2552 msgstr "B<MSG_INFO> (Linux 固有)"
2555 #: build/C/man2/msgctl.2:215
2557 "Returns a I<msginfo> structure containing the same information as for "
2558 "B<IPC_INFO>, except that the following fields are returned with information "
2559 "about system resources consumed by message queues: the I<msgpool> field "
2560 "returns the number of message queues that currently exist on the system; the "
2561 "I<msgmap> field returns the total number of messages in all queues on the "
2562 "system; and the I<msgtql> field returns the total number of bytes in all "
2563 "messages in all queues on the system."
2565 "B<IPC_INFO> のときと同じ情報を格納した I<msginfo> 構造体を返す。 但し、以下の"
2566 "フィールドにはメッセージ・キューが 消費しているシステム資源に関する情報が格納"
2567 "される点が異なる。 I<msgpool> フィールドは現在システム上に存在するメッセー"
2568 "ジ・キューの数を返す。 I<msgmap> フィールドはシステム上の全てのキューに入って"
2569 "いるメッセージ総数を返す。 I<msgtql> フィールドはシステム上の全てのキューに"
2570 "入っている全メッセージの 総バイト数を返す。"
2573 #: build/C/man2/msgctl.2:215
2575 msgid "B<MSG_STAT> (Linux-specific)"
2576 msgstr "B<MSG_STAT> (Linux 固有)"
2579 #: build/C/man2/msgctl.2:226
2581 "Returns a I<msqid_ds> structure as for B<IPC_STAT>. However, the I<msqid> "
2582 "argument is not a queue identifier, but instead an index into the kernel's "
2583 "internal array that maintains information about all message queues on the "
2586 "B<IPC_STAT> と同じく I<msqid_ds> 構造体を返す。 但し、 I<msqid> 引き数は、"
2587 "キュー識別子ではなく、システム上の全てのメッセージ・キュー に関する情報を管理"
2588 "するカーネルの内部配列へのインデックスである。"
2591 #: build/C/man2/msgctl.2:247
2593 "On success, B<IPC_STAT>, B<IPC_SET>, and B<IPC_RMID> return 0. A successful "
2594 "B<IPC_INFO> or B<MSG_INFO> operation returns the index of the highest used "
2595 "entry in the kernel's internal array recording information about all message "
2596 "queues. (This information can be used with repeated B<MSG_STAT> operations "
2597 "to obtain information about all queues on the system.) A successful "
2598 "B<MSG_STAT> operation returns the identifier of the queue whose index was "
2599 "given in I<msqid>."
2601 "成功すると、 B<IPC_STAT>, B<IPC_SET>, B<IPC_RMID> は 0 を返す。 B<IPC_INFO> "
2602 "と B<MSG_INFO> 操作は、成功すると、全てのメッセージ・キューに関する情報を 管"
2603 "理しているカーネルの内部配列の使用中エントリのインデックスの うち最大値を返"
2604 "す (この情報は、システムの全てのメッセージ・キューに関する情報を 取得するため"
2605 "に、 B<MSG_STAT> 操作を繰り返し実行する際に使用できる)。 B<MSG_STAT> 操作は、"
2606 "成功すると、 I<msqid> で指定されたインデックスを持つメッセージ・キューの識別"
2610 #: build/C/man2/msgctl.2:251
2611 msgid "On error, -1 is returned with I<errno> indicating the error."
2612 msgstr "エラーの場合は -1 を返し、 I<errno> を適切に設定する。"
2615 #: build/C/man2/msgctl.2:255
2616 msgid "On failure, I<errno> is set to one of the following:"
2617 msgstr "失敗した場合、 I<errno> は以下の値の中のどれか一つに設定される:"
2620 #: build/C/man2/msgctl.2:268
2622 "The argument I<cmd> is equal to B<IPC_STAT> or B<MSG_STAT>, but the calling "
2623 "process does not have read permission on the message queue I<msqid>, and "
2624 "does not have the B<CAP_IPC_OWNER> capability."
2626 "引き数 I<cmd> が B<IPC_STAT> または B<MSG_STAT> に等しいが、呼び出したプロセ"
2627 "スがメッセージ・キュー I<msqid> に対する読み込み許可を持っておらず、かつ "
2628 "B<CAP_IPC_OWNER> ケーパビリティを持っていない。"
2631 #: build/C/man2/msgctl.2:268 build/C/man2/msgop.2:320 build/C/man2/msgop.2:373
2637 #: build/C/man2/msgctl.2:279
2639 "The argument I<cmd> has the value B<IPC_SET> or B<IPC_STAT>, but the address "
2640 "pointed to by I<buf> isn't accessible."
2642 "引き数 I<cmd> が B<IPC_SET> か B<IPC_STAT> で、ポインタ I<buf> で指されている"
2646 #: build/C/man2/msgctl.2:279 build/C/man2/msgop.2:325 build/C/man2/msgop.2:378
2652 #: build/C/man2/msgctl.2:282 build/C/man2/msgop.2:328
2653 msgid "The message queue was removed."
2654 msgstr "メッセージ・キューが削除された。"
2657 #: build/C/man2/msgctl.2:293
2659 "Invalid value for I<cmd> or I<msqid>. Or: for a B<MSG_STAT> operation, the "
2660 "index value specified in I<msqid> referred to an array slot that is "
2663 "I<cmd> または I<msqid> に不正な値が設定された。 もしくは、 B<MSG_STAT> 操作の"
2664 "場合に、 I<msqid> で指定されたインデックス値が現在未使用の配列のスロットを参"
2668 #: build/C/man2/msgctl.2:293
2674 #: build/C/man2/msgctl.2:311
2676 "The argument I<cmd> has the value B<IPC_SET> or B<IPC_RMID>, but the "
2677 "effective user ID of the calling process is not the creator (as found in "
2678 "I<msg_perm.cuid>) or the owner (as found in I<msg_perm.uid>) of the "
2679 "message queue, and the process is not privileged (Linux: it does not have "
2680 "the B<CAP_SYS_ADMIN> capability)."
2682 "引き数 I<cmd> が B<IPC_SET> か B<IPC_RMID> であるが、呼び出したプロセスの実効"
2683 "ユーザ ID がメッセージキューの (I<msg_perm.cuid> として見つかる) 作成者 と "
2684 "(I<msg_perm.uid> として見つかる) 所有者のいずれでもなく、 かつ呼び出したプロ"
2685 "セスに特権 (Linux では B<CAP_SYS_ADMIN> ケーパビリティ) がない。"
2688 #: build/C/man2/msgctl.2:314 build/C/man2/msgget.2:185
2689 #: build/C/man2/msgop.2:401
2690 msgid "SVr4, POSIX.1-2001."
2691 msgstr "SVr4, POSIX.1-2001."
2693 #. Like Linux, the FreeBSD man pages still document
2694 #. the inclusion of these header files.
2696 #: build/C/man2/msgctl.2:327 build/C/man2/msgget.2:198
2697 #: build/C/man2/msgop.2:414
2699 "The inclusion of I<E<lt>sys/types.hE<gt>> and I<E<lt>sys/ipc.hE<gt>> isn't "
2700 "required on Linux or by any version of POSIX. However, some old "
2701 "implementations required the inclusion of these header files, and the SVID "
2702 "also documented their inclusion. Applications intended to be portable to "
2703 "such old systems may need to include these header files."
2707 #: build/C/man2/msgctl.2:338
2709 "The B<IPC_INFO>, B<MSG_STAT> and B<MSG_INFO> operations are used by the "
2710 "B<ipcs>(1) program to provide information on allocated resources. In the "
2711 "future these may modified or moved to a /proc file system interface."
2713 "B<IPC_INFO>, B<MSG_STAT>, B<MSG_INFO> 操作は、 B<ipcs>(1) プログラムで割り当"
2714 "て済の資源に関する情報を提供するために 使用されている。将来、これらの操作は変"
2715 "更されたり、 /proc ファイルシステムのインタフェースに移動されるかもしれない。"
2718 #: build/C/man2/msgctl.2:352
2720 "Various fields in the I<struct msqid_ds> were typed as I<short> under Linux "
2721 "2.2 and have become I<long> under Linux 2.4. To take advantage of this, a "
2722 "recompilation under glibc-2.1.91 or later should suffice. (The kernel "
2723 "distinguishes old and new calls by an B<IPC_64> flag in I<cmd>.)"
2725 "I<struct msqid_ds> 内の多くのフィールドは、 Linux 2.2 では I<short> だった"
2726 "が、Linux 2.4 では I<long> になった。 この利点を生かすには、glibc-2.1.91 以降"
2727 "の環境下で 再コンパイルすれば十分である。 (カーネルは新しい形式の呼び出しと古"
2728 "い形式の呼び出しを I<cmd> 内の B<IPC_64> フラグで区別する。)"
2731 #: build/C/man2/msgctl.2:359
2733 "B<msgget>(2), B<msgrcv>(2), B<msgsnd>(2), B<capabilities>(7), B<mq_overview>"
2736 "B<msgget>(2), B<msgrcv>(2), B<msgsnd>(2), B<capabilities>(7), B<mq_overview>"
2740 #: build/C/man2/msgget.2:35
2746 #: build/C/man2/msgget.2:38
2747 msgid "msgget - get a message queue identifier"
2748 msgstr "msgget - メッセージ・キュー識別子を取得する"
2751 #: build/C/man2/msgget.2:45
2753 msgid "B<int msgget(key_t >I<key>B<, int >I<msgflg>B<);>\n"
2754 msgstr "B<int msgget(key_t >I<key>B<, int >I<msgflg>B<);>\n"
2757 #: build/C/man2/msgget.2:67
2759 "The B<msgget>() system call returns the message queue identifier associated "
2760 "with the value of the I<key> argument. A new message queue is created if "
2761 "I<key> has the value B<IPC_PRIVATE> or I<key> isn't B<IPC_PRIVATE>, no "
2762 "message queue with the given key I<key> exists, and B<IPC_CREAT> is "
2763 "specified in I<msgflg>."
2765 "B<msgget>() システムコールは I<key> 引き数の値に対応するメッセージ・キューの"
2766 "識別子を返す。 I<key> の値が B<IPC_PRIVATE> の場合、または I<key> が "
2767 "B<IPC_PRIVATE> でなくても、 I<key> に対応するメッセージ・キューが存在せず、 "
2768 "I<msgflg> に B<IPC_CREAT> が指定されている場合、 新しいメッセージ・キューが作"
2772 #: build/C/man2/msgget.2:86
2774 "If I<msgflg> specifies both B<IPC_CREAT> and B<IPC_EXCL> and a message queue "
2775 "already exists for I<key>, then B<msgget>() fails with I<errno> set to "
2776 "B<EEXIST>. (This is analogous to the effect of the combination B<O_CREAT | "
2777 "O_EXCL> for B<open>(2).)"
2779 "I<msgflg> に B<IPC_CREAT> と B<IPC_EXCL> の両方が指定された場合、 I<key> に対"
2780 "応するメッセージ・キューが既に存在すると、 B<msgget>() は失敗し、 I<errno> "
2781 "に B<EEXIST> が設定される。 (これは B<open>(2) に B<O_CREAT | O_EXCL> を指定"
2785 #: build/C/man2/msgget.2:96
2787 "Upon creation, the least significant bits of the argument I<msgflg> define "
2788 "the permissions of the message queue. These permission bits have the same "
2789 "format and semantics as the permissions specified for the I<mode> argument "
2790 "of B<open>(2). (The execute permissions are not used.)"
2792 "メッセージ・キューの作成時に、 I<msgflg> 引き数の下位 9 ビットは、 そのメッ"
2793 "セージ・キューのアクセス許可の定義として使用される。 これらの許可ビットは "
2794 "B<open>(2) の引き数 I<mode> と同じ形式で同じ意味である。 や B<creat>(2) シ"
2795 "ステム・コールのアクセス許可パラメータと同じ形式で、同じ意味を持つ。 (但し、"
2796 "実行 (execute) 許可は使用されない。)"
2799 #: build/C/man2/msgget.2:103
2801 "If a new message queue is created, then its associated data structure "
2802 "I<msqid_ds> (see B<msgctl>(2)) is initialized as follows:"
2804 "新規のメッセージ・キューを作成する際、 B<msgget>() システム・コールはメッ"
2805 "セージ・キューのデータ構造体 I<msqid_ds> を以下のように初期化する "
2806 "(I<msqid_ds> については B<msgctl>(2) を参照):"
2809 #: build/C/man2/msgget.2:108
2811 "I<msg_perm.cuid> and I<msg_perm.uid> are set to the effective user ID of the "
2814 "I<msg_perm.cuid> と I<msg_perm.uid> に呼び出し元プロセスの実効 (effective) "
2818 #: build/C/man2/msgget.2:113
2820 "I<msg_perm.cgid> and I<msg_perm.gid> are set to the effective group ID of "
2821 "the calling process."
2823 "I<msg_perm.cgid> と I<msg_perm.gid> に呼び出し元プロセスの実効 (effective) グ"
2827 #: build/C/man2/msgget.2:118
2829 "The least significant 9 bits of I<msg_perm.mode> are set to the least "
2830 "significant 9 bits of I<msgflg>."
2832 "I<msg_perm.mode> の下位 9 ビットは I<msgflg> の下位 9 ビットを設定する。"
2835 #: build/C/man2/msgget.2:126
2837 "I<msg_qnum>, I<msg_lspid>, I<msg_lrpid>, I<msg_stime> and I<msg_rtime> are "
2840 "I<msg_qnum>, I<msg_lspid>, I<msg_lrpid>, I<msg_stime>, I<msg_rtime> に 0 を設"
2844 #: build/C/man2/msgget.2:129
2845 msgid "I<msg_ctime> is set to the current time."
2846 msgstr "I<msg_ctime> に現在の時刻を設定する。"
2849 #: build/C/man2/msgget.2:133
2850 msgid "I<msg_qbytes> is set to the system limit B<MSGMNB>."
2852 "I<msg_qbytes> に、システムで決められたメッセージ・キューの最大サイズ "
2856 #: build/C/man2/msgget.2:137
2858 "If the message queue already exists the permissions are verified, and a "
2859 "check is made to see if it is marked for destruction."
2861 "メッセージ・キューがすでに存在する場合は、アクセス許可の検査と、 破棄 "
2862 "(destruction) マークがないかの確認が行われる。"
2865 #: build/C/man2/msgget.2:143
2867 "If successful, the return value will be the message queue identifier (a "
2868 "nonnegative integer), otherwise -1 with I<errno> indicating the error."
2870 "成功した場合、返り値はメッセージ・キュー識別子 (非負の整数) となる。 失敗した"
2871 "場合は -1 が返され、 I<errno> にそのエラーが示される。"
2874 #: build/C/man2/msgget.2:147
2875 msgid "On failure, I<errno> is set to one of the following values:"
2876 msgstr "失敗した場合、 I<errno> に以下の値のいずれか一つが設定される:"
2879 #: build/C/man2/msgget.2:155
2881 "A message queue exists for I<key>, but the calling process does not have "
2882 "permission to access the queue, and does not have the B<CAP_IPC_OWNER> "
2885 "I<key> に対応するメッセージ・キューは存在するが、 呼び出し元プロセスはその"
2886 "キューに対するアクセス許可がなく、 B<CAP_IPC_OWNER> ケーパビリティも持ってい"
2890 #: build/C/man2/msgget.2:165
2892 "A message queue exists for I<key> and I<msgflg> specified both B<IPC_CREAT> "
2895 "I<key> に対応するメッセージ・キューが存在し、 I<msgflg> に B<IPC_CREAT> と "
2896 "B<IPC_EXCL> が指定されていた。"
2899 #: build/C/man2/msgget.2:173
2901 "No message queue exists for I<key> and I<msgflg> did not specify "
2904 "I<key> に対応するメッセージ・キューが存在せず、 I<msgflg> に B<IPC_CREAT> が"
2908 #: build/C/man2/msgget.2:177
2910 "A message queue has to be created but the system does not have enough memory "
2911 "for the new data structure."
2913 "メッセージ・キューを作成しようとしたが、新しいデータ構造体を作成 するのに十分"
2917 #: build/C/man2/msgget.2:183
2919 "A message queue has to be created but the system limit for the maximum "
2920 "number of message queues (B<MSGMNI>) would be exceeded."
2922 "メッセージ・キューを作成しようとしたが、作成すると システム全体のメッセージ・"
2923 "キュー数の最大値 (B<MSGMNI>) を超えてしまう。"
2926 #: build/C/man2/msgget.2:208
2928 "B<IPC_PRIVATE> isn't a flag field but a I<key_t> type. If this special "
2929 "value is used for I<key>, the system call ignores everything but the least "
2930 "significant 9 bits of I<msgflg> and creates a new message queue (on success)."
2932 "B<IPC_PRIVATE> はフラグではなく、 I<key_t> 型である。 この特別な値が I<key> "
2933 "として使用された場合、 B<msgget>() システムコールは I<msgflg> の下位 9 ビッ"
2934 "ト以外の全てを無視して (成功した場合は) 新しいメッセージ・キューを作成する。"
2937 #: build/C/man2/msgget.2:212
2939 "The following is a system limit on message queue resources affecting a "
2942 "B<msgget>() システムコールに影響を及ぼすメッセージ・キューの資源の システム"
2946 #: build/C/man2/msgget.2:212
2952 #: build/C/man2/msgget.2:218
2954 "System wide maximum number of message queues: policy dependent (on Linux, "
2955 "this limit can be read and modified via I</proc/sys/kernel/msgmni>)."
2957 "システム全体のメッセージ・キュー数の最大値: 方針依存 (Linux では、この制限値"
2958 "は I</proc/sys/kernel/msgmni> 経由で参照したり、変更したりできる)。"
2961 #: build/C/man2/msgget.2:218
2963 #| msgid "Linux Notes"
2968 #: build/C/man2/msgget.2:224
2970 "Until version 2.3.20 Linux would return B<EIDRM> for a B<msgget>() on a "
2971 "message queue scheduled for deletion."
2973 "Linux 2.3.20 までは、削除が予定されているメッセージ・キューに対して B<msgget>"
2974 "() を行うと B<EIDRM> がエラーとして返されるようになっていた。"
2977 #: build/C/man2/msgget.2:230
2979 "The name choice B<IPC_PRIVATE> was perhaps unfortunate, B<IPC_NEW> would "
2980 "more clearly show its function."
2982 "B<IPC_PRIVATE> という名前を選んだのはおそらく失敗であろう。 B<IPC_NEW> の方が"
2983 "より明確にその機能を表しているだろう。"
2986 #: build/C/man2/msgget.2:238
2988 "B<msgctl>(2), B<msgrcv>(2), B<msgsnd>(2), B<ftok>(3), B<capabilities>(7), "
2989 "B<mq_overview>(7), B<svipc>(7)"
2991 "B<msgctl>(2), B<msgrcv>(2), B<msgsnd>(2), B<ftok>(3), B<capabilities>(7), "
2992 "B<mq_overview>(7), B<svipc>(7)"
2995 #: build/C/man2/msgop.2:40
3001 #: build/C/man2/msgop.2:43
3002 msgid "msgrcv, msgsnd - message operations"
3003 msgstr "msgrcv, msgsnd - メッセージ操作"
3006 #: build/C/man2/msgop.2:51
3008 msgid "B<int msgsnd(int >I<msqid>B<, const void *>I<msgp>B<, size_t >I<msgsz>B<, int >I<msgflg>B<);>\n"
3009 msgstr "B<int msgsnd(int >I<msqid>B<, const void *>I<msgp>B<, size_t >I<msgsz>B<, int >I<msgflg>B<);>\n"
3012 #: build/C/man2/msgop.2:55
3015 "B<ssize_t msgrcv(int >I<msqid>B<, void *>I<msgp>B<, size_t >I<msgsz>B<, long >I<msgtyp>B<,>\n"
3016 "B< int >I<msgflg>B<);>\n"
3018 "B<ssize_t msgrcv(int >I<msqid>B<, void *>I<msgp>B<, size_t >I<msgsz>B<, long >I<msgtyp>B<,>\n"
3019 "B< int >I<msgflg>B<);>\n"
3022 #: build/C/man2/msgop.2:65
3024 "The B<msgsnd>() and B<msgrcv>() system calls are used, respectively, to "
3025 "send messages to, and receive messages from, a message queue. The calling "
3026 "process must have write permission on the message queue in order to send a "
3027 "message, and read permission to receive a message."
3029 "システムコール B<msgsnd>() と B<msgrcv>() はそれぞれ、メッセージ・キューへ"
3030 "のメッセージの送信と、 メッセージの受信に使用される。呼び出し元プロセスは、 "
3031 "メッセージを送信するためにはメッセージ・キューに対する書き込み許可を、 メッ"
3032 "セージを受信するためには読み出し許可を持っていなければならない。"
3035 #: build/C/man2/msgop.2:70
3037 "The I<msgp> argument is a pointer to caller-defined structure of the "
3038 "following general form:"
3040 "呼び出し元プロセスは以下に示す構造体を用意し、この構造体への ポインタを "
3044 #: build/C/man2/msgop.2:77
3048 " long mtype; /* message type, must be E<gt> 0 */\n"
3049 " char mtext[1]; /* message data */\n"
3053 " long mtype; /* message type, must be E<gt> 0 */\n"
3054 " char mtext[1]; /* message data */\n"
3058 #: build/C/man2/msgop.2:96
3060 "The I<mtext> field is an array (or other structure) whose size is specified "
3061 "by I<msgsz>, a nonnegative integer value. Messages of zero length (i.e., no "
3062 "I<mtext> field) are permitted. The I<mtype> field must have a strictly "
3063 "positive integer value. This value can be used by the receiving process for "
3064 "message selection (see the description of B<msgrcv>() below)."
3066 "I<mtext> フィールドは配列 (または他の構造体) で、その大きさは 非負の整数であ"
3067 "る I<msgsz> で指定される。 長さ 0 のメッセージ (つまり I<mtext> フィールドが"
3068 "ないメッセージ) も認められている。 B<mtype> フィールドは厳密に正の整数でなけ"
3069 "ればならない。 この値は、メッセージを受信するプロセスでメッセージを選択するた"
3070 "めに 使用される (下記の B<msgrcv>() の説明を参照のこと)。"
3073 #: build/C/man2/msgop.2:96
3079 #: build/C/man2/msgop.2:104
3081 "The B<msgsnd>() system call appends a copy of the message pointed to by "
3082 "I<msgp> to the message queue whose identifier is specified by I<msqid>."
3084 "B<msgsnd>() システムコールは I<msgp> 引き数で指定されたメッセージのコピーを "
3085 "I<msqid> で指定された識別子を持つメッセージ・キューへ追加する。"
3088 #: build/C/man2/msgop.2:125
3090 "If sufficient space is available in the queue, B<msgsnd>() succeeds "
3091 "immediately. (The queue capacity is defined by the I<msg_qbytes> field in "
3092 "the associated data structure for the message queue. During queue creation "
3093 "this field is initialized to B<MSGMNB> bytes, but this limit can be modified "
3094 "using B<msgctl>(2).) If insufficient space is available in the queue, then "
3095 "the default behavior of B<msgsnd>() is to block until space becomes "
3096 "available. If B<IPC_NOWAIT> is specified in I<msgflg>, then the call "
3097 "instead fails with the error B<EAGAIN>."
3099 "キューに十分な空き容量がある場合、 B<msgsnd>() は直ちに成功する。 (キューの"
3100 "容量は、メッセージ・キューのデータ構造体の I<msg_qbytes> フィールドで定義され"
3101 "る。 キュー作成時にこのフィールドは B<MSGMNB> に初期化されるが、この制限は "
3102 "B<msgctl>(2) を使って変更できる。) キューに十分な空き容量がない場合、 デ"
3103 "フォルトでは B<msgsnd>() は空き容量ができるまで停止 (block) する。 "
3104 "I<msgflg> に B<IPC_NOWAIT> が指定された場合は、エラー B<EAGAIN> で失敗する。"
3107 #: build/C/man2/msgop.2:129
3108 msgid "A blocked B<msgsnd>() call may also fail if:"
3109 msgstr "停止している B<msgsnd>() は以下の場合にも失敗する。"
3112 #: build/C/man2/msgop.2:129 build/C/man2/msgop.2:136 build/C/man2/msgop.2:198
3113 #: build/C/man2/msgop.2:203 build/C/man2/msgop.2:217 build/C/man2/msgop.2:256
3114 #: build/C/man2/msgop.2:258 build/C/man2/msgop.2:264
3120 #: build/C/man2/msgop.2:136
3122 "the queue is removed, in which case the system call fails with I<errno> set "
3124 msgstr "キューが削除された。 この場合、 I<errno> は B<EIDRM> に設定される。"
3127 #: build/C/man2/msgop.2:148
3129 "a signal is caught, in which case the system call fails with I<errno> set to "
3130 "B<EINTR>;B<see> B<signal>(7). (B<msgsnd>() is never automatically "
3131 "restarted after being interrupted by a signal handler, regardless of the "
3132 "setting of the B<SA_RESTART> flag when establishing a signal handler.)"
3134 "シグナルが捕捉された。 この場合、 I<errno> は B<EINTR> に設定される。 "
3135 "B<signal>(7) 参照。 (B<msgsnd>() は、たとえシグナルハンドラの設定時に "
3136 "B<SA_RESTART> を指定していたとしても、シグナルハンドラによって割り込まれた後"
3137 "で 自動的に再スタートすることは決してない。)"
3140 #: build/C/man2/msgop.2:151 build/C/man2/msgop.2:278
3142 "Upon successful completion the message queue data structure is updated as "
3145 "正常に終了した場合、メッセージ・キューのデータ構造体は以下のように 更新され"
3149 #: build/C/man2/msgop.2:154
3150 msgid "I<msg_lspid> is set to the process ID of the calling process."
3151 msgstr "I<msg_lspid> には呼び出し元プロセスのプロセス ID が設定される。"
3154 #: build/C/man2/msgop.2:157
3155 msgid "I<msg_qnum> is incremented by 1."
3156 msgstr "I<msg_qnum> は 1 増加する。"
3159 #: build/C/man2/msgop.2:160
3160 msgid "I<msg_stime> is set to the current time."
3161 msgstr "I<msg_stime> には現在時刻が設定される。"
3164 #: build/C/man2/msgop.2:160
3170 #: build/C/man2/msgop.2:168
3172 "The B<msgrcv>() system call removes a message from the queue specified by "
3173 "I<msqid> and places it in the buffer pointed to by I<msgp>."
3175 "B<msgrcv>() システムコールは I<msqid> で指定されたキューからメッセージを削除"
3176 "し、 I<msgp> で指定されたバッファにそのメッセージを格納する。"
3179 #: build/C/man2/msgop.2:194
3181 "The argument I<msgsz> specifies the maximum size in bytes for the member "
3182 "I<mtext> of the structure pointed to by the I<msgp> argument. If the "
3183 "message text has length greater than I<msgsz>, then the behavior depends on "
3184 "whether B<MSG_NOERROR> is specified in I<msgflg>. If B<MSG_NOERROR> is "
3185 "specified, then the message text will be truncated (and the truncated part "
3186 "will be lost); if B<MSG_NOERROR> is not specified, then the message isn't "
3187 "removed from the queue and the system call fails returning -1 with I<errno> "
3190 "I<msgsz> 引き数には I<msgp> 引き数で指定された構造体の I<mtext> メンバーの最"
3191 "大のバイト数を指定する。 メッセージのテキストの長さが I<msgsz> より大きい場合"
3192 "の動作は、 I<msgflg> に B<MSG_NOERROR> が指定されているかどうかで決まる。 "
3193 "B<MSG_NOERROR> が指定されていれば、メッセージのテキストは切り詰められる (切り"
3194 "捨てられた部分は失われる)。 B<MSG_NOERROR> が指定されていなければ、メッセージ"
3195 "はキューから削除されず、 システムコールは -1 を返して失敗し、 I<errno> に "
3199 #: build/C/man2/msgop.2:198
3201 "The argument I<msgtyp> specifies the type of message requested as follows:"
3203 "I<msgtyp> 引き数には要求するメッセージの型を指定する。 型は以下のように指定す"
3207 #: build/C/man2/msgop.2:203
3208 msgid "If I<msgtyp> is 0, then the first message in the queue is read."
3209 msgstr "I<msgtyp> が 0 ならば、キューの最初にあるメッセージが読み込まれる。"
3212 #: build/C/man2/msgop.2:217
3214 "If I<msgtyp> is greater than 0, then the first message in the queue of type "
3215 "I<msgtyp> is read, unless B<MSG_EXCEPT> was specified in I<msgflg>, in which "
3216 "case the first message in the queue of type not equal to I<msgtyp> will be "
3219 "I<msgtyp> が 0 より大きい場合、 I<msgflg> に B<MSG_EXCEPT> が指定されていなけ"
3220 "れば、 I<msgtyp> 型のキューの最初のメッセージが読み込まれる。 B<MSG_EXCEPT> "
3221 "が指定された場合は、 I<msgtyp> 型以外のキューの最初のメッセージが読み込まれ"
3225 #: build/C/man2/msgop.2:225
3227 "If I<msgtyp> is less than 0, then the first message in the queue with the "
3228 "lowest type less than or equal to the absolute value of I<msgtyp> will be "
3231 "I<msgtyp> が 0 より小さければ、 I<msgtyp> の絶対値以下で最も小さい型を持つ"
3232 "キューの最初のメッセージが読み込まれる。"
3235 #: build/C/man2/msgop.2:230
3237 "The I<msgflg> argument is a bit mask constructed by ORing together zero or "
3238 "more of the following flags:"
3240 "I<msgflg> 引き数には、以下のフラグを任意の数だけ (0個も可)、これらの OR で指"
3244 #: build/C/man2/msgop.2:230
3246 msgid "B<IPC_NOWAIT>"
3247 msgstr "B<IPC_NOWAIT>"
3250 #: build/C/man2/msgop.2:237
3252 "Return immediately if no message of the requested type is in the queue. The "
3253 "system call fails with I<errno> set to B<ENOMSG>."
3255 "キューに要求された型のメッセージがない場合には直ちに返る。 システムコールは失"
3256 "敗し、 I<errno> には B<ENOMSG> が設定される。"
3259 #: build/C/man2/msgop.2:237
3261 msgid "B<MSG_EXCEPT>"
3262 msgstr "B<MSG_EXCEPT>"
3265 #: build/C/man2/msgop.2:245
3267 "Used with I<msgtyp> greater than 0 to read the first message in the queue "
3268 "with message type that differs from I<msgtyp>."
3270 "0 より大きな I<msgtyp> と一緒に使用して、 I<msgtyp> 以外のキューの最初のメッ"
3274 #: build/C/man2/msgop.2:245
3276 msgid "B<MSG_NOERROR>"
3277 msgstr "B<MSG_NOERROR>"
3280 #: build/C/man2/msgop.2:250
3281 msgid "To truncate the message text if longer than I<msgsz> bytes."
3282 msgstr "I<msgsz> バイトよりも長かった場合はメッセージのテキストを切り詰める。"
3285 #: build/C/man2/msgop.2:256
3287 "If no message of the requested type is available and B<IPC_NOWAIT> isn't "
3288 "specified in I<msgflg>, the calling process is blocked until one of the "
3289 "following conditions occurs:"
3291 "要求された型のメッセージが存在せず、 I<msgflg> に B<IPC_NOWAIT> が指定されて"
3292 "いなかった場合、呼び出し元プロセスは 以下のいずれかの状況になるまで停止 "
3296 #: build/C/man2/msgop.2:258
3297 msgid "A message of the desired type is placed in the queue."
3298 msgstr "要求している型のメッセージがキューへ入れられた。"
3301 #: build/C/man2/msgop.2:264
3303 "The message queue is removed from the system. In this case the system call "
3304 "fails with I<errno> set to B<EIDRM>."
3306 "メッセージ・キューがシステムから削除された。 この場合、システムコールは失敗"
3307 "し、 I<errno> に B<EIDRM> が設定される。"
3310 #: build/C/man2/msgop.2:275
3312 "The calling process catches a signal. In this case the system call fails "
3313 "with I<errno> set to B<EINTR>. (B<msgrcv>() is never automatically "
3314 "restarted after being interrupted by a signal handler, regardless of the "
3315 "setting of the B<SA_RESTART> flag when establishing a signal handler.)"
3317 "呼び出し元プロセスがシグナルを捕獲した。 この場合、システムコールは失敗し、 "
3318 "I<errno> に B<EINTR> が設定される。 (B<msgrcv>() は、たとえシグナルハンドラ"
3319 "の設定時に B<SA_RESTART> を指定していたとしても、シグナルハンドラによって割り"
3320 "込まれた後で 自動的に再スタートすることは決してない。)"
3323 #: build/C/man2/msgop.2:281
3324 msgid "I<msg_lrpid> is set to the process ID of the calling process."
3325 msgstr "I<msg_lrpid> には呼び出し元プロセスのプロセス ID が設定される。"
3328 #: build/C/man2/msgop.2:284
3329 msgid "I<msg_qnum> is decremented by 1."
3330 msgstr "I<msg_qnum> は 1 減算される。"
3333 #: build/C/man2/msgop.2:287
3334 msgid "I<msg_rtime> is set to the current time."
3335 msgstr "I<msg_rtime> には現在の時刻が設定される。"
3338 #: build/C/man2/msgop.2:300
3340 "On failure both functions return -1 with I<errno> indicating the error, "
3341 "otherwise B<msgsnd>() returns 0 and B<msgrcv>() returns the number of "
3342 "bytes actually copied into the I<mtext> array."
3344 "失敗した場合は、どちらの関数も -1 を返し、エラーを I<errno> に表示する。成功"
3345 "した場合、 B<msgsnd>() は 0 を返し、 B<msgrcv>() は I<mtext> 配列に実際にコ"
3349 #: build/C/man2/msgop.2:306
3351 "When B<msgsnd>() fails, I<errno> will be set to one among the following "
3354 "B<msgsnd>() が失敗した場合、 B<errno> に以下の値のいずれかが設定される:"
3357 #: build/C/man2/msgop.2:312
3359 "The calling process does not have write permission on the message queue, and "
3360 "does not have the B<CAP_IPC_OWNER> capability."
3362 "呼び出し元プロセスにはメッセージ・キューに対する書き込み許可がなく、 "
3363 "B<CAP_IPC_OWNER> ケーパビリティもない。"
3366 #: build/C/man2/msgop.2:320
3368 "The message can't be sent due to the I<msg_qbytes> limit for the queue and "
3369 "B<IPC_NOWAIT> was specified in I<msgflg>."
3371 "I<msg_qbytes> がキューの制限を超えていたため、メッセージを送ることができず、"
3372 "かつ I<msgflg> に B<IPC_NOWAIT> が指定されていた。"
3375 #: build/C/man2/msgop.2:325 build/C/man2/msgop.2:378
3376 msgid "The address pointed to by I<msgp> isn't accessible."
3377 msgstr "I<msgp> が指しているアドレスがアクセス可能でない。"
3380 #: build/C/man2/msgop.2:331
3382 "Sleeping on a full message queue condition, the process caught a signal."
3384 "メッセージ・キューが要求した条件を満たすまで停止している時に、 プロセスがシグ"
3388 #: build/C/man2/msgop.2:342
3390 "Invalid I<msqid> value, or nonpositive I<mtype> value, or invalid I<msgsz> "
3391 "value (less than 0 or greater than the system value B<MSGMAX>)."
3393 "I<msqid> が不適切な値であるか、 I<mtype> が正の値でないか、 I<msgsz> が不適切"
3394 "な値 (0 以下か、システムで決まる値 B<MSGMAX> よりも大きい値) である。"
3397 #: build/C/man2/msgop.2:347
3399 "The system does not have enough memory to make a copy of the message pointed "
3402 "I<msgp> が指すメッセージのコピーを作成するのに十分なメモリがシステムに存在し"
3406 #: build/C/man2/msgop.2:353
3408 "When B<msgrcv>() fails, I<errno> will be set to one among the following "
3411 "B<msgrcv>() が失敗した場合には I<errno> に以下の値のいずれかが設定される:"
3414 #: build/C/man2/msgop.2:353
3420 #: build/C/man2/msgop.2:361
3422 "The message text length is greater than I<msgsz> and B<MSG_NOERROR> isn't "
3423 "specified in I<msgflg>."
3425 "メッセージのテキストの長さが I<msgsz> よりも大きく、 I<msgflg> に "
3426 "B<MSG_NOERROR> が設定されていなかった。"
3429 #: build/C/man2/msgop.2:367
3431 "The calling process does not have read permission on the message queue, and "
3432 "does not have the B<CAP_IPC_OWNER> capability."
3434 "呼び出し元プロセスにはメッセージ・キューに対する読み込み許可がなく、 "
3435 "B<CAP_IPC_OWNER> ケーパビリティもない。"
3438 #: build/C/man2/msgop.2:373
3440 "No message was available in the queue and B<IPC_NOWAIT> was specified in "
3442 msgstr "キューにはメッセージがなく、 I<msgflg> に B<IPC_NOWAIT> が指定された。"
3445 #: build/C/man2/msgop.2:382
3447 "While the process was sleeping to receive a message, the message queue was "
3450 "メッセージを受信するためにプロセスが停止している間に、 メッセージ・キューが削"
3454 #: build/C/man2/msgop.2:387
3456 "While the process was sleeping to receive a message, the process caught a "
3457 "signal; see B<signal>(7)."
3459 "メッセージを受けるためにプロセスが停止している間に、 プロセスがシグナルを捕獲"
3460 "した。 B<signal>(7) 参照。"
3463 #: build/C/man2/msgop.2:393
3464 msgid "I<msgqid> was invalid, or I<msgsz> was less than 0."
3465 msgstr "I<msgqid> が不正か、 I<msgsz> が 0 より小さい。"
3468 #: build/C/man2/msgop.2:393
3474 #: build/C/man2/msgop.2:399
3476 "B<IPC_NOWAIT> was specified in I<msgflg> and no message of the requested "
3477 "type existed on the message queue."
3479 "I<msgflg> に B<IPC_NOWAIT> が設定されており、 メッセージ・キューに要求された"
3483 #: build/C/man2/msgop.2:421
3485 "The I<msgp> argument is declared as I<struct msgbuf *> with libc4, libc5, "
3486 "glibc 2.0, glibc 2.1. It is declared as I<void *> with glibc 2.2 and later, "
3487 "as required by SUSv2 and SUSv3."
3489 "I<msgp> 引き数は、 libc4, libc5, glibc 2.0, glibc 2.1 では I<struct msgbuf "
3490 "*> と宣言されている。glibc 2.2 以降では、 SUSv2 と SUSv3 の要求通り、I<void "
3494 #: build/C/man2/msgop.2:425
3496 "The following limits on message queue resources affect the B<msgsnd>() call:"
3497 msgstr "以下は B<msgsnd> システムコールに影響するシステム制限である:"
3500 #: build/C/man2/msgop.2:425
3506 #: build/C/man2/msgop.2:430
3508 "Maximum size for a message text: 8192 bytes (on Linux, this limit can be "
3509 "read and modified via I</proc/sys/kernel/msgmax>)."
3511 "メッセージのテキストの最大サイズ: 8192 バイト (Linux では、この制限値は I</"
3512 "proc/sys/kernel/msgmax> 経由で読み出したり変更したりできる)。"
3515 #: build/C/man2/msgop.2:430
3521 #: build/C/man2/msgop.2:440
3523 "Default maximum size in bytes of a message queue: 16384 bytes (on Linux, "
3524 "this limit can be read and modified via I</proc/sys/kernel/msgmnb>). The "
3525 "superuser can increase the size of a message queue beyond B<MSGMNB> by a "
3526 "B<msgctl>(2) system call."
3528 "バイト単位でのメッセージ・キューのデフォルトの最大サイズ : 16384 バイト。 "
3529 "(Linux では、この制限値は I</proc/sys/kernel/msgmnb> 経由で読み出したり変更し"
3530 "たりできる)。 スーパーユーザーは B<msgctl>(2) システムコールでメッセージ・"
3531 "キューのサイズを B<MSGMNB> よりも大きい値に増やすことができる。"
3534 #: build/C/man2/msgop.2:446
3536 "The implementation has no intrinsic limits for the system wide maximum "
3537 "number of message headers (B<MSGTQL>) and for the system wide maximum size "
3538 "in bytes of the message pool (B<MSGPOOL>)."
3540 "現在の実装では、システム全体のメッセージ・ヘッダーの最大数 (B<MSGTQL>) と、"
3541 "システム全体のメッセージ・プールの最大バイト数 (B<MSGPOOL>) に関して実装依存"
3545 #: build/C/man2/msgop.2:452
3547 "B<msgctl>(2), B<msgget>(2), B<capabilities>(7), B<mq_overview>(7), B<svipc>"
3550 "B<msgctl>(2), B<msgget>(2), B<capabilities>(7), B<mq_overview>(7), B<svipc>"
3553 #~ msgid "2008-08-06"
3554 #~ msgstr "2008-08-06"
3556 #~ msgid "2008-04-23"
3557 #~ msgstr "2008-04-23"