-
-
Notifications
You must be signed in to change notification settings - Fork 403
Expand file tree
/
Copy pathannotationlib.po
More file actions
985 lines (844 loc) · 34.5 KB
/
annotationlib.po
File metadata and controls
985 lines (844 loc) · 34.5 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
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2001 Python Software Foundation
# This file is distributed under the same license as the Python en Español
# package.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2026.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: Python en Español 3.14\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2026-02-26 18:44-0300\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language: es\n"
"Language-Team: es <LL@li.org>\n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Generated-By: Babel 2.18.0\n"
#: ../Doc/library/annotationlib.rst:2
msgid ":mod:`!annotationlib` --- Functionality for introspecting annotations"
msgstr ""
#: ../Doc/library/annotationlib.rst:9
msgid "**Source code:** :source:`Lib/annotationlib.py`"
msgstr ""
#: ../Doc/library/annotationlib.rst:18
msgid ""
"The :mod:`!annotationlib` module provides tools for introspecting :term:"
"`annotations <annotation>` on modules, classes, and functions."
msgstr ""
#: ../Doc/library/annotationlib.rst:21
msgid ""
"Annotations are :ref:`lazily evaluated <lazy-evaluation>` and often contain "
"forward references to objects that are not yet defined when the annotation "
"is created. This module provides a set of low-level tools that can be used "
"to retrieve annotations in a reliable way, even in the presence of forward "
"references and other edge cases."
msgstr ""
#: ../Doc/library/annotationlib.rst:26
msgid ""
"This module supports retrieving annotations in three main formats (see :"
"class:`Format`), each of which works best for different use cases:"
msgstr ""
#: ../Doc/library/annotationlib.rst:29
msgid ""
":attr:`~Format.VALUE` evaluates the annotations and returns their value. "
"This is most straightforward to work with, but it may raise errors, for "
"example if the annotations contain references to undefined names."
msgstr ""
#: ../Doc/library/annotationlib.rst:32
msgid ""
":attr:`~Format.FORWARDREF` returns :class:`ForwardRef` objects for "
"annotations that cannot be resolved, allowing you to inspect the annotations "
"without evaluating them. This is useful when you need to work with "
"annotations that may contain unresolved forward references."
msgstr ""
#: ../Doc/library/annotationlib.rst:36
msgid ""
":attr:`~Format.STRING` returns the annotations as a string, similar to how "
"it would appear in the source file. This is useful for documentation "
"generators that want to display annotations in a readable way."
msgstr ""
#: ../Doc/library/annotationlib.rst:40
msgid ""
"The :func:`get_annotations` function is the main entry point for retrieving "
"annotations. Given a function, class, or module, it returns an annotations "
"dictionary in the requested format. This module also provides functionality "
"for working directly with the :term:`annotate function` that is used to "
"evaluate annotations, such as :func:`get_annotate_from_class_namespace` and :"
"func:`call_annotate_function`, as well as the :func:`call_evaluate_function` "
"function for working with :term:`evaluate functions <evaluate function>`."
msgstr ""
#: ../Doc/library/annotationlib.rst:51
msgid ""
"Most functionality in this module can execute arbitrary code; see :ref:`the "
"security section <annotationlib-security>` for more information."
msgstr ""
#: ../Doc/library/annotationlib.rst:56
msgid ""
":pep:`649` proposed the current model for how annotations work in Python."
msgstr ""
#: ../Doc/library/annotationlib.rst:58
msgid ""
":pep:`749` expanded on various aspects of :pep:`649` and introduced the :mod:"
"`!annotationlib` module."
msgstr ""
#: ../Doc/library/annotationlib.rst:61
msgid ""
":ref:`annotations-howto` provides best practices for working with "
"annotations."
msgstr ""
#: ../Doc/library/annotationlib.rst:64
msgid ""
":pypi:`typing-extensions` provides a backport of :func:`get_annotations` "
"that works on earlier versions of Python."
msgstr ""
#: ../Doc/library/annotationlib.rst:68
msgid "Annotation semantics"
msgstr ""
#: ../Doc/library/annotationlib.rst:70
msgid ""
"The way annotations are evaluated has changed over the history of Python 3, "
"and currently still depends on a :ref:`future import <future>`. There have "
"been execution models for annotations:"
msgstr ""
#: ../Doc/library/annotationlib.rst:74
msgid ""
"*Stock semantics* (default in Python 3.0 through 3.13; see :pep:`3107` and :"
"pep:`526`): Annotations are evaluated eagerly, as they are encountered in "
"the source code."
msgstr ""
#: ../Doc/library/annotationlib.rst:77
msgid ""
"*Stringified annotations* (used with ``from __future__ import annotations`` "
"in Python 3.7 and newer; see :pep:`563`): Annotations are stored as strings "
"only."
msgstr ""
#: ../Doc/library/annotationlib.rst:80
msgid ""
"*Deferred evaluation* (default in Python 3.14 and newer; see :pep:`649` and :"
"pep:`749`): Annotations are evaluated lazily, only when they are accessed."
msgstr ""
#: ../Doc/library/annotationlib.rst:83
msgid "As an example, consider the following program::"
msgstr ""
#: ../Doc/library/annotationlib.rst:85
msgid ""
"def func(a: Cls) -> None:\n"
" print(a)\n"
"\n"
"class Cls: pass\n"
"\n"
"print(func.__annotations__)"
msgstr ""
#: ../Doc/library/annotationlib.rst:92
msgid "This will behave as follows:"
msgstr ""
#: ../Doc/library/annotationlib.rst:94
msgid ""
"Under stock semantics (Python 3.13 and earlier), it will throw a :exc:"
"`NameError` at the line where ``func`` is defined, because ``Cls`` is an "
"undefined name at that point."
msgstr ""
#: ../Doc/library/annotationlib.rst:97
#, python-brace-format
msgid ""
"Under stringified annotations (if ``from __future__ import annotations`` is "
"used), it will print ``{'a': 'Cls', 'return': 'None'}``."
msgstr ""
#: ../Doc/library/annotationlib.rst:99
#, python-brace-format
msgid ""
"Under deferred evaluation (Python 3.14 and later), it will print ``{'a': "
"<class 'Cls'>, 'return': None}``."
msgstr ""
#: ../Doc/library/annotationlib.rst:102
msgid ""
"Stock semantics were used when function annotations were first introduced in "
"Python 3.0 (by :pep:`3107`) because this was the simplest, most obvious way "
"to implement annotations. The same execution model was used when variable "
"annotations were introduced in Python 3.6 (by :pep:`526`). However, stock "
"semantics caused problems when using annotations as type hints, such as a "
"need to refer to names that are not yet defined when the annotation is "
"encountered. In addition, there were performance problems with executing "
"annotations at module import time. Therefore, in Python 3.7, :pep:`563` "
"introduced the ability to store annotations as strings using the ``from "
"__future__ import annotations`` syntax. The plan at the time was to "
"eventually make this behavior the default, but a problem appeared: "
"stringified annotations are more difficult to process for those who "
"introspect annotations at runtime. An alternative proposal, :pep:`649`, "
"introduced the third execution model, deferred evaluation, and was "
"implemented in Python 3.14. Stringified annotations are still used if ``from "
"__future__ import annotations`` is present, but this behavior will "
"eventually be removed."
msgstr ""
#: ../Doc/library/annotationlib.rst:121
msgid "Classes"
msgstr ""
#: ../Doc/library/annotationlib.rst:125
msgid ""
"An :class:`~enum.IntEnum` describing the formats in which annotations can be "
"returned. Members of the enum, or their equivalent integer values, can be "
"passed to :func:`get_annotations` and other functions in this module, as "
"well as to :attr:`~object.__annotate__` functions."
msgstr ""
#: ../Doc/library/annotationlib.rst:133
msgid "Values are the result of evaluating the annotation expressions."
msgstr ""
#: ../Doc/library/annotationlib.rst:138
msgid ""
"Special value used to signal that an annotate function is being evaluated in "
"a special environment with fake globals. When passed this value, annotate "
"functions should either return the same value as for the :attr:`Format."
"VALUE` format, or raise :exc:`NotImplementedError` to signal that they do "
"not support execution in this environment. This format is only used "
"internally and should not be passed to the functions in this module."
msgstr ""
#: ../Doc/library/annotationlib.rst:149
msgid ""
"Values are real annotation values (as per :attr:`Format.VALUE` format) for "
"defined values, and :class:`ForwardRef` proxies for undefined values. Real "
"objects may contain references to :class:`ForwardRef` proxy objects."
msgstr ""
#: ../Doc/library/annotationlib.rst:157
msgid ""
"Values are the text string of the annotation as it appears in the source "
"code, up to modifications including, but not restricted to, whitespace "
"normalizations and constant values optimizations."
msgstr ""
#: ../Doc/library/annotationlib.rst:161
msgid ""
"The exact values of these strings may change in future versions of Python."
msgstr ""
#: ../Doc/library/annotationlib.rst:167
msgid "A proxy object for forward references in annotations."
msgstr ""
#: ../Doc/library/annotationlib.rst:169
msgid ""
"Instances of this class are returned when the :attr:`~Format.FORWARDREF` "
"format is used and annotations contain a name that cannot be resolved. This "
"can happen when a forward reference is used in an annotation, such as when a "
"class is referenced before it is defined."
msgstr ""
#: ../Doc/library/annotationlib.rst:176
msgid ""
"A string containing the code that was evaluated to produce the :class:"
"`~ForwardRef`. The string may not be exactly equivalent to the original "
"source."
msgstr ""
#: ../Doc/library/annotationlib.rst:182
msgid "Evaluate the forward reference, returning its value."
msgstr ""
#: ../Doc/library/annotationlib.rst:184
msgid ""
"If the *format* argument is :attr:`~Format.VALUE` (the default), this method "
"may throw an exception, such as :exc:`NameError`, if the forward reference "
"refers to a name that cannot be resolved. The arguments to this method can "
"be used to provide bindings for names that would otherwise be undefined. If "
"the *format* argument is :attr:`~Format.FORWARDREF`, the method will never "
"throw an exception, but may return a :class:`~ForwardRef` instance. For "
"example, if the forward reference object contains the code "
"``list[undefined]``, where ``undefined`` is a name that is not defined, "
"evaluating it with the :attr:`~Format.FORWARDREF` format will return "
"``list[ForwardRef('undefined')]``. If the *format* argument is :attr:"
"`~Format.STRING`, the method will return :attr:`~ForwardRef.__forward_arg__`."
msgstr ""
#: ../Doc/library/annotationlib.rst:196
msgid ""
"The *owner* parameter provides the preferred mechanism for passing scope "
"information to this method. The owner of a :class:`~ForwardRef` is the "
"object that contains the annotation from which the :class:`~ForwardRef` "
"derives, such as a module object, type object, or function object."
msgstr ""
#: ../Doc/library/annotationlib.rst:201
msgid ""
"The *globals*, *locals*, and *type_params* parameters provide a more precise "
"mechanism for influencing the names that are available when the :class:"
"`~ForwardRef` is evaluated. *globals* and *locals* are passed to :func:"
"`eval`, representing the global and local namespaces in which the name is "
"evaluated. The *type_params* parameter is relevant for objects created using "
"the native syntax for :ref:`generic classes <generic-classes>` and :ref:"
"`functions <generic-functions>`. It is a tuple of :ref:`type parameters "
"<type-params>` that are in scope while the forward reference is being "
"evaluated. For example, if evaluating a :class:`~ForwardRef` retrieved from "
"an annotation found in the class namespace of a generic class ``C``, "
"*type_params* should be set to ``C.__type_params__``."
msgstr ""
#: ../Doc/library/annotationlib.rst:212
msgid ""
":class:`~ForwardRef` instances returned by :func:`get_annotations` retain "
"references to information about the scope they originated from, so calling "
"this method with no further arguments may be sufficient to evaluate such "
"objects. :class:`~ForwardRef` instances created by other means may not have "
"any information about their scope, so passing arguments to this method may "
"be necessary to evaluate them successfully."
msgstr ""
#: ../Doc/library/annotationlib.rst:219
msgid ""
"If no *owner*, *globals*, *locals*, or *type_params* are provided and the :"
"class:`~ForwardRef` does not contain information about its origin, empty "
"globals and locals dictionaries are used."
msgstr ""
#: ../Doc/library/annotationlib.rst:227
msgid "Functions"
msgstr ""
#: ../Doc/library/annotationlib.rst:231
msgid ""
"Convert an annotations dict containing runtime values to a dict containing "
"only strings. If the values are not already strings, they are converted "
"using :func:`type_repr`. This is meant as a helper for user-provided "
"annotate functions that support the :attr:`~Format.STRING` format but do not "
"have access to the code creating the annotations."
msgstr ""
#: ../Doc/library/annotationlib.rst:238
msgid ""
"For example, this is used to implement the :attr:`~Format.STRING` for :class:"
"`typing.TypedDict` classes created through the functional syntax:"
msgstr ""
#: ../Doc/library/annotationlib.rst:241
#, python-brace-format
msgid ""
">>> from typing import TypedDict\n"
">>> Movie = TypedDict(\"movie\", {\"name\": str, \"year\": int})\n"
">>> get_annotations(Movie, format=Format.STRING)\n"
"{'name': 'str', 'year': 'int'}"
msgstr ""
#: ../Doc/library/annotationlib.rst:252
msgid ""
"Call the :term:`annotate function` *annotate* with the given *format*, a "
"member of the :class:`Format` enum, and return the annotations dictionary "
"produced by the function."
msgstr ""
#: ../Doc/library/annotationlib.rst:256
msgid ""
"This helper function is required because annotate functions generated by the "
"compiler for functions, classes, and modules only support the :attr:`~Format."
"VALUE` format when called directly. To support other formats, this function "
"calls the annotate function in a special environment that allows it to "
"produce annotations in the other formats. This is a useful building block "
"when implementing functionality that needs to partially evaluate annotations "
"while a class is being constructed."
msgstr ""
#: ../Doc/library/annotationlib.rst:265
msgid ""
"*owner* is the object that owns the annotation function, usually a function, "
"class, or module. If provided, it is used in the :attr:`~Format.FORWARDREF` "
"format to produce a :class:`ForwardRef` object that carries more information."
msgstr ""
#: ../Doc/library/annotationlib.rst:272
msgid ""
":PEP:`PEP 649 <649#the-stringizer-and-the-fake-globals-environment>` "
"contains an explanation of the implementation technique used by this "
"function."
msgstr ""
#: ../Doc/library/annotationlib.rst:280
msgid ""
"Call the :term:`evaluate function` *evaluate* with the given *format*, a "
"member of the :class:`Format` enum, and return the value produced by the "
"function. This is similar to :func:`call_annotate_function`, but the latter "
"always returns a dictionary mapping strings to annotations, while this "
"function returns a single value."
msgstr ""
#: ../Doc/library/annotationlib.rst:286
msgid ""
"This is intended for use with the evaluate functions generated for lazily "
"evaluated elements related to type aliases and type parameters:"
msgstr ""
#: ../Doc/library/annotationlib.rst:289
msgid ":meth:`typing.TypeAliasType.evaluate_value`, the value of type aliases"
msgstr ""
#: ../Doc/library/annotationlib.rst:290
msgid ":meth:`typing.TypeVar.evaluate_bound`, the bound of type variables"
msgstr ""
#: ../Doc/library/annotationlib.rst:291
msgid ""
":meth:`typing.TypeVar.evaluate_constraints`, the constraints of type "
"variables"
msgstr ""
#: ../Doc/library/annotationlib.rst:293
msgid ""
":meth:`typing.TypeVar.evaluate_default`, the default value of type variables"
msgstr ""
#: ../Doc/library/annotationlib.rst:295
msgid ""
":meth:`typing.ParamSpec.evaluate_default`, the default value of parameter "
"specifications"
msgstr ""
#: ../Doc/library/annotationlib.rst:297
msgid ""
":meth:`typing.TypeVarTuple.evaluate_default`, the default value of type "
"variable tuples"
msgstr ""
#: ../Doc/library/annotationlib.rst:300
msgid ""
"*owner* is the object that owns the evaluate function, such as the type "
"alias or type variable object."
msgstr ""
#: ../Doc/library/annotationlib.rst:303
msgid ""
"*format* can be used to control the format in which the value is returned:"
msgstr ""
#: ../Doc/library/annotationlib.rst:305
msgid ""
">>> type Alias = undefined\n"
">>> call_evaluate_function(Alias.evaluate_value, Format.VALUE)\n"
"Traceback (most recent call last):\n"
"...\n"
"NameError: name 'undefined' is not defined\n"
">>> call_evaluate_function(Alias.evaluate_value, Format.FORWARDREF)\n"
"ForwardRef('undefined')\n"
">>> call_evaluate_function(Alias.evaluate_value, Format.STRING)\n"
"'undefined'"
msgstr ""
#: ../Doc/library/annotationlib.rst:321
msgid ""
"Retrieve the :term:`annotate function` from a class namespace dictionary "
"*namespace*. Return :const:`!None` if the namespace does not contain an "
"annotate function. This is primarily useful before the class has been fully "
"created (e.g., in a metaclass); after the class exists, the annotate "
"function can be retrieved with ``cls.__annotate__``. See :ref:`below "
"<annotationlib-metaclass>` for an example using this function in a metaclass."
msgstr ""
#: ../Doc/library/annotationlib.rst:331
msgid "Compute the annotations dict for an object."
msgstr ""
#: ../Doc/library/annotationlib.rst:333
msgid ""
"*obj* may be a callable, class, module, or other object with :attr:`~object."
"__annotate__` or :attr:`~object.__annotations__` attributes. Passing any "
"other object raises :exc:`TypeError`."
msgstr ""
#: ../Doc/library/annotationlib.rst:337
msgid ""
"The *format* parameter controls the format in which annotations are "
"returned, and must be a member of the :class:`Format` enum or its integer "
"equivalent. The different formats work as follows:"
msgstr ""
#: ../Doc/library/annotationlib.rst:341
msgid ""
"VALUE: :attr:`!object.__annotations__` is tried first; if that does not "
"exist, the :attr:`!object.__annotate__` function is called if it exists."
msgstr ""
#: ../Doc/library/annotationlib.rst:343
msgid ""
"FORWARDREF: If :attr:`!object.__annotations__` exists and can be evaluated "
"successfully, it is used; otherwise, the :attr:`!object.__annotate__` "
"function is called. If it does not exist either, :attr:`!object."
"__annotations__` is tried again and any error from accessing it is re-raised."
msgstr ""
#: ../Doc/library/annotationlib.rst:347
msgid ""
"STRING: If :attr:`!object.__annotate__` exists, it is called first; "
"otherwise, :attr:`!object.__annotations__` is used and stringified using :"
"func:`annotations_to_string`."
msgstr ""
#: ../Doc/library/annotationlib.rst:351
msgid ""
"Returns a dict. :func:`!get_annotations` returns a new dict every time it's "
"called; calling it twice on the same object will return two different but "
"equivalent dicts."
msgstr ""
#: ../Doc/library/annotationlib.rst:355
msgid "This function handles several details for you:"
msgstr ""
#: ../Doc/library/annotationlib.rst:357
msgid ""
"If *eval_str* is true, values of type :class:`!str` will be un-stringized "
"using :func:`eval`. This is intended for use with stringized annotations "
"(``from __future__ import annotations``). It is an error to set *eval_str* "
"to true with formats other than :attr:`Format.VALUE`."
msgstr ""
#: ../Doc/library/annotationlib.rst:362
msgid ""
"If *obj* doesn't have an annotations dict, returns an empty dict. (Functions "
"and methods always have an annotations dict; classes, modules, and other "
"types of callables may not.)"
msgstr ""
#: ../Doc/library/annotationlib.rst:366
msgid ""
"Ignores inherited annotations on classes, as well as annotations on "
"metaclasses. If a class doesn't have its own annotations dict, returns an "
"empty dict."
msgstr ""
#: ../Doc/library/annotationlib.rst:369
msgid ""
"All accesses to object members and dict values are done using ``getattr()`` "
"and ``dict.get()`` for safety."
msgstr ""
#: ../Doc/library/annotationlib.rst:372
msgid ""
"*eval_str* controls whether or not values of type :class:`!str` are replaced "
"with the result of calling :func:`eval` on those values:"
msgstr ""
#: ../Doc/library/annotationlib.rst:375
msgid ""
"If eval_str is true, :func:`eval` is called on values of type :class:`!str`. "
"(Note that :func:`!get_annotations` doesn't catch exceptions; if :func:"
"`eval` raises an exception, it will unwind the stack past the :func:`!"
"get_annotations` call.)"
msgstr ""
#: ../Doc/library/annotationlib.rst:379
msgid ""
"If *eval_str* is false (the default), values of type :class:`!str` are "
"unchanged."
msgstr ""
#: ../Doc/library/annotationlib.rst:382
msgid ""
"*globals* and *locals* are passed in to :func:`eval`; see the documentation "
"for :func:`eval` for more information. If *globals* or *locals* is :const:`!"
"None`, this function may replace that value with a context-specific default, "
"contingent on ``type(obj)``:"
msgstr ""
#: ../Doc/library/annotationlib.rst:387
msgid "If *obj* is a module, *globals* defaults to ``obj.__dict__``."
msgstr ""
#: ../Doc/library/annotationlib.rst:388
msgid ""
"If *obj* is a class, *globals* defaults to ``sys.modules[obj.__module__]."
"__dict__`` and *locals* defaults to the *obj* class namespace."
msgstr ""
#: ../Doc/library/annotationlib.rst:391
msgid ""
"If *obj* is a callable, *globals* defaults to :attr:`obj.__globals__ "
"<function.__globals__>`, although if *obj* is a wrapped function (using :"
"func:`functools.update_wrapper`) or a :class:`functools.partial` object, it "
"is unwrapped until a non-wrapped function is found."
msgstr ""
#: ../Doc/library/annotationlib.rst:397
msgid ""
"Calling :func:`!get_annotations` is best practice for accessing the "
"annotations dict of any object. See :ref:`annotations-howto` for more "
"information on annotations best practices."
msgstr ""
#: ../Doc/library/annotationlib.rst:401
#, python-brace-format
msgid ""
">>> def f(a: int, b: str) -> float:\n"
"... pass\n"
">>> get_annotations(f)\n"
"{'a': <class 'int'>, 'b': <class 'str'>, 'return': <class 'float'>}"
msgstr ""
#: ../Doc/library/annotationlib.rst:412
msgid ""
"Convert an arbitrary Python value to a format suitable for use by the :attr:"
"`~Format.STRING` format. This calls :func:`repr` for most objects, but has "
"special handling for some objects, such as type objects."
msgstr ""
#: ../Doc/library/annotationlib.rst:416
msgid ""
"This is meant as a helper for user-provided annotate functions that support "
"the :attr:`~Format.STRING` format but do not have access to the code "
"creating the annotations. It can also be used to provide a user-friendly "
"string representation for other objects that contain values that are "
"commonly encountered in annotations."
msgstr ""
#: ../Doc/library/annotationlib.rst:426
msgid "Recipes"
msgstr ""
#: ../Doc/library/annotationlib.rst:431
msgid "Using annotations in a metaclass"
msgstr ""
#: ../Doc/library/annotationlib.rst:433
msgid ""
"A :ref:`metaclass <metaclasses>` may want to inspect or even modify the "
"annotations in a class body during class creation. Doing so requires "
"retrieving annotations from the class namespace dictionary. For classes "
"created with ``from __future__ import annotations``, the annotations will be "
"in the ``__annotations__`` key of the dictionary. For other classes with "
"annotations, :func:`get_annotate_from_class_namespace` can be used to get "
"the annotate function, and :func:`call_annotate_function` can be used to "
"call it and retrieve the annotations. Using the :attr:`~Format.FORWARDREF` "
"format will usually be best, because this allows the annotations to refer to "
"names that cannot yet be resolved when the class is created."
msgstr ""
#: ../Doc/library/annotationlib.rst:444
msgid ""
"To modify the annotations, it is best to create a wrapper annotate function "
"that calls the original annotate function, makes any necessary adjustments, "
"and returns the result."
msgstr ""
#: ../Doc/library/annotationlib.rst:448
msgid ""
"Below is an example of a metaclass that filters out all :class:`typing."
"ClassVar` annotations from the class and puts them in a separate attribute:"
msgstr ""
#: ../Doc/library/annotationlib.rst:451
#, python-brace-format
msgid ""
"import annotationlib\n"
"import typing\n"
"\n"
"class ClassVarSeparator(type):\n"
" def __new__(mcls, name, bases, ns):\n"
" if \"__annotations__\" in ns: # from __future__ import annotations\n"
" annotations = ns[\"__annotations__\"]\n"
" classvar_keys = {\n"
" key for key, value in annotations.items()\n"
" # Use string comparison for simplicity; a more robust solution\n"
" # could use annotationlib.ForwardRef.evaluate\n"
" if value.startswith(\"ClassVar\")\n"
" }\n"
" classvars = {key: annotations[key] for key in classvar_keys}\n"
" ns[\"__annotations__\"] = {\n"
" key: value for key, value in annotations.items()\n"
" if key not in classvar_keys\n"
" }\n"
" wrapped_annotate = None\n"
" elif annotate := annotationlib.get_annotate_from_class_namespace(ns):\n"
" annotations = annotationlib.call_annotate_function(\n"
" annotate, format=annotationlib.Format.FORWARDREF\n"
" )\n"
" classvar_keys = {\n"
" key for key, value in annotations.items()\n"
" if typing.get_origin(value) is typing.ClassVar\n"
" }\n"
" classvars = {key: annotations[key] for key in classvar_keys}\n"
"\n"
" def wrapped_annotate(format):\n"
" annos = annotationlib.call_annotate_function(annotate, format, "
"owner=typ)\n"
" return {key: value for key, value in annos.items() if key not in "
"classvar_keys}\n"
"\n"
" else: # no annotations\n"
" classvars = {}\n"
" wrapped_annotate = None\n"
" typ = super().__new__(mcls, name, bases, ns)\n"
"\n"
" if wrapped_annotate is not None:\n"
" # Wrap the original __annotate__ with a wrapper that removes "
"ClassVars\n"
" typ.__annotate__ = wrapped_annotate\n"
" typ.classvars = classvars # Store the ClassVars in a separate "
"attribute\n"
" return typ"
msgstr ""
#: ../Doc/library/annotationlib.rst:499
msgid "Limitations of the ``STRING`` format"
msgstr ""
#: ../Doc/library/annotationlib.rst:501
msgid ""
"The :attr:`~Format.STRING` format is meant to approximate the source code of "
"the annotation, but the implementation strategy used means that it is not "
"always possible to recover the exact source code."
msgstr ""
#: ../Doc/library/annotationlib.rst:505
msgid ""
"First, the stringifier of course cannot recover any information that is not "
"present in the compiled code, including comments, whitespace, "
"parenthesization, and operations that get simplified by the compiler."
msgstr ""
#: ../Doc/library/annotationlib.rst:509
msgid ""
"Second, the stringifier can intercept almost all operations that involve "
"names looked up in some scope, but it cannot intercept operations that "
"operate fully on constants. As a corollary, this also means it is not safe "
"to request the ``STRING`` format on untrusted code: Python is powerful "
"enough that it is possible to achieve arbitrary code execution even with no "
"access to any globals or builtins. For example:"
msgstr ""
#: ../Doc/library/annotationlib.rst:515
#, python-brace-format
msgid ""
">>> def f(x: (1).__class__.__base__.__subclasses__()[-1].__init__."
"__builtins__[\"print\"](\"Hello world\")): pass\n"
"...\n"
">>> annotationlib.get_annotations(f, format=annotationlib.Format.STRING)\n"
"Hello world\n"
"{'x': 'None'}"
msgstr ""
#: ../Doc/library/annotationlib.rst:524
msgid ""
"This particular example works as of the time of writing, but it relies on "
"implementation details and is not guaranteed to work in the future."
msgstr ""
#: ../Doc/library/annotationlib.rst:527
msgid ""
"Among the different kinds of expressions that exist in Python, as "
"represented by the :mod:`ast` module, some expressions are supported, "
"meaning that the ``STRING`` format can generally recover the original source "
"code; others are unsupported, meaning that they may result in incorrect "
"output or an error."
msgstr ""
#: ../Doc/library/annotationlib.rst:532
msgid "The following are supported (sometimes with caveats):"
msgstr ""
#: ../Doc/library/annotationlib.rst:534
msgid ":class:`ast.BinOp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:535
msgid ":class:`ast.UnaryOp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:537
msgid ""
":class:`ast.Invert` (``~``), :class:`ast.UAdd` (``+``), and :class:`ast."
"USub` (``-``) are supported"
msgstr ""
#: ../Doc/library/annotationlib.rst:538
msgid ":class:`ast.Not` (``not``) is not supported"
msgstr ""
#: ../Doc/library/annotationlib.rst:540
msgid ":class:`ast.Dict` (except when using ``**`` unpacking)"
msgstr ""
#: ../Doc/library/annotationlib.rst:541
msgid ":class:`ast.Set`"
msgstr ""
#: ../Doc/library/annotationlib.rst:542
msgid ":class:`ast.Compare`"
msgstr ""
#: ../Doc/library/annotationlib.rst:544
msgid ":class:`ast.Eq` and :class:`ast.NotEq` are supported"
msgstr ""
#: ../Doc/library/annotationlib.rst:545
msgid ""
":class:`ast.Lt`, :class:`ast.LtE`, :class:`ast.Gt`, and :class:`ast.GtE` are "
"supported, but the operand may be flipped"
msgstr ""
#: ../Doc/library/annotationlib.rst:546
msgid ""
":class:`ast.Is`, :class:`ast.IsNot`, :class:`ast.In`, and :class:`ast.NotIn` "
"are not supported"
msgstr ""
#: ../Doc/library/annotationlib.rst:548
msgid ":class:`ast.Call` (except when using ``**`` unpacking)"
msgstr ""
#: ../Doc/library/annotationlib.rst:549
msgid ""
":class:`ast.Constant` (though not the exact representation of the constant; "
"for example, escape sequences in strings are lost; hexadecimal numbers are "
"converted to decimal)"
msgstr ""
#: ../Doc/library/annotationlib.rst:551
msgid ":class:`ast.Attribute` (assuming the value is not a constant)"
msgstr ""
#: ../Doc/library/annotationlib.rst:552
msgid ":class:`ast.Subscript` (assuming the value is not a constant)"
msgstr ""
#: ../Doc/library/annotationlib.rst:553
msgid ":class:`ast.Starred` (``*`` unpacking)"
msgstr ""
#: ../Doc/library/annotationlib.rst:554
msgid ":class:`ast.Name`"
msgstr ""
#: ../Doc/library/annotationlib.rst:555
msgid ":class:`ast.List`"
msgstr ""
#: ../Doc/library/annotationlib.rst:556
msgid ":class:`ast.Tuple`"
msgstr ""
#: ../Doc/library/annotationlib.rst:557
msgid ":class:`ast.Slice`"
msgstr ""
#: ../Doc/library/annotationlib.rst:559
msgid ""
"The following are unsupported, but throw an informative error when "
"encountered by the stringifier:"
msgstr ""
#: ../Doc/library/annotationlib.rst:562
msgid ""
":class:`ast.FormattedValue` (f-strings; error is not detected if conversion "
"specifiers like ``!r`` are used)"
msgstr ""
#: ../Doc/library/annotationlib.rst:564
msgid ":class:`ast.JoinedStr` (f-strings)"
msgstr ""
#: ../Doc/library/annotationlib.rst:566
msgid "The following are unsupported and result in incorrect output:"
msgstr ""
#: ../Doc/library/annotationlib.rst:568
msgid ":class:`ast.BoolOp` (``and`` and ``or``)"
msgstr ""
#: ../Doc/library/annotationlib.rst:569
msgid ":class:`ast.IfExp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:570
msgid ":class:`ast.Lambda`"
msgstr ""
#: ../Doc/library/annotationlib.rst:571
msgid ":class:`ast.ListComp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:572
msgid ":class:`ast.SetComp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:573
msgid ":class:`ast.DictComp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:574
msgid ":class:`ast.GeneratorExp`"
msgstr ""
#: ../Doc/library/annotationlib.rst:576
msgid ""
"The following are disallowed in annotation scopes and therefore not relevant:"
msgstr ""
#: ../Doc/library/annotationlib.rst:578
msgid ":class:`ast.NamedExpr` (``:=``)"
msgstr ""
#: ../Doc/library/annotationlib.rst:579
msgid ":class:`ast.Await`"
msgstr ""
#: ../Doc/library/annotationlib.rst:580
msgid ":class:`ast.Yield`"
msgstr ""
#: ../Doc/library/annotationlib.rst:581
msgid ":class:`ast.YieldFrom`"
msgstr ""
#: ../Doc/library/annotationlib.rst:585
msgid "Limitations of the ``FORWARDREF`` format"
msgstr ""
#: ../Doc/library/annotationlib.rst:587
msgid ""
"The :attr:`~Format.FORWARDREF` format aims to produce real values as much as "
"possible, with anything that cannot be resolved replaced with :class:"
"`ForwardRef` objects. It is affected by broadly the same Limitations as the :"
"attr:`~Format.STRING` format: annotations that perform operations on "
"literals or that use unsupported expression types may raise exceptions when "
"evaluated using the :attr:`~Format.FORWARDREF` format."
msgstr ""
#: ../Doc/library/annotationlib.rst:594
msgid "Below are a few examples of the behavior with unsupported expressions:"
msgstr ""
#: ../Doc/library/annotationlib.rst:596
#, python-brace-format
msgid ""
">>> from annotationlib import get_annotations, Format\n"
">>> def zerodiv(x: 1 / 0): ...\n"
">>> get_annotations(zerodiv, format=Format.STRING)\n"
"Traceback (most recent call last):\n"
" ...\n"
"ZeroDivisionError: division by zero\n"
">>> get_annotations(zerodiv, format=Format.FORWARDREF)\n"
"Traceback (most recent call last):\n"
" ...\n"
"ZeroDivisionError: division by zero\n"
">>> def ifexp(x: 1 if y else 0): ...\n"
">>> get_annotations(ifexp, format=Format.STRING)\n"
"{'x': '1'}"
msgstr ""
#: ../Doc/library/annotationlib.rst:615
msgid "Security implications of introspecting annotations"
msgstr ""
#: ../Doc/library/annotationlib.rst:617
msgid ""
"Much of the functionality in this module involves executing code related to "
"annotations, which can then do arbitrary things. For example, :func:"
"`get_annotations` may call an arbitrary :term:`annotate function`, and :meth:"
"`ForwardRef.evaluate` may call :func:`eval` on an arbitrary string. Code "
"contained in an annotation might make arbitrary system calls, enter an "
"infinite loop, or perform any other operation. This is also true for any "
"access of the :attr:`~object.__annotations__` attribute, and for various "
"functions in the :mod:`typing` module that work with annotations, such as :"
"func:`typing.get_type_hints`."
msgstr ""
#: ../Doc/library/annotationlib.rst:626
msgid ""
"Any security issue arising from this also applies immediately after "
"importing code that may contain untrusted annotations: importing code can "
"always cause arbitrary operations to be performed. However, it is unsafe to "
"accept strings or other input from an untrusted source and pass them to any "
"of the APIs for introspecting annotations, for example by editing an "
"``__annotations__`` dictionary or directly creating a :class:`ForwardRef` "
"object."
msgstr ""