-
-
Notifications
You must be signed in to change notification settings - Fork 23
Expand file tree
/
Copy pathasyncio-queue.po
More file actions
482 lines (431 loc) · 21.8 KB
/
asyncio-queue.po
File metadata and controls
482 lines (431 loc) · 21.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2001-2024, Python Software Foundation
# This file is distributed under the same license as the Python package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: Python 3.12\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-12-04 09:48+0200\n"
"PO-Revision-Date: 2025-05-05 22:16+0300\n"
"Last-Translator: Marios Giannopoulos <mariosgian_2002@yahoo.gr>\n"
"Language-Team: PyGreece <organizers@pygreece.org>\n"
"Language: el\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
#: library/asyncio-queue.rst:7
msgid "Queues"
msgstr "Ουρές"
#: library/asyncio-queue.rst:9
msgid "**Source code:** :source:`Lib/asyncio/queues.py`"
msgstr "**Πηγαίος κώδικας:** :source:`Lib/asyncio/queues.py`"
#: library/asyncio-queue.rst:13
msgid ""
"asyncio queues are designed to be similar to classes of the :mod:`queue` "
"module. Although asyncio queues are not thread-safe, they are designed to "
"be used specifically in async/await code."
msgstr ""
"Οι ουρές asyncio έχουν σχεδιαστεί ώστε να μοιάζουν με τις κλάσεις του "
"module :mod:`queue`. Αν και οι ουρές asyncio δεν είναι ασφαλείς για χρήση "
"με νήματα (thread-safe), έχουν σχεδιαστεί για να χρησιμοποιούνται "
"συγκεκριμένα σε κώδικα async/await."
#: library/asyncio-queue.rst:17
msgid ""
"Note that methods of asyncio queues don't have a *timeout* parameter; use :"
"func:`asyncio.wait_for` function to do queue operations with a timeout."
msgstr ""
"Σημειώστε ότι οι μέθοδοι των ουρών asyncio δεν διαθέτουν παράμετρο "
"*timeout*. Χρησιμοποιήστε την συνάρτηση :func:`asyncio.wait_for` για να "
"εκτελέσετε λειτουργίες ουράς με χρονικό όριο."
#: library/asyncio-queue.rst:21
msgid "See also the `Examples`_ section below."
msgstr "Δείτε επίσης την ενότητα `Examples`_ παρακάτω."
#: library/asyncio-queue.rst:24
msgid "Queue"
msgstr "Ουρά"
#: library/asyncio-queue.rst:28
msgid "A first in, first out (FIFO) queue."
msgstr "Μια ουρά τύπου πρώτος που εισέρχεται, πρώτος που εξέρχεται (FIFO)."
#: library/asyncio-queue.rst:30
msgid ""
"If *maxsize* is less than or equal to zero, the queue size is infinite. If "
"it is an integer greater than ``0``, then ``await put()`` blocks when the "
"queue reaches *maxsize* until an item is removed by :meth:`get`."
msgstr ""
"Αν η τιμή του *maxsize* είναι λιγότερη ή ίση με το μηδέν, το μέγεθος της "
"ουράς είναι άπειρο. Αν είναι ένας ακέραιος μεγαλύτερος από το ``0``, τότε η "
"εντολή ``await put()`` μπλοκάρει, όταν η ουρά φτάσει το *maxsize* μέχρι να "
"αφαιρεθεί ένα στοιχείο μέσω της μεθόδου :meth:`get`."
#: library/asyncio-queue.rst:35
msgid ""
"Unlike the standard library threading :mod:`queue`, the size of the queue is "
"always known and can be returned by calling the :meth:`qsize` method."
msgstr ""
"Σε αντίθεση με την ουρά του :mod:`queue` στην βιβλιοθήκη threading, το "
"μέγεθος της ουράς είναι πάντα γνωστό και μπορεί να επιστραφεί καλώντας τη "
"μέθοδο :meth:`qsize`."
#: library/asyncio-queue.rst:39
msgid "Removed the *loop* parameter."
msgstr "Αφαιρέθηκε η παράμετρος *loop*."
#: library/asyncio-queue.rst:43
msgid "This class is :ref:`not thread safe <asyncio-multithreading>`."
msgstr "Αυτή η κλάση είναι :ref:`not thread safe <asyncio-multithreading>`."
#: library/asyncio-queue.rst:47
msgid "Number of items allowed in the queue."
msgstr "Αριθμός στοιχείων που επιτρέπονται στην ουρά."
#: library/asyncio-queue.rst:51
msgid "Return ``True`` if the queue is empty, ``False`` otherwise."
msgstr "Επιστρέφει ``True`` αν η ουρά είναι άδεια, διαφορετικά ``False``."
#: library/asyncio-queue.rst:55
msgid "Return ``True`` if there are :attr:`maxsize` items in the queue."
msgstr "Επιστρέφει ``True`` αν υπάρχουν :attr:`maxsize` αντικείμενα στην ουρά."
#: library/asyncio-queue.rst:57
msgid ""
"If the queue was initialized with ``maxsize=0`` (the default), then :meth:"
"`full` never returns ``True``."
msgstr ""
"Αν η ουρά αρχικοποιήθηκε με ``maxsize=0`` (προεπιλογή), τότε η :meth:`full` "
"δεν επιστρέφει ποτέ ``True``."
#: library/asyncio-queue.rst:63
msgid ""
"Remove and return an item from the queue. If queue is empty, wait until an "
"item is available."
msgstr ""
"Αφαίρεση και επιστροφή ενός αντικειμένου από την ουρά. Αν η ουρά είναι κενή, "
"περιμένετε μέχρι να είναι διαθέσιμο ένα αντικείμενο."
#: library/asyncio-queue.rst:66
msgid ""
"Raises :exc:`QueueShutDown` if the queue has been shut down and is empty, or "
"if the queue has been shut down immediately."
msgstr ""
"Κάνει raise μια :exc:`QueueShutDown` αν η ουρά έχει τερματιστεί και είναι "
"κενή, ή αν η ουρά έχει τερματιστεί άμεσα."
#: library/asyncio-queue.rst:71
msgid ""
"Return an item if one is immediately available, else raise :exc:`QueueEmpty`."
msgstr ""
"Επιστρέφει ένα αντικείμενο, αν είναι άμεσα διαθέσιμο, αλλιώς κάνε raise την :"
"exc:`QueueEmpty`."
#: library/asyncio-queue.rst:77
msgid "Block until all items in the queue have been received and processed."
msgstr ""
"Αποκλείει μέχρι να ληφθούν και να υποβληθούν σε επεξεργασία όλα τα στοιχεία "
"στην ουρά."
#: library/asyncio-queue.rst:79
msgid ""
"The count of unfinished tasks goes up whenever an item is added to the "
"queue. The count goes down whenever a consumer coroutine calls :meth:"
"`task_done` to indicate that the item was retrieved and all work on it is "
"complete. When the count of unfinished tasks drops to zero, :meth:`join` "
"unblocks."
msgstr ""
"Ο αριθμός των ημιτελών εργασιών αυξάνεται κάθε φορά που προστίθεται ένα "
"αντικείμενο στην ουρά. Ο αριθμός μειώνεται όταν μια καταναλωτική coroutine "
"καλεί τη μέθοδο :meth:`task_done` για να υποδείξει ότι το αντικείμενο "
"λήφθηκε και η εργασία πάνω του έχει ολοκληρωθεί. Όταν ο αριθμός των "
"ατελείωτων εργασιών μειωθεί στο μηδέν, η μέθοδος :meth:`join` αποδεσμεύεται."
#: library/asyncio-queue.rst:88
msgid ""
"Put an item into the queue. If the queue is full, wait until a free slot is "
"available before adding the item."
msgstr ""
"Τοποθετεί ένα αντικείμενο στην ουρά. Αν η ουρά είναι γεμάτη, περιμένετε "
"μέχρι να είναι διαθέσιμη μια ελεύθερη θέση, πριν προσθέσετε το αντικείμενο."
#: library/asyncio-queue.rst:91
msgid "Raises :exc:`QueueShutDown` if the queue has been shut down."
msgstr "Κάνει raise μια :exc:`QueueShutDown` αν η ουρά έχει τερματιστεί."
#: library/asyncio-queue.rst:95
msgid "Put an item into the queue without blocking."
msgstr "Τοποθετεί ένα αντικείμενο στην ουρά χωρίς να μπλοκάρει."
#: library/asyncio-queue.rst:97
msgid "If no free slot is immediately available, raise :exc:`QueueFull`."
msgstr ""
"Αν δεν είναι διαθέσιμη μια ελεύθερη θέση αμέσως, γίνεται raise η :exc:"
"`QueueFull`."
#: library/asyncio-queue.rst:101
msgid "Return the number of items in the queue."
msgstr "Επιστρέφει τον αριθμό των αντικειμένων στην ουρά."
#: library/asyncio-queue.rst:105
msgid "Put a :class:`Queue` instance into a shutdown mode."
msgstr "Βάζει ένα στιγμιότυπο της :class:`Queue` σε λειτουργία τερματισμού."
#: library/asyncio-queue.rst:107
msgid ""
"The queue can no longer grow. Future calls to :meth:`~Queue.put` raise :exc:"
"`QueueShutDown`. Currently blocked callers of :meth:`~Queue.put` will be "
"unblocked and will raise :exc:`QueueShutDown` in the formerly blocked thread."
msgstr ""
"Η ουρά δεν μπορεί πλέον να μεγαλώσει. Μελλοντικές κλήσεις της :meth:`~Queue."
"put` κάνουν raise την :exc:`QueueShutDown`. Οι τρέχοντες αποκλεισμένοι "
"καλούντες της :meth:`~Queue.put` θα αποδεσμευτούν και θα κάνουν raise την :"
"exc:`QueueShutDown` στο προηγουμένως αποκλεισμένο νήμα."
#: library/asyncio-queue.rst:112
msgid ""
"If *immediate* is false (the default), the queue can be wound down normally "
"with :meth:`~Queue.get` calls to extract tasks that have already been loaded."
msgstr ""
"Αν το *immediate* είναι false (η προεπιλογή), η ουρά μπορεί να τερματιστεί "
"κανονικά με κλήσεις της :meth:`~Queue.get` για να εξαχθούν εργασίες που "
"έχουν ήδη φορτωθεί."
#: library/asyncio-queue.rst:116
msgid ""
"And if :meth:`~Queue.task_done` is called for each remaining task, a "
"pending :meth:`~Queue.join` will be unblocked normally."
msgstr ""
"Και αν η :meth:`~Queue.task_done` κληθεί για κάθε υπόλοιπη εργασία, μια "
"εκκρεμής :meth:`~Queue.join` θα αποδεσμευτεί κανονικά."
#: library/asyncio-queue.rst:119
msgid ""
"Once the queue is empty, future calls to :meth:`~Queue.get` will raise :exc:"
"`QueueShutDown`."
msgstr ""
"Μόλις η ουρά είναι κενή, μελλοντικές κλήσεις της :meth:`~Queue.get` θα "
"κάνουν raise την :exc:`QueueShutDown`."
#: library/asyncio-queue.rst:122
msgid ""
"If *immediate* is true, the queue is terminated immediately. The queue is "
"drained to be completely empty and the count of unfinished tasks is reduced "
"by the number of tasks drained. If unfinished tasks is zero, callers of :"
"meth:`~Queue.join` are unblocked. Also, blocked callers of :meth:`~Queue."
"get` are unblocked and will raise :exc:`QueueShutDown` because the queue is "
"empty."
msgstr ""
"Αν το *immediate* είναι true, η ουρά τερματίζεται αμέσως. Η ουρά αδειάζει "
"για να είναι εντελώς κενή και ο αριθμός των ημιτελών εργασιών μειώνεται κατά "
"τον αριθμό των εργασιών που αδειάστηκαν. Αν οι ημιτελείς εργασίες είναι "
"μηδέν, οι καλούντες της :meth:`~Queue.join` αποδεσμεύονται. Επίσης, οι "
"αποκλεισμένοι καλούντες της :meth:`~Queue.get` αποδεσμεύονται και θα κάνουν "
"raise την :exc:`QueueShutDown` επειδή η ουρά είναι κενή."
#: library/asyncio-queue.rst:130
msgid ""
"Use caution when using :meth:`~Queue.join` with *immediate* set to true. "
"This unblocks the join even when no work has been done on the tasks, "
"violating the usual invariant for joining a queue."
msgstr ""
"Χρησιμοποιήστε προσοχή όταν χρησιμοποιείτε την :meth:`~Queue.join` με το "
"*immediate* ορισμένο σε αληθές. Αυτό αποδεσμεύει την ένωση ακόμη και όταν "
"δεν έχει γίνει καμία εργασία στις εργασίες, παραβιάζοντας το συνηθισμένο "
"αμετάβλητο για την ένωση μιας ουράς."
#: library/asyncio-queue.rst:138
msgid "Indicate that a formerly enqueued work item is complete."
msgstr ""
"Υποδεικνύει ότι μια εργασία που είχε προστεθεί στην ουρά έχει ολοκληρωθεί."
#: library/asyncio-queue.rst:140
msgid ""
"Used by queue consumers. For each :meth:`~Queue.get` used to fetch a work "
"item, a subsequent call to :meth:`task_done` tells the queue that the "
"processing on the work item is complete."
msgstr ""
"Χρησιμοποιείται από τους καταναλωτές της ουράς. Για κάθε κλήση της :meth:"
"`~Queue.get` για να ανακτηθεί μια εργασία, μια επακόλουθη κλήση της :meth:"
"`task_done` ενημερώνει την ουρά ότι η επεξεργασία της εργασίας έχει "
"ολοκληρωθεί."
#: library/asyncio-queue.rst:144
msgid ""
"If a :meth:`join` is currently blocking, it will resume when all items have "
"been processed (meaning that a :meth:`task_done` call was received for every "
"item that had been :meth:`~Queue.put` into the queue)."
msgstr ""
"Εάν μια κλήση της :meth:`join` μπλοκάρει αυτή την στιγμή, θα συνεχιστεί όταν "
"όλα τα αντικείμενα έχουν επεξεργαστεί (σημαίνει ότι λήφθηκε μια κλήση της :"
"meth:`task_done` για κάθε αντικείμενο που είχε προστεθεί με :meth:`~Queue."
"put` στην ουρά)."
#: library/asyncio-queue.rst:149
msgid ""
"Raises :exc:`ValueError` if called more times than there were items placed "
"in the queue."
msgstr ""
"Κάνει raise την :exc:`ValueError` εάν κληθεί περισσότερες φορές από όσες τα "
"αντικείμενα που είχαν τοποθετηθεί στην ουρά."
#: library/asyncio-queue.rst:154
msgid "Priority Queue"
msgstr "Σειρά Προτεραιότητας"
#: library/asyncio-queue.rst:158
msgid ""
"A variant of :class:`Queue`; retrieves entries in priority order (lowest "
"first)."
msgstr ""
"Μια παραλλαγή της :class:`Queue`; η οποία ανακτά τις καταχωρήσεις με σειρά "
"προτεραιότητας (οι χαμηλότερες πρώτες)."
#: library/asyncio-queue.rst:161
msgid "Entries are typically tuples of the form ``(priority_number, data)``."
msgstr "Οι καταχωρήσεις είναι συνήθως της μορφής ``(priority_number, data)``."
#: library/asyncio-queue.rst:166
msgid "LIFO Queue"
msgstr "Ουρά LIFO"
#: library/asyncio-queue.rst:170
msgid ""
"A variant of :class:`Queue` that retrieves most recently added entries first "
"(last in, first out)."
msgstr ""
"Μια παραλλαγή της κλάσης :class:`Queue` που ανακτά τις πιο πρόσφατα "
"προστιθέμενες καταχωρίσεις πρώτες (με τη λογική τελευταίος μέσα, πρώτος έξω)."
#: library/asyncio-queue.rst:175
msgid "Exceptions"
msgstr "Εξαιρέσεις"
#: library/asyncio-queue.rst:179
msgid ""
"This exception is raised when the :meth:`~Queue.get_nowait` method is called "
"on an empty queue."
msgstr ""
"Αυτή η εξαίρεση γίνεται raise όταν η μέθοδος :meth:`~Queue.get_nowait` "
"καλείται σε μια άδεια ουρά."
#: library/asyncio-queue.rst:185
msgid ""
"Exception raised when the :meth:`~Queue.put_nowait` method is called on a "
"queue that has reached its *maxsize*."
msgstr ""
"Εξαίρεση που γίνεται raise όταν η μέθοδος :meth:`~Queue.put_nowait` καλείται "
"σε μια ουρά που έχει φτάσει στο *maxsize* της."
#: library/asyncio-queue.rst:191
msgid ""
"Exception raised when :meth:`~Queue.put` or :meth:`~Queue.get` is called on "
"a queue which has been shut down."
msgstr ""
"Εξαίρεση που γίνεται raise όταν η μέθοδος :meth:`~Queue.put` ή :meth:`~Queue."
"get` καλείται σε μια ουρά που έχει τερματιστεί."
#: library/asyncio-queue.rst:198
msgid "Examples"
msgstr "Παραδείγματα"
#: library/asyncio-queue.rst:202
msgid ""
"Queues can be used to distribute workload between several concurrent tasks::"
msgstr ""
"Οι ουρές μπορούν να χρησιμοποιηθούν για τη διανομή εργασίας μεταξύ αρκετών "
"παράλληλων εργασιών::"
#: library/asyncio-queue.rst:205
msgid ""
"import asyncio\n"
"import random\n"
"import time\n"
"\n"
"\n"
"async def worker(name, queue):\n"
" while True:\n"
" # Get a \"work item\" out of the queue.\n"
" sleep_for = await queue.get()\n"
"\n"
" # Sleep for the \"sleep_for\" seconds.\n"
" await asyncio.sleep(sleep_for)\n"
"\n"
" # Notify the queue that the \"work item\" has been processed.\n"
" queue.task_done()\n"
"\n"
" print(f'{name} has slept for {sleep_for:.2f} seconds')\n"
"\n"
"\n"
"async def main():\n"
" # Create a queue that we will use to store our \"workload\".\n"
" queue = asyncio.Queue()\n"
"\n"
" # Generate random timings and put them into the queue.\n"
" total_sleep_time = 0\n"
" for _ in range(20):\n"
" sleep_for = random.uniform(0.05, 1.0)\n"
" total_sleep_time += sleep_for\n"
" queue.put_nowait(sleep_for)\n"
"\n"
" # Create three worker tasks to process the queue concurrently.\n"
" tasks = []\n"
" for i in range(3):\n"
" task = asyncio.create_task(worker(f'worker-{i}', queue))\n"
" tasks.append(task)\n"
"\n"
" # Wait until the queue is fully processed.\n"
" started_at = time.monotonic()\n"
" await queue.join()\n"
" total_slept_for = time.monotonic() - started_at\n"
"\n"
" # Cancel our worker tasks.\n"
" for task in tasks:\n"
" task.cancel()\n"
" # Wait until all worker tasks are cancelled.\n"
" await asyncio.gather(*tasks, return_exceptions=True)\n"
"\n"
" print('====')\n"
" print(f'3 workers slept in parallel for {total_slept_for:.2f} seconds')\n"
" print(f'total expected sleep time: {total_sleep_time:.2f} seconds')\n"
"\n"
"\n"
"asyncio.run(main())"
msgstr ""
"import asyncio\n"
"import random\n"
"import time\n"
"\n"
"\n"
"async def worker(name, queue):\n"
" while True:\n"
" # Get a \"work item\" out of the queue.\n"
" sleep_for = await queue.get()\n"
"\n"
" # Sleep for the \"sleep_for\" seconds.\n"
" await asyncio.sleep(sleep_for)\n"
"\n"
" # Notify the queue that the \"work item\" has been processed.\n"
" queue.task_done()\n"
"\n"
" print(f'{name} has slept for {sleep_for:.2f} seconds')\n"
"\n"
"\n"
"async def main():\n"
" # Create a queue that we will use to store our \"workload\".\n"
" queue = asyncio.Queue()\n"
"\n"
" # Generate random timings and put them into the queue.\n"
" total_sleep_time = 0\n"
" for _ in range(20):\n"
" sleep_for = random.uniform(0.05, 1.0)\n"
" total_sleep_time += sleep_for\n"
" queue.put_nowait(sleep_for)\n"
"\n"
" # Create three worker tasks to process the queue concurrently.\n"
" tasks = []\n"
" for i in range(3):\n"
" task = asyncio.create_task(worker(f'worker-{i}', queue))\n"
" tasks.append(task)\n"
"\n"
" # Wait until the queue is fully processed.\n"
" started_at = time.monotonic()\n"
" await queue.join()\n"
" total_slept_for = time.monotonic() - started_at\n"
"\n"
" # Cancel our worker tasks.\n"
" for task in tasks:\n"
" task.cancel()\n"
" # Wait until all worker tasks are cancelled.\n"
" await asyncio.gather(*tasks, return_exceptions=True)\n"
"\n"
" print('====')\n"
" print(f'3 workers slept in parallel for {total_slept_for:.2f} seconds')\n"
" print(f'total expected sleep time: {total_sleep_time:.2f} seconds')\n"
"\n"
"\n"
"asyncio.run(main())"
#~ msgid ""
#~ "By default, :meth:`~Queue.get` on a shut down queue will only raise once "
#~ "the queue is empty. Set *immediate* to true to make :meth:`~Queue.get` "
#~ "raise immediately instead."
#~ msgstr ""
#~ "Από προεπιλογή, η :meth:`~Queue.get` σε μια τερματισμένη ουρά θα κάνει "
#~ "raise εξαίρεση μόνο όταν η ουρά είναι κενή. Ορίστε το *immediate* σε true "
#~ "για να κάνετε την :meth:`~Queue.get` να εξάγει την εξαίρεση αμέσως αντί "
#~ "για αργότερα."
#~ msgid ""
#~ "All blocked callers of :meth:`~Queue.put` and :meth:`~Queue.get` will be "
#~ "unblocked. If *immediate* is true, a task will be marked as done for each "
#~ "remaining item in the queue, which may unblock callers of :meth:`~Queue."
#~ "join`."
#~ msgstr ""
#~ "Όλοι οι αποκλεισμένοι καλούντες των :meth:`~Queue.put` και :meth:`~Queue."
#~ "get` θα αποδεσμευτούν. Αν το *immediate* είναι αληθές, μια εργασία θα "
#~ "χαρακτηριστεί ως ολοκληρωμένη για κάθε εναπομείναν αντικείμενο στην ουρά, "
#~ "το οποίο μπορεί να αποδεσμευτεί στους καλούντες της :meth:`~Queue.join`."
#~ msgid ""
#~ "``shutdown(immediate=True)`` calls :meth:`task_done` for each remaining "
#~ "item in the queue."
#~ msgstr ""
#~ "Το ``shutdown(immediate=True)`` καλεί τη :meth:`task_done` για κάθε "
#~ "υπόλοιπο στοιχείο στην ουρά."