Merged revisions 53623-53858 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r53624 | peter.astrand | 2007-02-02 20:06:36 +0100 (Fri, 02 Feb 2007) | 1 line
We had several if statements checking the value of a fd. This is unsafe, since valid fds might be zero. We should check for not None instead.
........
r53635 | kurt.kaiser | 2007-02-05 07:03:18 +0100 (Mon, 05 Feb 2007) | 2 lines
Add 'raw' support to configHandler. Patch 1650174 Tal Einat.
........
r53641 | kurt.kaiser | 2007-02-06 00:02:16 +0100 (Tue, 06 Feb 2007) | 5 lines
1. Calltips now 'handle' tuples in the argument list (display '<tuple>' :)
Suggested solution by Christos Georgiou, Bug 791968.
2. Clean up tests, were not failing when they should have been.
4. Remove some camelcase and an unneeded try/except block.
........
r53644 | kurt.kaiser | 2007-02-06 04:21:40 +0100 (Tue, 06 Feb 2007) | 2 lines
Clean up ModifiedInterpreter.runcode() structure
........
r53646 | peter.astrand | 2007-02-06 16:37:50 +0100 (Tue, 06 Feb 2007) | 1 line
Applied patch 1124861.3.patch to solve bug #1124861: Automatically create pipes on Windows, if GetStdHandle fails. Will backport.
........
r53648 | lars.gustaebel | 2007-02-06 19:38:13 +0100 (Tue, 06 Feb 2007) | 4 lines
Patch #1652681: create nonexistent files in append mode and
allow appending to empty files.
........
r53649 | kurt.kaiser | 2007-02-06 20:09:43 +0100 (Tue, 06 Feb 2007) | 4 lines
Updated patch (CodeContext.061217.patch) to
[ 1362975 ] CodeContext - Improved text indentation
Tal Einat 16Dec06
........
r53650 | kurt.kaiser | 2007-02-06 20:21:19 +0100 (Tue, 06 Feb 2007) | 2 lines
narrow exception per [ 1540849 ] except too broad
........
r53653 | kurt.kaiser | 2007-02-07 04:39:41 +0100 (Wed, 07 Feb 2007) | 4 lines
[ 1621265 ] Auto-completion list placement
Move AC window below input line unless not enough space, then put it above.
Patch: Tal Einat
........
r53654 | kurt.kaiser | 2007-02-07 09:07:13 +0100 (Wed, 07 Feb 2007) | 2 lines
Handle AttributeError during calltip lookup
........
r53656 | raymond.hettinger | 2007-02-07 21:08:22 +0100 (Wed, 07 Feb 2007) | 3 lines
SF #1615701: make d.update(m) honor __getitem__() and keys() in dict subclasses
........
r53658 | raymond.hettinger | 2007-02-07 22:04:20 +0100 (Wed, 07 Feb 2007) | 1 line
SF: 1397711 Set docs conflated immutable and hashable
........
r53660 | raymond.hettinger | 2007-02-07 22:42:17 +0100 (Wed, 07 Feb 2007) | 1 line
Check for a common user error with defaultdict().
........
r53662 | raymond.hettinger | 2007-02-07 23:24:07 +0100 (Wed, 07 Feb 2007) | 1 line
Bug #1575169: operator.isSequenceType() now returns False for subclasses of dict.
........
r53664 | raymond.hettinger | 2007-02-08 00:49:03 +0100 (Thu, 08 Feb 2007) | 1 line
Silence compiler warning
........
r53666 | raymond.hettinger | 2007-02-08 01:07:32 +0100 (Thu, 08 Feb 2007) | 1 line
Do not let overflows in enumerate() and count() pass silently.
........
r53668 | raymond.hettinger | 2007-02-08 01:50:39 +0100 (Thu, 08 Feb 2007) | 1 line
Bypass set specific optimizations for set and frozenset subclasses.
........
r53670 | raymond.hettinger | 2007-02-08 02:42:35 +0100 (Thu, 08 Feb 2007) | 1 line
Fix docstring bug
........
r53671 | martin.v.loewis | 2007-02-08 10:13:36 +0100 (Thu, 08 Feb 2007) | 3 lines
Bug #1653736: Complain about keyword arguments to time.isoformat.
Will backport to 2.5.
........
r53679 | kurt.kaiser | 2007-02-08 23:58:18 +0100 (Thu, 08 Feb 2007) | 6 lines
Corrected some bugs in AutoComplete. Also, Page Up/Down in ACW implemented;
mouse and cursor selection in ACWindow implemented; double Tab inserts current
selection and closes ACW (similar to double-click and Return); scroll wheel now
works in ACW. Added AutoComplete instructions to IDLE Help.
........
r53689 | martin.v.loewis | 2007-02-09 13:19:32 +0100 (Fri, 09 Feb 2007) | 3 lines
Bug #1653736: Properly discard third argument to slot_nb_inplace_power.
Will backport.
........
r53691 | martin.v.loewis | 2007-02-09 13:36:48 +0100 (Fri, 09 Feb 2007) | 4 lines
Bug #1600860: Search for shared python library in LIBDIR, not
lib/python/config, on "linux" and "gnu" systems.
Will backport.
........
r53693 | martin.v.loewis | 2007-02-09 13:58:49 +0100 (Fri, 09 Feb 2007) | 2 lines
Update broken link. Will backport to 2.5.
........
r53697 | georg.brandl | 2007-02-09 19:48:41 +0100 (Fri, 09 Feb 2007) | 2 lines
Bug #1656078: typo in in profile docs.
........
r53731 | brett.cannon | 2007-02-11 06:36:00 +0100 (Sun, 11 Feb 2007) | 3 lines
Change a very minor inconsistency (that is purely cosmetic) in the AST
definition.
........
r53735 | skip.montanaro | 2007-02-11 19:24:37 +0100 (Sun, 11 Feb 2007) | 1 line
fix trace.py --ignore-dir
........
r53741 | brett.cannon | 2007-02-11 20:44:41 +0100 (Sun, 11 Feb 2007) | 3 lines
Check in changed Python-ast.c from a cosmetic change to Python.asdl (in
r53731).
........
r53751 | brett.cannon | 2007-02-12 04:51:02 +0100 (Mon, 12 Feb 2007) | 5 lines
Modify Parser/asdl_c.py so that the __version__ number for Python/Python-ast.c
is specified at the top of the file. Also add a note that Python/Python-ast.c
needs to be committed separately after a change to the AST grammar to capture
the revision number of the change (which is what __version__ is set to).
........
r53752 | lars.gustaebel | 2007-02-12 10:25:53 +0100 (Mon, 12 Feb 2007) | 3 lines
Bug #1656581: Point out that external file objects are supposed to be
at position 0.
........
r53754 | martin.v.loewis | 2007-02-12 13:21:10 +0100 (Mon, 12 Feb 2007) | 3 lines
Patch 1463026: Support default namespace in XMLGenerator.
Fixes #847665. Will backport.
........
r53757 | armin.rigo | 2007-02-12 17:23:24 +0100 (Mon, 12 Feb 2007) | 4 lines
Fix the line to what is my guess at the original author's meaning.
(The line has no effect anyway, but is present because it's
customary call the base class __init__).
........
r53763 | martin.v.loewis | 2007-02-13 09:34:45 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #685268: Consider a package's __path__ in imputil.
Will backport.
........
r53765 | martin.v.loewis | 2007-02-13 10:49:38 +0100 (Tue, 13 Feb 2007) | 2 lines
Patch #698833: Support file decryption in zipfile.
........
r53766 | martin.v.loewis | 2007-02-13 11:10:39 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #1517891: Make 'a' create the file if it doesn't exist.
Fixes #1514451.
........
r53767 | martin.v.loewis | 2007-02-13 13:08:24 +0100 (Tue, 13 Feb 2007) | 3 lines
Bug #1658794: Remove extraneous 'this'.
Will backport to 2.5.
........
r53769 | martin.v.loewis | 2007-02-13 13:14:19 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #1657276: Make NETLINK_DNRTMSG conditional.
Will backport.
........
r53771 | lars.gustaebel | 2007-02-13 17:09:24 +0100 (Tue, 13 Feb 2007) | 4 lines
Patch #1647484: Renamed GzipFile's filename attribute to name. The
filename attribute is still accessible as a property that emits a
DeprecationWarning.
........
r53772 | lars.gustaebel | 2007-02-13 17:24:00 +0100 (Tue, 13 Feb 2007) | 3 lines
Strip the '.gz' extension from the filename that is written to the
gzip header.
........
r53774 | martin.v.loewis | 2007-02-14 11:07:37 +0100 (Wed, 14 Feb 2007) | 2 lines
Patch #1432399: Add HCI sockets.
........
r53775 | martin.v.loewis | 2007-02-14 12:30:07 +0100 (Wed, 14 Feb 2007) | 2 lines
Update 1432399 to removal of _BT_SOCKADDR_MEMB.
........
r53776 | martin.v.loewis | 2007-02-14 12:30:56 +0100 (Wed, 14 Feb 2007) | 3 lines
Ignore directory time stamps when considering
whether to rerun libffi configure.
........
r53778 | lars.gustaebel | 2007-02-14 15:45:12 +0100 (Wed, 14 Feb 2007) | 4 lines
A missing binary mode in AppendTest caused failures in Windows
Buildbot.
........
r53782 | martin.v.loewis | 2007-02-15 10:51:35 +0100 (Thu, 15 Feb 2007) | 2 lines
Patch #1397848: add the reasoning behind no-resize-on-shrinkage.
........
r53783 | georg.brandl | 2007-02-15 11:37:59 +0100 (Thu, 15 Feb 2007) | 2 lines
Make functools.wraps() docs a bit clearer.
........
r53785 | georg.brandl | 2007-02-15 12:29:04 +0100 (Thu, 15 Feb 2007) | 2 lines
Patch #1494140: Add documentation for the new struct.Struct object.
........
r53787 | georg.brandl | 2007-02-15 12:29:55 +0100 (Thu, 15 Feb 2007) | 2 lines
Add missing \versionadded.
........
r53800 | brett.cannon | 2007-02-15 23:54:39 +0100 (Thu, 15 Feb 2007) | 11 lines
Update the encoding package's search function to use absolute imports when
calling __import__. This helps make the expected search locations for encoding
modules be more explicit.
One could use an explicit value for __path__ when making the call to __import__
to force the exact location searched for encodings. This would give the most
strict search path possible if one is worried about malicious code being
imported. The unfortunate side-effect of that is that if __path__ was modified
on 'encodings' on purpose in a safe way it would not be picked up in future
__import__ calls.
........
r53801 | brett.cannon | 2007-02-16 20:33:01 +0100 (Fri, 16 Feb 2007) | 2 lines
Make the __import__ call in encodings.__init__ absolute with a level 0 call.
........
r53809 | vinay.sajip | 2007-02-16 23:36:24 +0100 (Fri, 16 Feb 2007) | 1 line
Minor fix for currentframe (SF #1652788).
........
r53818 | raymond.hettinger | 2007-02-19 03:03:19 +0100 (Mon, 19 Feb 2007) | 3 lines
Extend work on revision 52962: Eliminate redundant calls to PyObject_Hash().
........
r53820 | raymond.hettinger | 2007-02-19 05:08:43 +0100 (Mon, 19 Feb 2007) | 1 line
Add merge() function to heapq.
........
r53821 | raymond.hettinger | 2007-02-19 06:28:28 +0100 (Mon, 19 Feb 2007) | 1 line
Add tie-breaker count to preserve sort stability.
........
r53822 | raymond.hettinger | 2007-02-19 07:59:32 +0100 (Mon, 19 Feb 2007) | 1 line
Use C heapreplace() instead of slower _siftup() in pure python.
........
r53823 | raymond.hettinger | 2007-02-19 08:30:21 +0100 (Mon, 19 Feb 2007) | 1 line
Add test for merge stability
........
r53824 | raymond.hettinger | 2007-02-19 10:14:10 +0100 (Mon, 19 Feb 2007) | 1 line
Provide an example of defaultdict with non-zero constant factory function.
........
r53825 | lars.gustaebel | 2007-02-19 10:54:47 +0100 (Mon, 19 Feb 2007) | 2 lines
Moved misplaced news item.
........
r53826 | martin.v.loewis | 2007-02-19 11:55:19 +0100 (Mon, 19 Feb 2007) | 3 lines
Patch #1490190: posixmodule now includes os.chflags() and os.lchflags()
functions on platforms where the underlying system calls are available.
........
r53827 | raymond.hettinger | 2007-02-19 19:15:04 +0100 (Mon, 19 Feb 2007) | 1 line
Fixup docstrings for merge().
........
r53829 | raymond.hettinger | 2007-02-19 21:44:04 +0100 (Mon, 19 Feb 2007) | 1 line
Fixup set/dict interoperability.
........
r53837 | raymond.hettinger | 2007-02-21 06:20:38 +0100 (Wed, 21 Feb 2007) | 1 line
Add itertools.izip_longest().
........
r53838 | raymond.hettinger | 2007-02-21 18:22:05 +0100 (Wed, 21 Feb 2007) | 1 line
Remove filler struct item and fix leak.
........
2007-02-23 23:07:44 +08:00
|
|
|
/* File automatically generated by Parser/asdl_c.py. */
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
__version__ 62078.
|
Merged revisions 53623-53858 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r53624 | peter.astrand | 2007-02-02 20:06:36 +0100 (Fri, 02 Feb 2007) | 1 line
We had several if statements checking the value of a fd. This is unsafe, since valid fds might be zero. We should check for not None instead.
........
r53635 | kurt.kaiser | 2007-02-05 07:03:18 +0100 (Mon, 05 Feb 2007) | 2 lines
Add 'raw' support to configHandler. Patch 1650174 Tal Einat.
........
r53641 | kurt.kaiser | 2007-02-06 00:02:16 +0100 (Tue, 06 Feb 2007) | 5 lines
1. Calltips now 'handle' tuples in the argument list (display '<tuple>' :)
Suggested solution by Christos Georgiou, Bug 791968.
2. Clean up tests, were not failing when they should have been.
4. Remove some camelcase and an unneeded try/except block.
........
r53644 | kurt.kaiser | 2007-02-06 04:21:40 +0100 (Tue, 06 Feb 2007) | 2 lines
Clean up ModifiedInterpreter.runcode() structure
........
r53646 | peter.astrand | 2007-02-06 16:37:50 +0100 (Tue, 06 Feb 2007) | 1 line
Applied patch 1124861.3.patch to solve bug #1124861: Automatically create pipes on Windows, if GetStdHandle fails. Will backport.
........
r53648 | lars.gustaebel | 2007-02-06 19:38:13 +0100 (Tue, 06 Feb 2007) | 4 lines
Patch #1652681: create nonexistent files in append mode and
allow appending to empty files.
........
r53649 | kurt.kaiser | 2007-02-06 20:09:43 +0100 (Tue, 06 Feb 2007) | 4 lines
Updated patch (CodeContext.061217.patch) to
[ 1362975 ] CodeContext - Improved text indentation
Tal Einat 16Dec06
........
r53650 | kurt.kaiser | 2007-02-06 20:21:19 +0100 (Tue, 06 Feb 2007) | 2 lines
narrow exception per [ 1540849 ] except too broad
........
r53653 | kurt.kaiser | 2007-02-07 04:39:41 +0100 (Wed, 07 Feb 2007) | 4 lines
[ 1621265 ] Auto-completion list placement
Move AC window below input line unless not enough space, then put it above.
Patch: Tal Einat
........
r53654 | kurt.kaiser | 2007-02-07 09:07:13 +0100 (Wed, 07 Feb 2007) | 2 lines
Handle AttributeError during calltip lookup
........
r53656 | raymond.hettinger | 2007-02-07 21:08:22 +0100 (Wed, 07 Feb 2007) | 3 lines
SF #1615701: make d.update(m) honor __getitem__() and keys() in dict subclasses
........
r53658 | raymond.hettinger | 2007-02-07 22:04:20 +0100 (Wed, 07 Feb 2007) | 1 line
SF: 1397711 Set docs conflated immutable and hashable
........
r53660 | raymond.hettinger | 2007-02-07 22:42:17 +0100 (Wed, 07 Feb 2007) | 1 line
Check for a common user error with defaultdict().
........
r53662 | raymond.hettinger | 2007-02-07 23:24:07 +0100 (Wed, 07 Feb 2007) | 1 line
Bug #1575169: operator.isSequenceType() now returns False for subclasses of dict.
........
r53664 | raymond.hettinger | 2007-02-08 00:49:03 +0100 (Thu, 08 Feb 2007) | 1 line
Silence compiler warning
........
r53666 | raymond.hettinger | 2007-02-08 01:07:32 +0100 (Thu, 08 Feb 2007) | 1 line
Do not let overflows in enumerate() and count() pass silently.
........
r53668 | raymond.hettinger | 2007-02-08 01:50:39 +0100 (Thu, 08 Feb 2007) | 1 line
Bypass set specific optimizations for set and frozenset subclasses.
........
r53670 | raymond.hettinger | 2007-02-08 02:42:35 +0100 (Thu, 08 Feb 2007) | 1 line
Fix docstring bug
........
r53671 | martin.v.loewis | 2007-02-08 10:13:36 +0100 (Thu, 08 Feb 2007) | 3 lines
Bug #1653736: Complain about keyword arguments to time.isoformat.
Will backport to 2.5.
........
r53679 | kurt.kaiser | 2007-02-08 23:58:18 +0100 (Thu, 08 Feb 2007) | 6 lines
Corrected some bugs in AutoComplete. Also, Page Up/Down in ACW implemented;
mouse and cursor selection in ACWindow implemented; double Tab inserts current
selection and closes ACW (similar to double-click and Return); scroll wheel now
works in ACW. Added AutoComplete instructions to IDLE Help.
........
r53689 | martin.v.loewis | 2007-02-09 13:19:32 +0100 (Fri, 09 Feb 2007) | 3 lines
Bug #1653736: Properly discard third argument to slot_nb_inplace_power.
Will backport.
........
r53691 | martin.v.loewis | 2007-02-09 13:36:48 +0100 (Fri, 09 Feb 2007) | 4 lines
Bug #1600860: Search for shared python library in LIBDIR, not
lib/python/config, on "linux" and "gnu" systems.
Will backport.
........
r53693 | martin.v.loewis | 2007-02-09 13:58:49 +0100 (Fri, 09 Feb 2007) | 2 lines
Update broken link. Will backport to 2.5.
........
r53697 | georg.brandl | 2007-02-09 19:48:41 +0100 (Fri, 09 Feb 2007) | 2 lines
Bug #1656078: typo in in profile docs.
........
r53731 | brett.cannon | 2007-02-11 06:36:00 +0100 (Sun, 11 Feb 2007) | 3 lines
Change a very minor inconsistency (that is purely cosmetic) in the AST
definition.
........
r53735 | skip.montanaro | 2007-02-11 19:24:37 +0100 (Sun, 11 Feb 2007) | 1 line
fix trace.py --ignore-dir
........
r53741 | brett.cannon | 2007-02-11 20:44:41 +0100 (Sun, 11 Feb 2007) | 3 lines
Check in changed Python-ast.c from a cosmetic change to Python.asdl (in
r53731).
........
r53751 | brett.cannon | 2007-02-12 04:51:02 +0100 (Mon, 12 Feb 2007) | 5 lines
Modify Parser/asdl_c.py so that the __version__ number for Python/Python-ast.c
is specified at the top of the file. Also add a note that Python/Python-ast.c
needs to be committed separately after a change to the AST grammar to capture
the revision number of the change (which is what __version__ is set to).
........
r53752 | lars.gustaebel | 2007-02-12 10:25:53 +0100 (Mon, 12 Feb 2007) | 3 lines
Bug #1656581: Point out that external file objects are supposed to be
at position 0.
........
r53754 | martin.v.loewis | 2007-02-12 13:21:10 +0100 (Mon, 12 Feb 2007) | 3 lines
Patch 1463026: Support default namespace in XMLGenerator.
Fixes #847665. Will backport.
........
r53757 | armin.rigo | 2007-02-12 17:23:24 +0100 (Mon, 12 Feb 2007) | 4 lines
Fix the line to what is my guess at the original author's meaning.
(The line has no effect anyway, but is present because it's
customary call the base class __init__).
........
r53763 | martin.v.loewis | 2007-02-13 09:34:45 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #685268: Consider a package's __path__ in imputil.
Will backport.
........
r53765 | martin.v.loewis | 2007-02-13 10:49:38 +0100 (Tue, 13 Feb 2007) | 2 lines
Patch #698833: Support file decryption in zipfile.
........
r53766 | martin.v.loewis | 2007-02-13 11:10:39 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #1517891: Make 'a' create the file if it doesn't exist.
Fixes #1514451.
........
r53767 | martin.v.loewis | 2007-02-13 13:08:24 +0100 (Tue, 13 Feb 2007) | 3 lines
Bug #1658794: Remove extraneous 'this'.
Will backport to 2.5.
........
r53769 | martin.v.loewis | 2007-02-13 13:14:19 +0100 (Tue, 13 Feb 2007) | 3 lines
Patch #1657276: Make NETLINK_DNRTMSG conditional.
Will backport.
........
r53771 | lars.gustaebel | 2007-02-13 17:09:24 +0100 (Tue, 13 Feb 2007) | 4 lines
Patch #1647484: Renamed GzipFile's filename attribute to name. The
filename attribute is still accessible as a property that emits a
DeprecationWarning.
........
r53772 | lars.gustaebel | 2007-02-13 17:24:00 +0100 (Tue, 13 Feb 2007) | 3 lines
Strip the '.gz' extension from the filename that is written to the
gzip header.
........
r53774 | martin.v.loewis | 2007-02-14 11:07:37 +0100 (Wed, 14 Feb 2007) | 2 lines
Patch #1432399: Add HCI sockets.
........
r53775 | martin.v.loewis | 2007-02-14 12:30:07 +0100 (Wed, 14 Feb 2007) | 2 lines
Update 1432399 to removal of _BT_SOCKADDR_MEMB.
........
r53776 | martin.v.loewis | 2007-02-14 12:30:56 +0100 (Wed, 14 Feb 2007) | 3 lines
Ignore directory time stamps when considering
whether to rerun libffi configure.
........
r53778 | lars.gustaebel | 2007-02-14 15:45:12 +0100 (Wed, 14 Feb 2007) | 4 lines
A missing binary mode in AppendTest caused failures in Windows
Buildbot.
........
r53782 | martin.v.loewis | 2007-02-15 10:51:35 +0100 (Thu, 15 Feb 2007) | 2 lines
Patch #1397848: add the reasoning behind no-resize-on-shrinkage.
........
r53783 | georg.brandl | 2007-02-15 11:37:59 +0100 (Thu, 15 Feb 2007) | 2 lines
Make functools.wraps() docs a bit clearer.
........
r53785 | georg.brandl | 2007-02-15 12:29:04 +0100 (Thu, 15 Feb 2007) | 2 lines
Patch #1494140: Add documentation for the new struct.Struct object.
........
r53787 | georg.brandl | 2007-02-15 12:29:55 +0100 (Thu, 15 Feb 2007) | 2 lines
Add missing \versionadded.
........
r53800 | brett.cannon | 2007-02-15 23:54:39 +0100 (Thu, 15 Feb 2007) | 11 lines
Update the encoding package's search function to use absolute imports when
calling __import__. This helps make the expected search locations for encoding
modules be more explicit.
One could use an explicit value for __path__ when making the call to __import__
to force the exact location searched for encodings. This would give the most
strict search path possible if one is worried about malicious code being
imported. The unfortunate side-effect of that is that if __path__ was modified
on 'encodings' on purpose in a safe way it would not be picked up in future
__import__ calls.
........
r53801 | brett.cannon | 2007-02-16 20:33:01 +0100 (Fri, 16 Feb 2007) | 2 lines
Make the __import__ call in encodings.__init__ absolute with a level 0 call.
........
r53809 | vinay.sajip | 2007-02-16 23:36:24 +0100 (Fri, 16 Feb 2007) | 1 line
Minor fix for currentframe (SF #1652788).
........
r53818 | raymond.hettinger | 2007-02-19 03:03:19 +0100 (Mon, 19 Feb 2007) | 3 lines
Extend work on revision 52962: Eliminate redundant calls to PyObject_Hash().
........
r53820 | raymond.hettinger | 2007-02-19 05:08:43 +0100 (Mon, 19 Feb 2007) | 1 line
Add merge() function to heapq.
........
r53821 | raymond.hettinger | 2007-02-19 06:28:28 +0100 (Mon, 19 Feb 2007) | 1 line
Add tie-breaker count to preserve sort stability.
........
r53822 | raymond.hettinger | 2007-02-19 07:59:32 +0100 (Mon, 19 Feb 2007) | 1 line
Use C heapreplace() instead of slower _siftup() in pure python.
........
r53823 | raymond.hettinger | 2007-02-19 08:30:21 +0100 (Mon, 19 Feb 2007) | 1 line
Add test for merge stability
........
r53824 | raymond.hettinger | 2007-02-19 10:14:10 +0100 (Mon, 19 Feb 2007) | 1 line
Provide an example of defaultdict with non-zero constant factory function.
........
r53825 | lars.gustaebel | 2007-02-19 10:54:47 +0100 (Mon, 19 Feb 2007) | 2 lines
Moved misplaced news item.
........
r53826 | martin.v.loewis | 2007-02-19 11:55:19 +0100 (Mon, 19 Feb 2007) | 3 lines
Patch #1490190: posixmodule now includes os.chflags() and os.lchflags()
functions on platforms where the underlying system calls are available.
........
r53827 | raymond.hettinger | 2007-02-19 19:15:04 +0100 (Mon, 19 Feb 2007) | 1 line
Fixup docstrings for merge().
........
r53829 | raymond.hettinger | 2007-02-19 21:44:04 +0100 (Mon, 19 Feb 2007) | 1 line
Fixup set/dict interoperability.
........
r53837 | raymond.hettinger | 2007-02-21 06:20:38 +0100 (Wed, 21 Feb 2007) | 1 line
Add itertools.izip_longest().
........
r53838 | raymond.hettinger | 2007-02-21 18:22:05 +0100 (Wed, 21 Feb 2007) | 1 line
Remove filler struct item and fix leak.
........
2007-02-23 23:07:44 +08:00
|
|
|
|
|
|
|
This module must be committed separately after each AST grammar change;
|
|
|
|
The __version__ number is set to the revision number of the commit
|
|
|
|
containing the grammar change.
|
|
|
|
*/
|
2005-10-21 03:59:25 +08:00
|
|
|
|
|
|
|
#include "Python.h"
|
|
|
|
#include "Python-ast.h"
|
|
|
|
|
2008-03-31 12:42:11 +08:00
|
|
|
static PyTypeObject AST_type;
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *mod_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_mod(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Module_type;
|
|
|
|
static char *Module_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Interactive_type;
|
|
|
|
static char *Interactive_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Expression_type;
|
|
|
|
static char *Expression_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Suite_type;
|
|
|
|
static char *Suite_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *stmt_type;
|
|
|
|
static char *stmt_attributes[] = {
|
2006-02-27 23:23:19 +08:00
|
|
|
"lineno",
|
2006-03-02 06:49:05 +08:00
|
|
|
"col_offset",
|
2006-02-27 23:23:19 +08:00
|
|
|
};
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_stmt(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *FunctionDef_type;
|
|
|
|
static char *FunctionDef_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"name",
|
|
|
|
"args",
|
|
|
|
"body",
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
"decorator_list",
|
2006-12-28 14:47:50 +08:00
|
|
|
"returns",
|
2006-02-27 03:42:26 +08:00
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *ClassDef_type;
|
|
|
|
static char *ClassDef_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"name",
|
|
|
|
"bases",
|
2007-03-18 23:41:51 +08:00
|
|
|
"keywords",
|
|
|
|
"starargs",
|
|
|
|
"kwargs",
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
"decorator_list",
|
2006-02-27 03:42:26 +08:00
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Return_type;
|
|
|
|
static char *Return_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Delete_type;
|
|
|
|
static char *Delete_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"targets",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Assign_type;
|
|
|
|
static char *Assign_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"targets",
|
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *AugAssign_type;
|
|
|
|
static char *AugAssign_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"target",
|
|
|
|
"op",
|
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *For_type;
|
|
|
|
static char *For_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"target",
|
|
|
|
"iter",
|
|
|
|
"body",
|
|
|
|
"orelse",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *While_type;
|
|
|
|
static char *While_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"test",
|
|
|
|
"body",
|
|
|
|
"orelse",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *If_type;
|
|
|
|
static char *If_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"test",
|
|
|
|
"body",
|
|
|
|
"orelse",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *With_type;
|
|
|
|
static char *With_fields[]={
|
2006-02-28 06:32:47 +08:00
|
|
|
"context_expr",
|
|
|
|
"optional_vars",
|
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Raise_type;
|
|
|
|
static char *Raise_fields[]={
|
2007-08-31 08:04:24 +08:00
|
|
|
"exc",
|
|
|
|
"cause",
|
2006-02-27 03:42:26 +08:00
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *TryExcept_type;
|
|
|
|
static char *TryExcept_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
"handlers",
|
|
|
|
"orelse",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *TryFinally_type;
|
|
|
|
static char *TryFinally_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"body",
|
|
|
|
"finalbody",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Assert_type;
|
|
|
|
static char *Assert_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"test",
|
|
|
|
"msg",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Import_type;
|
|
|
|
static char *Import_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"names",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *ImportFrom_type;
|
|
|
|
static char *ImportFrom_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"module",
|
|
|
|
"names",
|
2006-03-01 00:09:29 +08:00
|
|
|
"level",
|
2006-02-27 03:42:26 +08:00
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Global_type;
|
|
|
|
static char *Global_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"names",
|
|
|
|
};
|
2007-02-27 14:50:52 +08:00
|
|
|
static PyTypeObject *Nonlocal_type;
|
|
|
|
static char *Nonlocal_fields[]={
|
|
|
|
"names",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Expr_type;
|
|
|
|
static char *Expr_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Pass_type;
|
|
|
|
static PyTypeObject *Break_type;
|
|
|
|
static PyTypeObject *Continue_type;
|
|
|
|
static PyTypeObject *expr_type;
|
|
|
|
static char *expr_attributes[] = {
|
2006-02-27 23:23:19 +08:00
|
|
|
"lineno",
|
2006-03-02 06:49:05 +08:00
|
|
|
"col_offset",
|
2006-02-27 23:23:19 +08:00
|
|
|
};
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_expr(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *BoolOp_type;
|
|
|
|
static char *BoolOp_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"op",
|
|
|
|
"values",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *BinOp_type;
|
|
|
|
static char *BinOp_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"left",
|
|
|
|
"op",
|
|
|
|
"right",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *UnaryOp_type;
|
|
|
|
static char *UnaryOp_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"op",
|
|
|
|
"operand",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Lambda_type;
|
|
|
|
static char *Lambda_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"args",
|
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *IfExp_type;
|
|
|
|
static char *IfExp_fields[]={
|
2006-02-27 08:24:13 +08:00
|
|
|
"test",
|
|
|
|
"body",
|
|
|
|
"orelse",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Dict_type;
|
|
|
|
static char *Dict_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"keys",
|
|
|
|
"values",
|
|
|
|
};
|
2006-08-28 23:27:34 +08:00
|
|
|
static PyTypeObject *Set_type;
|
|
|
|
static char *Set_fields[]={
|
|
|
|
"elts",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *ListComp_type;
|
|
|
|
static char *ListComp_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"elt",
|
|
|
|
"generators",
|
|
|
|
};
|
2007-04-15 20:05:43 +08:00
|
|
|
static PyTypeObject *SetComp_type;
|
|
|
|
static char *SetComp_fields[]={
|
|
|
|
"elt",
|
|
|
|
"generators",
|
|
|
|
};
|
Merged revisions 56154-56264 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56155 | neal.norwitz | 2007-07-03 08:59:08 +0300 (Tue, 03 Jul 2007) | 1 line
Get this test working after converting map to return an iterator
................
r56202 | neal.norwitz | 2007-07-09 04:30:09 +0300 (Mon, 09 Jul 2007) | 37 lines
Merged revisions 56124-56201 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56129 | georg.brandl | 2007-06-30 04:01:01 -0700 (Sat, 30 Jun 2007) | 2 lines
Document smtp.SMTPAuthenticationError.
........
r56137 | georg.brandl | 2007-07-01 01:11:35 -0700 (Sun, 01 Jul 2007) | 2 lines
Fix a few webbrowser.py problems.
........
r56143 | georg.brandl | 2007-07-02 04:54:28 -0700 (Mon, 02 Jul 2007) | 2 lines
Remove duplicate sentence from alarm() doc.
........
r56170 | mark.hammond | 2007-07-03 19:03:10 -0700 (Tue, 03 Jul 2007) | 3 lines
copy built files to the PCBuild directory, where tools like
distutils or external build processes can find them.
........
r56176 | kurt.kaiser | 2007-07-05 15:03:39 -0700 (Thu, 05 Jul 2007) | 10 lines
Many calls to tk.call involve an arglist containing a single tuple.
Calls using METH_OLDARGS unpack this tuple; calls using METH_VARARG
don't. Tcl's concatenation of args was affected; IDLE doesn't start.
Modify Tkapp_Call() to unpack single tuple arglists.
Bug 1733943
Ref http://mail.python.org/pipermail/python-checkins/2007-May/060454.html
........
r56177 | neal.norwitz | 2007-07-05 21:13:39 -0700 (Thu, 05 Jul 2007) | 1 line
Fix typo in comment
........
................
r56251 | neal.norwitz | 2007-07-11 10:01:01 +0300 (Wed, 11 Jul 2007) | 1 line
Get working with map returning an iterator (had to fix whitespace too)
................
r56255 | thomas.wouters | 2007-07-11 13:41:37 +0300 (Wed, 11 Jul 2007) | 6 lines
Clean up merge glitch or copy-paste error (the entire module was duplicated,
except the first half even had some more copy-paste errors, referring to
listcomps and genexps instead of setcomps)
................
r56256 | thomas.wouters | 2007-07-11 15:16:01 +0300 (Wed, 11 Jul 2007) | 14 lines
Dict comprehensions. Still needs doc changes (like many python-3000 features
;-). It generates bytecode similar to:
x = {}
for k, v in (generator here):
x[k] = v
except there is no tuple-packing and -unpacking involved. Trivial
measurement suggests it's significantly faster than dict(generator here) (in
the order of 2 to 3 times as fast) but I have not done extensive
measurements.
................
r56263 | guido.van.rossum | 2007-07-11 15:36:26 +0300 (Wed, 11 Jul 2007) | 3 lines
Patch 1724999 by Ali Gholami Rudi -- avoid complaints about dict size
change during iter in destroy call.
................
2007-07-11 21:09:30 +08:00
|
|
|
static PyTypeObject *DictComp_type;
|
|
|
|
static char *DictComp_fields[]={
|
|
|
|
"key",
|
|
|
|
"value",
|
|
|
|
"generators",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *GeneratorExp_type;
|
|
|
|
static char *GeneratorExp_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"elt",
|
|
|
|
"generators",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Yield_type;
|
|
|
|
static char *Yield_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Compare_type;
|
|
|
|
static char *Compare_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"left",
|
|
|
|
"ops",
|
|
|
|
"comparators",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Call_type;
|
|
|
|
static char *Call_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"func",
|
|
|
|
"args",
|
|
|
|
"keywords",
|
|
|
|
"starargs",
|
|
|
|
"kwargs",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Num_type;
|
|
|
|
static char *Num_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"n",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Str_type;
|
|
|
|
static char *Str_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"s",
|
|
|
|
};
|
2007-02-24 03:56:57 +08:00
|
|
|
static PyTypeObject *Bytes_type;
|
|
|
|
static char *Bytes_fields[]={
|
|
|
|
"s",
|
|
|
|
};
|
2006-09-06 15:06:08 +08:00
|
|
|
static PyTypeObject *Ellipsis_type;
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Attribute_type;
|
|
|
|
static char *Attribute_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
"attr",
|
|
|
|
"ctx",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Subscript_type;
|
|
|
|
static char *Subscript_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
"slice",
|
|
|
|
"ctx",
|
|
|
|
};
|
Merged revisions 55225-55227,55229-55269 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55238 | guido.van.rossum | 2007-05-10 16:46:05 -0700 (Thu, 10 May 2007) | 9 lines
Merged revisions 55227 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55227 | guido.van.rossum | 2007-05-10 10:20:15 -0700 (Thu, 10 May 2007) | 2 lines
Fix a bug in test_c_api() that caused a negative refcount.
........
................
r55246 | neal.norwitz | 2007-05-11 00:01:52 -0700 (Fri, 11 May 2007) | 1 line
Remove commands.getstatus() it is obsolete.
................
r55248 | neal.norwitz | 2007-05-11 00:29:05 -0700 (Fri, 11 May 2007) | 2 lines
Remove bsddb185 support.
................
r55249 | neal.norwitz | 2007-05-11 00:29:50 -0700 (Fri, 11 May 2007) | 1 line
Remove bsddb185 module too
................
r55250 | neal.norwitz | 2007-05-11 00:32:13 -0700 (Fri, 11 May 2007) | 1 line
bsddb185: Gotta remove from the file checked in, not Setup
................
r55251 | neal.norwitz | 2007-05-11 00:53:26 -0700 (Fri, 11 May 2007) | 1 line
Remove obsolete IRIX modules (as much as I could find, there is probably more)
................
r55252 | neal.norwitz | 2007-05-11 00:55:35 -0700 (Fri, 11 May 2007) | 1 line
Remove SGI turd.
................
r55254 | georg.brandl | 2007-05-11 03:11:01 -0700 (Fri, 11 May 2007) | 2 lines
Add a case for set comprehensions to the "cannot assign to" switch.
................
r55255 | georg.brandl | 2007-05-11 03:11:25 -0700 (Fri, 11 May 2007) | 2 lines
Fix wrong imports.
................
r55261 | georg.brandl | 2007-05-11 07:37:48 -0700 (Fri, 11 May 2007) | 2 lines
Remove removed tex files.
................
r55262 | georg.brandl | 2007-05-11 08:28:41 -0700 (Fri, 11 May 2007) | 2 lines
Commit PEP 3132 implementation.
................
r55264 | georg.brandl | 2007-05-11 08:50:19 -0700 (Fri, 11 May 2007) | 2 lines
Check in the inevitable AST version number and format Py_ssize_t with %zd.
................
r55265 | neal.norwitz | 2007-05-11 09:12:22 -0700 (Fri, 11 May 2007) | 1 line
Remove mention of os.popen* and popen2.* since these will be removed.
................
r55266 | neal.norwitz | 2007-05-11 09:19:57 -0700 (Fri, 11 May 2007) | 1 line
Get doc to build again (almost, the doc is fine)
................
r55267 | neal.norwitz | 2007-05-11 09:21:02 -0700 (Fri, 11 May 2007) | 1 line
Really get doc to build (remove use of string module)
................
r55269 | neal.norwitz | 2007-05-11 09:29:43 -0700 (Fri, 11 May 2007) | 1 line
Add some notes to cleanup later
................
2007-05-12 00:50:42 +08:00
|
|
|
static PyTypeObject *Starred_type;
|
|
|
|
static char *Starred_fields[]={
|
|
|
|
"value",
|
|
|
|
"ctx",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Name_type;
|
|
|
|
static char *Name_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"id",
|
|
|
|
"ctx",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *List_type;
|
|
|
|
static char *List_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"elts",
|
|
|
|
"ctx",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Tuple_type;
|
|
|
|
static char *Tuple_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"elts",
|
|
|
|
"ctx",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *expr_context_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject *Load_singleton, *Store_singleton, *Del_singleton,
|
|
|
|
*AugLoad_singleton, *AugStore_singleton, *Param_singleton;
|
|
|
|
static PyObject* ast2obj_expr_context(expr_context_ty);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Load_type;
|
|
|
|
static PyTypeObject *Store_type;
|
|
|
|
static PyTypeObject *Del_type;
|
|
|
|
static PyTypeObject *AugLoad_type;
|
|
|
|
static PyTypeObject *AugStore_type;
|
|
|
|
static PyTypeObject *Param_type;
|
|
|
|
static PyTypeObject *slice_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_slice(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Slice_type;
|
|
|
|
static char *Slice_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"lower",
|
|
|
|
"upper",
|
|
|
|
"step",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *ExtSlice_type;
|
|
|
|
static char *ExtSlice_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"dims",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Index_type;
|
|
|
|
static char *Index_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *boolop_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject *And_singleton, *Or_singleton;
|
|
|
|
static PyObject* ast2obj_boolop(boolop_ty);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *And_type;
|
|
|
|
static PyTypeObject *Or_type;
|
|
|
|
static PyTypeObject *operator_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject *Add_singleton, *Sub_singleton, *Mult_singleton,
|
|
|
|
*Div_singleton, *Mod_singleton, *Pow_singleton, *LShift_singleton,
|
|
|
|
*RShift_singleton, *BitOr_singleton, *BitXor_singleton, *BitAnd_singleton,
|
|
|
|
*FloorDiv_singleton;
|
|
|
|
static PyObject* ast2obj_operator(operator_ty);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Add_type;
|
|
|
|
static PyTypeObject *Sub_type;
|
|
|
|
static PyTypeObject *Mult_type;
|
|
|
|
static PyTypeObject *Div_type;
|
|
|
|
static PyTypeObject *Mod_type;
|
|
|
|
static PyTypeObject *Pow_type;
|
|
|
|
static PyTypeObject *LShift_type;
|
|
|
|
static PyTypeObject *RShift_type;
|
|
|
|
static PyTypeObject *BitOr_type;
|
|
|
|
static PyTypeObject *BitXor_type;
|
|
|
|
static PyTypeObject *BitAnd_type;
|
|
|
|
static PyTypeObject *FloorDiv_type;
|
|
|
|
static PyTypeObject *unaryop_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject *Invert_singleton, *Not_singleton, *UAdd_singleton,
|
|
|
|
*USub_singleton;
|
|
|
|
static PyObject* ast2obj_unaryop(unaryop_ty);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Invert_type;
|
|
|
|
static PyTypeObject *Not_type;
|
|
|
|
static PyTypeObject *UAdd_type;
|
|
|
|
static PyTypeObject *USub_type;
|
|
|
|
static PyTypeObject *cmpop_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject *Eq_singleton, *NotEq_singleton, *Lt_singleton, *LtE_singleton,
|
|
|
|
*Gt_singleton, *GtE_singleton, *Is_singleton, *IsNot_singleton, *In_singleton,
|
|
|
|
*NotIn_singleton;
|
|
|
|
static PyObject* ast2obj_cmpop(cmpop_ty);
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *Eq_type;
|
|
|
|
static PyTypeObject *NotEq_type;
|
|
|
|
static PyTypeObject *Lt_type;
|
|
|
|
static PyTypeObject *LtE_type;
|
|
|
|
static PyTypeObject *Gt_type;
|
|
|
|
static PyTypeObject *GtE_type;
|
|
|
|
static PyTypeObject *Is_type;
|
|
|
|
static PyTypeObject *IsNot_type;
|
|
|
|
static PyTypeObject *In_type;
|
|
|
|
static PyTypeObject *NotIn_type;
|
|
|
|
static PyTypeObject *comprehension_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_comprehension(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static char *comprehension_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"target",
|
|
|
|
"iter",
|
|
|
|
"ifs",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *excepthandler_type;
|
2008-03-31 13:14:30 +08:00
|
|
|
static char *excepthandler_attributes[] = {
|
|
|
|
"lineno",
|
|
|
|
"col_offset",
|
|
|
|
};
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_excepthandler(void*);
|
2008-03-31 13:14:30 +08:00
|
|
|
static PyTypeObject *ExceptHandler_type;
|
|
|
|
static char *ExceptHandler_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"type",
|
|
|
|
"name",
|
|
|
|
"body",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *arguments_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_arguments(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static char *arguments_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"args",
|
|
|
|
"vararg",
|
2006-12-28 14:47:50 +08:00
|
|
|
"varargannotation",
|
2006-10-28 07:31:49 +08:00
|
|
|
"kwonlyargs",
|
2006-02-27 03:42:26 +08:00
|
|
|
"kwarg",
|
2006-12-28 14:47:50 +08:00
|
|
|
"kwargannotation",
|
2006-02-27 03:42:26 +08:00
|
|
|
"defaults",
|
2006-10-28 07:31:49 +08:00
|
|
|
"kw_defaults",
|
2006-02-27 03:42:26 +08:00
|
|
|
};
|
2006-12-28 14:47:50 +08:00
|
|
|
static PyTypeObject *arg_type;
|
|
|
|
static PyObject* ast2obj_arg(void*);
|
2007-05-16 02:46:22 +08:00
|
|
|
static char *arg_fields[]={
|
2006-12-28 14:47:50 +08:00
|
|
|
"arg",
|
|
|
|
"annotation",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *keyword_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_keyword(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static char *keyword_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"arg",
|
|
|
|
"value",
|
|
|
|
};
|
2006-03-01 06:47:29 +08:00
|
|
|
static PyTypeObject *alias_type;
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_alias(void*);
|
2006-03-01 06:47:29 +08:00
|
|
|
static char *alias_fields[]={
|
2006-02-27 03:42:26 +08:00
|
|
|
"name",
|
|
|
|
"asname",
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-31 12:42:11 +08:00
|
|
|
static int
|
|
|
|
ast_type_init(PyObject *self, PyObject *args, PyObject *kw)
|
|
|
|
{
|
|
|
|
Py_ssize_t i, numfields = 0;
|
|
|
|
int res = -1;
|
|
|
|
PyObject *key, *value, *fields;
|
|
|
|
fields = PyObject_GetAttrString((PyObject*)Py_TYPE(self), "_fields");
|
|
|
|
if (!fields)
|
|
|
|
PyErr_Clear();
|
|
|
|
if (fields) {
|
|
|
|
numfields = PySequence_Size(fields);
|
|
|
|
if (numfields == -1)
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
res = 0; /* if no error occurs, this stays 0 to the end */
|
|
|
|
if (PyTuple_GET_SIZE(args) > 0) {
|
|
|
|
if (numfields != PyTuple_GET_SIZE(args)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "%.400s constructor takes %s"
|
|
|
|
"%" PY_FORMAT_SIZE_T "d positional argument%s",
|
|
|
|
Py_TYPE(self)->tp_name,
|
|
|
|
numfields == 0 ? "" : "either 0 or ",
|
|
|
|
numfields, numfields == 1 ? "" : "s");
|
|
|
|
res = -1;
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
for (i = 0; i < PyTuple_GET_SIZE(args); i++) {
|
|
|
|
/* cannot be reached when fields is NULL */
|
|
|
|
PyObject *name = PySequence_GetItem(fields, i);
|
|
|
|
if (!name) {
|
|
|
|
res = -1;
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
res = PyObject_SetAttr(self, name, PyTuple_GET_ITEM(args, i));
|
|
|
|
Py_DECREF(name);
|
|
|
|
if (res < 0)
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (kw) {
|
|
|
|
i = 0; /* needed by PyDict_Next */
|
|
|
|
while (PyDict_Next(kw, &i, &key, &value)) {
|
|
|
|
res = PyObject_SetAttr(self, key, value);
|
|
|
|
if (res < 0)
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cleanup:
|
|
|
|
Py_XDECREF(fields);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
/* Pickling support */
|
|
|
|
static PyObject *
|
|
|
|
ast_type_reduce(PyObject *self, PyObject *unused)
|
|
|
|
{
|
|
|
|
PyObject *res;
|
|
|
|
PyObject *dict = PyObject_GetAttrString(self, "__dict__");
|
|
|
|
if (dict == NULL) {
|
|
|
|
if (PyErr_ExceptionMatches(PyExc_AttributeError))
|
|
|
|
PyErr_Clear();
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (dict) {
|
|
|
|
res = Py_BuildValue("O()O", Py_TYPE(self), dict);
|
|
|
|
Py_DECREF(dict);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
return Py_BuildValue("O()", Py_TYPE(self));
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyMethodDef ast_type_methods[] = {
|
|
|
|
{"__reduce__", ast_type_reduce, METH_NOARGS, NULL},
|
|
|
|
{NULL}
|
|
|
|
};
|
|
|
|
|
2008-03-31 12:42:11 +08:00
|
|
|
static PyTypeObject AST_type = {
|
|
|
|
PyVarObject_HEAD_INIT(&PyType_Type, 0)
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
"_ast.AST",
|
2008-03-31 12:42:11 +08:00
|
|
|
sizeof(PyObject),
|
|
|
|
0,
|
|
|
|
0, /* tp_dealloc */
|
|
|
|
0, /* tp_print */
|
|
|
|
0, /* tp_getattr */
|
|
|
|
0, /* tp_setattr */
|
|
|
|
0, /* tp_compare */
|
|
|
|
0, /* tp_repr */
|
|
|
|
0, /* tp_as_number */
|
|
|
|
0, /* tp_as_sequence */
|
|
|
|
0, /* tp_as_mapping */
|
|
|
|
0, /* tp_hash */
|
|
|
|
0, /* tp_call */
|
|
|
|
0, /* tp_str */
|
|
|
|
PyObject_GenericGetAttr, /* tp_getattro */
|
|
|
|
PyObject_GenericSetAttr, /* tp_setattro */
|
|
|
|
0, /* tp_as_buffer */
|
|
|
|
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
|
|
|
|
0, /* tp_doc */
|
|
|
|
0, /* tp_traverse */
|
|
|
|
0, /* tp_clear */
|
|
|
|
0, /* tp_richcompare */
|
|
|
|
0, /* tp_weaklistoffset */
|
|
|
|
0, /* tp_iter */
|
|
|
|
0, /* tp_iternext */
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
ast_type_methods, /* tp_methods */
|
2008-03-31 12:42:11 +08:00
|
|
|
0, /* tp_members */
|
|
|
|
0, /* tp_getset */
|
|
|
|
0, /* tp_base */
|
|
|
|
0, /* tp_dict */
|
|
|
|
0, /* tp_descr_get */
|
|
|
|
0, /* tp_descr_set */
|
|
|
|
0, /* tp_dictoffset */
|
|
|
|
(initproc)ast_type_init, /* tp_init */
|
|
|
|
PyType_GenericAlloc, /* tp_alloc */
|
|
|
|
PyType_GenericNew, /* tp_new */
|
|
|
|
PyObject_Del, /* tp_free */
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyTypeObject* make_type(char *type, PyTypeObject* base, char**fields, int num_fields)
|
|
|
|
{
|
|
|
|
PyObject *fnames, *result;
|
|
|
|
int i;
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
fnames = PyTuple_New(num_fields);
|
|
|
|
if (!fnames) return NULL;
|
|
|
|
for (i = 0; i < num_fields; i++) {
|
2007-08-25 09:33:49 +08:00
|
|
|
PyObject *field = PyUnicode_FromString(fields[i]);
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!field) {
|
|
|
|
Py_DECREF(fnames);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
PyTuple_SET_ITEM(fnames, i, field);
|
|
|
|
}
|
2007-11-03 07:07:07 +08:00
|
|
|
result = PyObject_CallFunction((PyObject*)&PyType_Type, "U(O){sOss}",
|
2006-02-27 23:23:19 +08:00
|
|
|
type, base, "_fields", fnames, "__module__", "_ast");
|
2006-02-27 03:42:26 +08:00
|
|
|
Py_DECREF(fnames);
|
|
|
|
return (PyTypeObject*)result;
|
|
|
|
}
|
|
|
|
|
2006-02-27 23:23:19 +08:00
|
|
|
static int add_attributes(PyTypeObject* type, char**attrs, int num_fields)
|
|
|
|
{
|
2006-04-21 18:40:58 +08:00
|
|
|
int i, result;
|
2008-03-31 12:42:11 +08:00
|
|
|
PyObject *s, *l = PyTuple_New(num_fields);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!l) return 0;
|
2006-04-21 18:40:58 +08:00
|
|
|
for(i = 0; i < num_fields; i++) {
|
2007-08-25 09:33:49 +08:00
|
|
|
s = PyUnicode_FromString(attrs[i]);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!s) {
|
|
|
|
Py_DECREF(l);
|
|
|
|
return 0;
|
|
|
|
}
|
2008-03-31 12:42:11 +08:00
|
|
|
PyTuple_SET_ITEM(l, i, s);
|
2006-02-27 23:23:19 +08:00
|
|
|
}
|
2006-04-21 18:40:58 +08:00
|
|
|
result = PyObject_SetAttrString((PyObject*)type, "_attributes", l) >= 0;
|
|
|
|
Py_DECREF(l);
|
|
|
|
return result;
|
2006-02-27 23:23:19 +08:00
|
|
|
}
|
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
/* Conversion AST -> Python */
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
static PyObject* ast2obj_list(asdl_seq *seq, PyObject* (*func)(void*))
|
|
|
|
{
|
|
|
|
int i, n = asdl_seq_LEN(seq);
|
|
|
|
PyObject *result = PyList_New(n);
|
|
|
|
PyObject *value;
|
|
|
|
if (!result)
|
|
|
|
return NULL;
|
|
|
|
for (i = 0; i < n; i++) {
|
|
|
|
value = func(asdl_seq_GET(seq, i));
|
|
|
|
if (!value) {
|
|
|
|
Py_DECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
PyList_SET_ITEM(result, i, value);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static PyObject* ast2obj_object(void *o)
|
|
|
|
{
|
|
|
|
if (!o)
|
|
|
|
o = Py_None;
|
|
|
|
Py_INCREF((PyObject*)o);
|
|
|
|
return (PyObject*)o;
|
|
|
|
}
|
|
|
|
#define ast2obj_identifier ast2obj_object
|
|
|
|
#define ast2obj_string ast2obj_object
|
|
|
|
|
2007-02-27 02:20:15 +08:00
|
|
|
static PyObject* ast2obj_int(long b)
|
2006-02-27 23:23:19 +08:00
|
|
|
{
|
2007-12-02 22:31:20 +08:00
|
|
|
return PyLong_FromLong(b);
|
2006-02-27 23:23:19 +08:00
|
|
|
}
|
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
/* Conversion Python -> AST */
|
|
|
|
|
|
|
|
static int obj2ast_object(PyObject* obj, PyObject** out, PyArena* arena)
|
|
|
|
{
|
|
|
|
if (obj == Py_None)
|
|
|
|
obj = NULL;
|
|
|
|
if (obj)
|
|
|
|
PyArena_AddPyObject(arena, obj);
|
|
|
|
Py_XINCREF(obj);
|
|
|
|
*out = obj;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define obj2ast_identifier obj2ast_object
|
|
|
|
#define obj2ast_string obj2ast_object
|
|
|
|
|
|
|
|
static int obj2ast_int(PyObject* obj, int* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
if (!PyLong_Check(obj)) {
|
|
|
|
PyObject *s = PyObject_Repr(obj);
|
|
|
|
if (s == NULL) return 1;
|
|
|
|
PyErr_Format(PyExc_ValueError, "invalid integer value: %.400s",
|
|
|
|
PyString_AS_STRING(s));
|
|
|
|
Py_DECREF(s);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
i = (int)PyLong_AsLong(obj);
|
|
|
|
if (i == -1 && PyErr_Occurred())
|
|
|
|
return 1;
|
|
|
|
*out = i;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
static int init_types(void)
|
|
|
|
{
|
2006-04-21 18:40:58 +08:00
|
|
|
static int initialized;
|
2006-02-27 03:42:26 +08:00
|
|
|
if (initialized) return 1;
|
2008-03-31 12:42:11 +08:00
|
|
|
mod_type = make_type("mod", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!mod_type) return 0;
|
|
|
|
if (!add_attributes(mod_type, NULL, 0)) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Module_type = make_type("Module", mod_type, Module_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Module_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Interactive_type = make_type("Interactive", mod_type,
|
|
|
|
Interactive_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Interactive_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Expression_type = make_type("Expression", mod_type, Expression_fields,
|
|
|
|
1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Expression_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Suite_type = make_type("Suite", mod_type, Suite_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Suite_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
stmt_type = make_type("stmt", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!stmt_type) return 0;
|
2006-03-02 06:49:05 +08:00
|
|
|
if (!add_attributes(stmt_type, stmt_attributes, 2)) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
FunctionDef_type = make_type("FunctionDef", stmt_type,
|
2006-12-28 14:47:50 +08:00
|
|
|
FunctionDef_fields, 5);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!FunctionDef_type) return 0;
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
ClassDef_type = make_type("ClassDef", stmt_type, ClassDef_fields, 7);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!ClassDef_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Return_type = make_type("Return", stmt_type, Return_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Return_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Delete_type = make_type("Delete", stmt_type, Delete_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Delete_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Assign_type = make_type("Assign", stmt_type, Assign_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Assign_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
AugAssign_type = make_type("AugAssign", stmt_type, AugAssign_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!AugAssign_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
For_type = make_type("For", stmt_type, For_fields, 4);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!For_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
While_type = make_type("While", stmt_type, While_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!While_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
If_type = make_type("If", stmt_type, If_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!If_type) return 0;
|
2006-02-28 06:32:47 +08:00
|
|
|
With_type = make_type("With", stmt_type, With_fields, 3);
|
|
|
|
if (!With_type) return 0;
|
2007-08-31 08:04:24 +08:00
|
|
|
Raise_type = make_type("Raise", stmt_type, Raise_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Raise_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
TryExcept_type = make_type("TryExcept", stmt_type, TryExcept_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!TryExcept_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
TryFinally_type = make_type("TryFinally", stmt_type, TryFinally_fields,
|
|
|
|
2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!TryFinally_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Assert_type = make_type("Assert", stmt_type, Assert_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Assert_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Import_type = make_type("Import", stmt_type, Import_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Import_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
ImportFrom_type = make_type("ImportFrom", stmt_type, ImportFrom_fields,
|
2006-03-01 00:09:29 +08:00
|
|
|
3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!ImportFrom_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Global_type = make_type("Global", stmt_type, Global_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Global_type) return 0;
|
2007-02-27 14:50:52 +08:00
|
|
|
Nonlocal_type = make_type("Nonlocal", stmt_type, Nonlocal_fields, 1);
|
|
|
|
if (!Nonlocal_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Expr_type = make_type("Expr", stmt_type, Expr_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Expr_type) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Pass_type = make_type("Pass", stmt_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Pass_type) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Break_type = make_type("Break", stmt_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Break_type) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Continue_type = make_type("Continue", stmt_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Continue_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
expr_type = make_type("expr", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!expr_type) return 0;
|
2006-03-02 06:49:05 +08:00
|
|
|
if (!add_attributes(expr_type, expr_attributes, 2)) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
BoolOp_type = make_type("BoolOp", expr_type, BoolOp_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BoolOp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
BinOp_type = make_type("BinOp", expr_type, BinOp_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BinOp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
UnaryOp_type = make_type("UnaryOp", expr_type, UnaryOp_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!UnaryOp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Lambda_type = make_type("Lambda", expr_type, Lambda_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Lambda_type) return 0;
|
2006-02-27 08:24:13 +08:00
|
|
|
IfExp_type = make_type("IfExp", expr_type, IfExp_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!IfExp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Dict_type = make_type("Dict", expr_type, Dict_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Dict_type) return 0;
|
2006-08-28 23:27:34 +08:00
|
|
|
Set_type = make_type("Set", expr_type, Set_fields, 1);
|
|
|
|
if (!Set_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
ListComp_type = make_type("ListComp", expr_type, ListComp_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!ListComp_type) return 0;
|
2007-04-15 20:05:43 +08:00
|
|
|
SetComp_type = make_type("SetComp", expr_type, SetComp_fields, 2);
|
|
|
|
if (!SetComp_type) return 0;
|
Merged revisions 56154-56264 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56155 | neal.norwitz | 2007-07-03 08:59:08 +0300 (Tue, 03 Jul 2007) | 1 line
Get this test working after converting map to return an iterator
................
r56202 | neal.norwitz | 2007-07-09 04:30:09 +0300 (Mon, 09 Jul 2007) | 37 lines
Merged revisions 56124-56201 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56129 | georg.brandl | 2007-06-30 04:01:01 -0700 (Sat, 30 Jun 2007) | 2 lines
Document smtp.SMTPAuthenticationError.
........
r56137 | georg.brandl | 2007-07-01 01:11:35 -0700 (Sun, 01 Jul 2007) | 2 lines
Fix a few webbrowser.py problems.
........
r56143 | georg.brandl | 2007-07-02 04:54:28 -0700 (Mon, 02 Jul 2007) | 2 lines
Remove duplicate sentence from alarm() doc.
........
r56170 | mark.hammond | 2007-07-03 19:03:10 -0700 (Tue, 03 Jul 2007) | 3 lines
copy built files to the PCBuild directory, where tools like
distutils or external build processes can find them.
........
r56176 | kurt.kaiser | 2007-07-05 15:03:39 -0700 (Thu, 05 Jul 2007) | 10 lines
Many calls to tk.call involve an arglist containing a single tuple.
Calls using METH_OLDARGS unpack this tuple; calls using METH_VARARG
don't. Tcl's concatenation of args was affected; IDLE doesn't start.
Modify Tkapp_Call() to unpack single tuple arglists.
Bug 1733943
Ref http://mail.python.org/pipermail/python-checkins/2007-May/060454.html
........
r56177 | neal.norwitz | 2007-07-05 21:13:39 -0700 (Thu, 05 Jul 2007) | 1 line
Fix typo in comment
........
................
r56251 | neal.norwitz | 2007-07-11 10:01:01 +0300 (Wed, 11 Jul 2007) | 1 line
Get working with map returning an iterator (had to fix whitespace too)
................
r56255 | thomas.wouters | 2007-07-11 13:41:37 +0300 (Wed, 11 Jul 2007) | 6 lines
Clean up merge glitch or copy-paste error (the entire module was duplicated,
except the first half even had some more copy-paste errors, referring to
listcomps and genexps instead of setcomps)
................
r56256 | thomas.wouters | 2007-07-11 15:16:01 +0300 (Wed, 11 Jul 2007) | 14 lines
Dict comprehensions. Still needs doc changes (like many python-3000 features
;-). It generates bytecode similar to:
x = {}
for k, v in (generator here):
x[k] = v
except there is no tuple-packing and -unpacking involved. Trivial
measurement suggests it's significantly faster than dict(generator here) (in
the order of 2 to 3 times as fast) but I have not done extensive
measurements.
................
r56263 | guido.van.rossum | 2007-07-11 15:36:26 +0300 (Wed, 11 Jul 2007) | 3 lines
Patch 1724999 by Ali Gholami Rudi -- avoid complaints about dict size
change during iter in destroy call.
................
2007-07-11 21:09:30 +08:00
|
|
|
DictComp_type = make_type("DictComp", expr_type, DictComp_fields, 3);
|
|
|
|
if (!DictComp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
GeneratorExp_type = make_type("GeneratorExp", expr_type,
|
|
|
|
GeneratorExp_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!GeneratorExp_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Yield_type = make_type("Yield", expr_type, Yield_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Yield_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Compare_type = make_type("Compare", expr_type, Compare_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Compare_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Call_type = make_type("Call", expr_type, Call_fields, 5);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Call_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Num_type = make_type("Num", expr_type, Num_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Num_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Str_type = make_type("Str", expr_type, Str_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Str_type) return 0;
|
2007-02-24 03:56:57 +08:00
|
|
|
Bytes_type = make_type("Bytes", expr_type, Bytes_fields, 1);
|
|
|
|
if (!Bytes_type) return 0;
|
2006-09-06 15:06:08 +08:00
|
|
|
Ellipsis_type = make_type("Ellipsis", expr_type, NULL, 0);
|
|
|
|
if (!Ellipsis_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Attribute_type = make_type("Attribute", expr_type, Attribute_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Attribute_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Subscript_type = make_type("Subscript", expr_type, Subscript_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Subscript_type) return 0;
|
Merged revisions 55225-55227,55229-55269 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55238 | guido.van.rossum | 2007-05-10 16:46:05 -0700 (Thu, 10 May 2007) | 9 lines
Merged revisions 55227 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55227 | guido.van.rossum | 2007-05-10 10:20:15 -0700 (Thu, 10 May 2007) | 2 lines
Fix a bug in test_c_api() that caused a negative refcount.
........
................
r55246 | neal.norwitz | 2007-05-11 00:01:52 -0700 (Fri, 11 May 2007) | 1 line
Remove commands.getstatus() it is obsolete.
................
r55248 | neal.norwitz | 2007-05-11 00:29:05 -0700 (Fri, 11 May 2007) | 2 lines
Remove bsddb185 support.
................
r55249 | neal.norwitz | 2007-05-11 00:29:50 -0700 (Fri, 11 May 2007) | 1 line
Remove bsddb185 module too
................
r55250 | neal.norwitz | 2007-05-11 00:32:13 -0700 (Fri, 11 May 2007) | 1 line
bsddb185: Gotta remove from the file checked in, not Setup
................
r55251 | neal.norwitz | 2007-05-11 00:53:26 -0700 (Fri, 11 May 2007) | 1 line
Remove obsolete IRIX modules (as much as I could find, there is probably more)
................
r55252 | neal.norwitz | 2007-05-11 00:55:35 -0700 (Fri, 11 May 2007) | 1 line
Remove SGI turd.
................
r55254 | georg.brandl | 2007-05-11 03:11:01 -0700 (Fri, 11 May 2007) | 2 lines
Add a case for set comprehensions to the "cannot assign to" switch.
................
r55255 | georg.brandl | 2007-05-11 03:11:25 -0700 (Fri, 11 May 2007) | 2 lines
Fix wrong imports.
................
r55261 | georg.brandl | 2007-05-11 07:37:48 -0700 (Fri, 11 May 2007) | 2 lines
Remove removed tex files.
................
r55262 | georg.brandl | 2007-05-11 08:28:41 -0700 (Fri, 11 May 2007) | 2 lines
Commit PEP 3132 implementation.
................
r55264 | georg.brandl | 2007-05-11 08:50:19 -0700 (Fri, 11 May 2007) | 2 lines
Check in the inevitable AST version number and format Py_ssize_t with %zd.
................
r55265 | neal.norwitz | 2007-05-11 09:12:22 -0700 (Fri, 11 May 2007) | 1 line
Remove mention of os.popen* and popen2.* since these will be removed.
................
r55266 | neal.norwitz | 2007-05-11 09:19:57 -0700 (Fri, 11 May 2007) | 1 line
Get doc to build again (almost, the doc is fine)
................
r55267 | neal.norwitz | 2007-05-11 09:21:02 -0700 (Fri, 11 May 2007) | 1 line
Really get doc to build (remove use of string module)
................
r55269 | neal.norwitz | 2007-05-11 09:29:43 -0700 (Fri, 11 May 2007) | 1 line
Add some notes to cleanup later
................
2007-05-12 00:50:42 +08:00
|
|
|
Starred_type = make_type("Starred", expr_type, Starred_fields, 2);
|
|
|
|
if (!Starred_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Name_type = make_type("Name", expr_type, Name_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Name_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
List_type = make_type("List", expr_type, List_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!List_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Tuple_type = make_type("Tuple", expr_type, Tuple_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Tuple_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
expr_context_type = make_type("expr_context", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!expr_context_type) return 0;
|
|
|
|
if (!add_attributes(expr_context_type, NULL, 0)) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Load_type = make_type("Load", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Load_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Load_singleton = PyType_GenericNew(Load_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Load_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Store_type = make_type("Store", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Store_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Store_singleton = PyType_GenericNew(Store_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Store_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Del_type = make_type("Del", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Del_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Del_singleton = PyType_GenericNew(Del_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Del_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
AugLoad_type = make_type("AugLoad", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!AugLoad_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
AugLoad_singleton = PyType_GenericNew(AugLoad_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!AugLoad_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
AugStore_type = make_type("AugStore", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!AugStore_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
AugStore_singleton = PyType_GenericNew(AugStore_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!AugStore_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Param_type = make_type("Param", expr_context_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Param_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Param_singleton = PyType_GenericNew(Param_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Param_singleton) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
slice_type = make_type("slice", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!slice_type) return 0;
|
|
|
|
if (!add_attributes(slice_type, NULL, 0)) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Slice_type = make_type("Slice", slice_type, Slice_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Slice_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
ExtSlice_type = make_type("ExtSlice", slice_type, ExtSlice_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!ExtSlice_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Index_type = make_type("Index", slice_type, Index_fields, 1);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Index_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
boolop_type = make_type("boolop", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!boolop_type) return 0;
|
|
|
|
if (!add_attributes(boolop_type, NULL, 0)) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
And_type = make_type("And", boolop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!And_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
And_singleton = PyType_GenericNew(And_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!And_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Or_type = make_type("Or", boolop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Or_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Or_singleton = PyType_GenericNew(Or_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Or_singleton) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
operator_type = make_type("operator", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!operator_type) return 0;
|
|
|
|
if (!add_attributes(operator_type, NULL, 0)) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Add_type = make_type("Add", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Add_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Add_singleton = PyType_GenericNew(Add_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Add_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Sub_type = make_type("Sub", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Sub_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Sub_singleton = PyType_GenericNew(Sub_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Sub_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Mult_type = make_type("Mult", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Mult_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Mult_singleton = PyType_GenericNew(Mult_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Mult_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Div_type = make_type("Div", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Div_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Div_singleton = PyType_GenericNew(Div_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Div_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Mod_type = make_type("Mod", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Mod_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Mod_singleton = PyType_GenericNew(Mod_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Mod_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Pow_type = make_type("Pow", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Pow_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Pow_singleton = PyType_GenericNew(Pow_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Pow_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
LShift_type = make_type("LShift", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!LShift_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
LShift_singleton = PyType_GenericNew(LShift_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!LShift_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
RShift_type = make_type("RShift", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!RShift_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
RShift_singleton = PyType_GenericNew(RShift_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!RShift_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
BitOr_type = make_type("BitOr", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitOr_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
BitOr_singleton = PyType_GenericNew(BitOr_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitOr_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
BitXor_type = make_type("BitXor", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitXor_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
BitXor_singleton = PyType_GenericNew(BitXor_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitXor_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
BitAnd_type = make_type("BitAnd", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitAnd_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
BitAnd_singleton = PyType_GenericNew(BitAnd_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!BitAnd_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
FloorDiv_type = make_type("FloorDiv", operator_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!FloorDiv_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
FloorDiv_singleton = PyType_GenericNew(FloorDiv_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!FloorDiv_singleton) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
unaryop_type = make_type("unaryop", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!unaryop_type) return 0;
|
|
|
|
if (!add_attributes(unaryop_type, NULL, 0)) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Invert_type = make_type("Invert", unaryop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Invert_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Invert_singleton = PyType_GenericNew(Invert_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Invert_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Not_type = make_type("Not", unaryop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Not_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Not_singleton = PyType_GenericNew(Not_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Not_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
UAdd_type = make_type("UAdd", unaryop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!UAdd_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
UAdd_singleton = PyType_GenericNew(UAdd_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!UAdd_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
USub_type = make_type("USub", unaryop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!USub_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
USub_singleton = PyType_GenericNew(USub_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!USub_singleton) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
cmpop_type = make_type("cmpop", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!cmpop_type) return 0;
|
|
|
|
if (!add_attributes(cmpop_type, NULL, 0)) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Eq_type = make_type("Eq", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Eq_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Eq_singleton = PyType_GenericNew(Eq_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Eq_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
NotEq_type = make_type("NotEq", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!NotEq_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
NotEq_singleton = PyType_GenericNew(NotEq_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!NotEq_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Lt_type = make_type("Lt", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Lt_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Lt_singleton = PyType_GenericNew(Lt_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Lt_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
LtE_type = make_type("LtE", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!LtE_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
LtE_singleton = PyType_GenericNew(LtE_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!LtE_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Gt_type = make_type("Gt", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Gt_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Gt_singleton = PyType_GenericNew(Gt_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Gt_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
GtE_type = make_type("GtE", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!GtE_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
GtE_singleton = PyType_GenericNew(GtE_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!GtE_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
Is_type = make_type("Is", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Is_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
Is_singleton = PyType_GenericNew(Is_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!Is_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
IsNot_type = make_type("IsNot", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!IsNot_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
IsNot_singleton = PyType_GenericNew(IsNot_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!IsNot_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
In_type = make_type("In", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!In_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
In_singleton = PyType_GenericNew(In_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!In_singleton) return 0;
|
2006-02-27 07:40:20 +08:00
|
|
|
NotIn_type = make_type("NotIn", cmpop_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!NotIn_type) return 0;
|
2006-02-27 03:42:26 +08:00
|
|
|
NotIn_singleton = PyType_GenericNew(NotIn_type, NULL, NULL);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!NotIn_singleton) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
comprehension_type = make_type("comprehension", &AST_type,
|
2006-02-27 03:42:26 +08:00
|
|
|
comprehension_fields, 3);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!comprehension_type) return 0;
|
2008-03-31 13:14:30 +08:00
|
|
|
excepthandler_type = make_type("excepthandler", &AST_type, NULL, 0);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!excepthandler_type) return 0;
|
2008-03-31 13:14:30 +08:00
|
|
|
if (!add_attributes(excepthandler_type, excepthandler_attributes, 2))
|
|
|
|
return 0;
|
|
|
|
ExceptHandler_type = make_type("ExceptHandler", excepthandler_type,
|
|
|
|
ExceptHandler_fields, 3);
|
|
|
|
if (!ExceptHandler_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
arguments_type = make_type("arguments", &AST_type, arguments_fields, 8);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!arguments_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
arg_type = make_type("arg", &AST_type, arg_fields, 2);
|
2006-12-28 14:47:50 +08:00
|
|
|
if (!arg_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
keyword_type = make_type("keyword", &AST_type, keyword_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!keyword_type) return 0;
|
2008-03-31 12:42:11 +08:00
|
|
|
alias_type = make_type("alias", &AST_type, alias_fields, 2);
|
2006-02-27 23:23:19 +08:00
|
|
|
if (!alias_type) return 0;
|
|
|
|
initialized = 1;
|
|
|
|
return 1;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
2005-11-14 03:14:20 +08:00
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
static int obj2ast_mod(PyObject* obj, mod_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_stmt(PyObject* obj, stmt_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_expr(PyObject* obj, expr_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_expr_context(PyObject* obj, expr_context_ty* out, PyArena*
|
|
|
|
arena);
|
|
|
|
static int obj2ast_slice(PyObject* obj, slice_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_boolop(PyObject* obj, boolop_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_operator(PyObject* obj, operator_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_unaryop(PyObject* obj, unaryop_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_cmpop(PyObject* obj, cmpop_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_comprehension(PyObject* obj, comprehension_ty* out, PyArena*
|
|
|
|
arena);
|
|
|
|
static int obj2ast_excepthandler(PyObject* obj, excepthandler_ty* out, PyArena*
|
|
|
|
arena);
|
|
|
|
static int obj2ast_arguments(PyObject* obj, arguments_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_arg(PyObject* obj, arg_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_keyword(PyObject* obj, keyword_ty* out, PyArena* arena);
|
|
|
|
static int obj2ast_alias(PyObject* obj, alias_ty* out, PyArena* arena);
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
mod_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Module(asdl_seq * body, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
mod_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (mod_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Module_kind;
|
|
|
|
p->v.Module.body = body;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
mod_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Interactive(asdl_seq * body, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
mod_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (mod_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Interactive_kind;
|
|
|
|
p->v.Interactive.body = body;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
mod_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Expression(expr_ty body, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
mod_ty p;
|
|
|
|
if (!body) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field body is required for Expression");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (mod_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Expression_kind;
|
|
|
|
p->v.Expression.body = body;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
mod_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Suite(asdl_seq * body, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
mod_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (mod_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Suite_kind;
|
|
|
|
p->v.Suite.body = body;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
|
|
|
FunctionDef(identifier name, arguments_ty args, asdl_seq * body, asdl_seq *
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
decorator_list, expr_ty returns, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!name) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field name is required for FunctionDef");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!args) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field args is required for FunctionDef");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = FunctionDef_kind;
|
|
|
|
p->v.FunctionDef.name = name;
|
|
|
|
p->v.FunctionDef.args = args;
|
|
|
|
p->v.FunctionDef.body = body;
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
p->v.FunctionDef.decorator_list = decorator_list;
|
2006-12-28 14:47:50 +08:00
|
|
|
p->v.FunctionDef.returns = returns;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2007-03-18 23:41:51 +08:00
|
|
|
ClassDef(identifier name, asdl_seq * bases, asdl_seq * keywords, expr_ty
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
starargs, expr_ty kwargs, asdl_seq * body, asdl_seq * decorator_list,
|
|
|
|
int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!name) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field name is required for ClassDef");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = ClassDef_kind;
|
|
|
|
p->v.ClassDef.name = name;
|
|
|
|
p->v.ClassDef.bases = bases;
|
2007-03-18 23:41:51 +08:00
|
|
|
p->v.ClassDef.keywords = keywords;
|
|
|
|
p->v.ClassDef.starargs = starargs;
|
|
|
|
p->v.ClassDef.kwargs = kwargs;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->v.ClassDef.body = body;
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
p->v.ClassDef.decorator_list = decorator_list;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Return(expr_ty value, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Return_kind;
|
|
|
|
p->v.Return.value = value;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Delete(asdl_seq * targets, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Delete_kind;
|
|
|
|
p->v.Delete.targets = targets;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Assign(asdl_seq * targets, expr_ty value, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Assign");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Assign_kind;
|
|
|
|
p->v.Assign.targets = targets;
|
|
|
|
p->v.Assign.value = value;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
AugAssign(expr_ty target, operator_ty op, expr_ty value, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!target) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field target is required for AugAssign");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!op) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field op is required for AugAssign");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for AugAssign");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = AugAssign_kind;
|
|
|
|
p->v.AugAssign.target = target;
|
|
|
|
p->v.AugAssign.op = op;
|
|
|
|
p->v.AugAssign.value = value;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
|
|
|
For(expr_ty target, expr_ty iter, asdl_seq * body, asdl_seq * orelse, int
|
2006-03-02 06:49:05 +08:00
|
|
|
lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!target) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field target is required for For");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!iter) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field iter is required for For");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = For_kind;
|
|
|
|
p->v.For.target = target;
|
|
|
|
p->v.For.iter = iter;
|
|
|
|
p->v.For.body = body;
|
|
|
|
p->v.For.orelse = orelse;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
While(expr_ty test, asdl_seq * body, asdl_seq * orelse, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!test) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field test is required for While");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = While_kind;
|
|
|
|
p->v.While.test = test;
|
|
|
|
p->v.While.body = body;
|
|
|
|
p->v.While.orelse = orelse;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
If(expr_ty test, asdl_seq * body, asdl_seq * orelse, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!test) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field test is required for If");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = If_kind;
|
|
|
|
p->v.If.test = test;
|
|
|
|
p->v.If.body = body;
|
|
|
|
p->v.If.orelse = orelse;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2006-02-28 06:32:47 +08:00
|
|
|
stmt_ty
|
|
|
|
With(expr_ty context_expr, expr_ty optional_vars, asdl_seq * body, int lineno,
|
2006-03-02 06:49:05 +08:00
|
|
|
int col_offset, PyArena *arena)
|
2006-02-28 06:32:47 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!context_expr) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field context_expr is required for With");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2006-02-28 06:32:47 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = With_kind;
|
|
|
|
p->v.With.context_expr = context_expr;
|
|
|
|
p->v.With.optional_vars = optional_vars;
|
|
|
|
p->v.With.body = body;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2006-02-28 06:32:47 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
stmt_ty
|
2007-08-31 08:04:24 +08:00
|
|
|
Raise(expr_ty exc, expr_ty cause, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Raise_kind;
|
2007-08-31 08:04:24 +08:00
|
|
|
p->v.Raise.exc = exc;
|
|
|
|
p->v.Raise.cause = cause;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
TryExcept(asdl_seq * body, asdl_seq * handlers, asdl_seq * orelse, int lineno,
|
2006-03-02 06:49:05 +08:00
|
|
|
int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = TryExcept_kind;
|
|
|
|
p->v.TryExcept.body = body;
|
|
|
|
p->v.TryExcept.handlers = handlers;
|
|
|
|
p->v.TryExcept.orelse = orelse;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
TryFinally(asdl_seq * body, asdl_seq * finalbody, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = TryFinally_kind;
|
|
|
|
p->v.TryFinally.body = body;
|
|
|
|
p->v.TryFinally.finalbody = finalbody;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Assert(expr_ty test, expr_ty msg, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!test) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field test is required for Assert");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Assert_kind;
|
|
|
|
p->v.Assert.test = test;
|
|
|
|
p->v.Assert.msg = msg;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Import(asdl_seq * names, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Import_kind;
|
|
|
|
p->v.Import.names = names;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
ImportFrom(identifier module, asdl_seq * names, int level, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!module) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field module is required for ImportFrom");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = ImportFrom_kind;
|
|
|
|
p->v.ImportFrom.module = module;
|
|
|
|
p->v.ImportFrom.names = names;
|
2006-03-01 00:09:29 +08:00
|
|
|
p->v.ImportFrom.level = level;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Global(asdl_seq * names, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Global_kind;
|
|
|
|
p->v.Global.names = names;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2007-02-27 14:50:52 +08:00
|
|
|
stmt_ty
|
|
|
|
Nonlocal(asdl_seq * names, int lineno, int col_offset, PyArena *arena)
|
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
|
|
|
if (!p)
|
|
|
|
return NULL;
|
|
|
|
p->kind = Nonlocal_kind;
|
|
|
|
p->v.Nonlocal.names = names;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Expr(expr_ty value, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Expr");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Expr_kind;
|
|
|
|
p->v.Expr.value = value;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Pass(int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Pass_kind;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Break(int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Break_kind;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
stmt_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Continue(int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
stmt_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (stmt_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Continue_kind;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
BoolOp(boolop_ty op, asdl_seq * values, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!op) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field op is required for BoolOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = BoolOp_kind;
|
|
|
|
p->v.BoolOp.op = op;
|
|
|
|
p->v.BoolOp.values = values;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
BinOp(expr_ty left, operator_ty op, expr_ty right, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!left) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field left is required for BinOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!op) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field op is required for BinOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!right) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field right is required for BinOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = BinOp_kind;
|
|
|
|
p->v.BinOp.left = left;
|
|
|
|
p->v.BinOp.op = op;
|
|
|
|
p->v.BinOp.right = right;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
UnaryOp(unaryop_ty op, expr_ty operand, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!op) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field op is required for UnaryOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!operand) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field operand is required for UnaryOp");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = UnaryOp_kind;
|
|
|
|
p->v.UnaryOp.op = op;
|
|
|
|
p->v.UnaryOp.operand = operand;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Lambda(arguments_ty args, expr_ty body, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!args) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field args is required for Lambda");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!body) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field body is required for Lambda");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Lambda_kind;
|
|
|
|
p->v.Lambda.args = args;
|
|
|
|
p->v.Lambda.body = body;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2006-02-27 08:24:13 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
IfExp(expr_ty test, expr_ty body, expr_ty orelse, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2006-02-27 08:24:13 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!test) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field test is required for IfExp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!body) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field body is required for IfExp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!orelse) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field orelse is required for IfExp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2006-02-27 08:24:13 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = IfExp_kind;
|
|
|
|
p->v.IfExp.test = test;
|
|
|
|
p->v.IfExp.body = body;
|
|
|
|
p->v.IfExp.orelse = orelse;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2006-02-27 08:24:13 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Dict(asdl_seq * keys, asdl_seq * values, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Dict_kind;
|
|
|
|
p->v.Dict.keys = keys;
|
|
|
|
p->v.Dict.values = values;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2006-08-28 23:27:34 +08:00
|
|
|
expr_ty
|
|
|
|
Set(asdl_seq * elts, int lineno, int col_offset, PyArena *arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2006-08-28 23:27:34 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Set_kind;
|
|
|
|
p->v.Set.elts = elts;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
ListComp(expr_ty elt, asdl_seq * generators, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!elt) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field elt is required for ListComp");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = ListComp_kind;
|
|
|
|
p->v.ListComp.elt = elt;
|
|
|
|
p->v.ListComp.generators = generators;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2007-04-15 20:05:43 +08:00
|
|
|
expr_ty
|
|
|
|
SetComp(expr_ty elt, asdl_seq * generators, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!elt) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field elt is required for SetComp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
|
|
|
if (!p)
|
|
|
|
return NULL;
|
|
|
|
p->kind = SetComp_kind;
|
|
|
|
p->v.SetComp.elt = elt;
|
|
|
|
p->v.SetComp.generators = generators;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
Merged revisions 56154-56264 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56155 | neal.norwitz | 2007-07-03 08:59:08 +0300 (Tue, 03 Jul 2007) | 1 line
Get this test working after converting map to return an iterator
................
r56202 | neal.norwitz | 2007-07-09 04:30:09 +0300 (Mon, 09 Jul 2007) | 37 lines
Merged revisions 56124-56201 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56129 | georg.brandl | 2007-06-30 04:01:01 -0700 (Sat, 30 Jun 2007) | 2 lines
Document smtp.SMTPAuthenticationError.
........
r56137 | georg.brandl | 2007-07-01 01:11:35 -0700 (Sun, 01 Jul 2007) | 2 lines
Fix a few webbrowser.py problems.
........
r56143 | georg.brandl | 2007-07-02 04:54:28 -0700 (Mon, 02 Jul 2007) | 2 lines
Remove duplicate sentence from alarm() doc.
........
r56170 | mark.hammond | 2007-07-03 19:03:10 -0700 (Tue, 03 Jul 2007) | 3 lines
copy built files to the PCBuild directory, where tools like
distutils or external build processes can find them.
........
r56176 | kurt.kaiser | 2007-07-05 15:03:39 -0700 (Thu, 05 Jul 2007) | 10 lines
Many calls to tk.call involve an arglist containing a single tuple.
Calls using METH_OLDARGS unpack this tuple; calls using METH_VARARG
don't. Tcl's concatenation of args was affected; IDLE doesn't start.
Modify Tkapp_Call() to unpack single tuple arglists.
Bug 1733943
Ref http://mail.python.org/pipermail/python-checkins/2007-May/060454.html
........
r56177 | neal.norwitz | 2007-07-05 21:13:39 -0700 (Thu, 05 Jul 2007) | 1 line
Fix typo in comment
........
................
r56251 | neal.norwitz | 2007-07-11 10:01:01 +0300 (Wed, 11 Jul 2007) | 1 line
Get working with map returning an iterator (had to fix whitespace too)
................
r56255 | thomas.wouters | 2007-07-11 13:41:37 +0300 (Wed, 11 Jul 2007) | 6 lines
Clean up merge glitch or copy-paste error (the entire module was duplicated,
except the first half even had some more copy-paste errors, referring to
listcomps and genexps instead of setcomps)
................
r56256 | thomas.wouters | 2007-07-11 15:16:01 +0300 (Wed, 11 Jul 2007) | 14 lines
Dict comprehensions. Still needs doc changes (like many python-3000 features
;-). It generates bytecode similar to:
x = {}
for k, v in (generator here):
x[k] = v
except there is no tuple-packing and -unpacking involved. Trivial
measurement suggests it's significantly faster than dict(generator here) (in
the order of 2 to 3 times as fast) but I have not done extensive
measurements.
................
r56263 | guido.van.rossum | 2007-07-11 15:36:26 +0300 (Wed, 11 Jul 2007) | 3 lines
Patch 1724999 by Ali Gholami Rudi -- avoid complaints about dict size
change during iter in destroy call.
................
2007-07-11 21:09:30 +08:00
|
|
|
expr_ty
|
|
|
|
DictComp(expr_ty key, expr_ty value, asdl_seq * generators, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!key) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field key is required for DictComp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for DictComp");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
|
|
|
if (!p)
|
|
|
|
return NULL;
|
|
|
|
p->kind = DictComp_kind;
|
|
|
|
p->v.DictComp.key = key;
|
|
|
|
p->v.DictComp.value = value;
|
|
|
|
p->v.DictComp.generators = generators;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
GeneratorExp(expr_ty elt, asdl_seq * generators, int lineno, int col_offset,
|
|
|
|
PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!elt) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field elt is required for GeneratorExp");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = GeneratorExp_kind;
|
|
|
|
p->v.GeneratorExp.elt = elt;
|
|
|
|
p->v.GeneratorExp.generators = generators;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Yield(expr_ty value, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Yield_kind;
|
|
|
|
p->v.Yield.value = value;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-04-21 18:40:58 +08:00
|
|
|
Compare(expr_ty left, asdl_int_seq * ops, asdl_seq * comparators, int lineno,
|
|
|
|
int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!left) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field left is required for Compare");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Compare_kind;
|
|
|
|
p->v.Compare.left = left;
|
|
|
|
p->v.Compare.ops = ops;
|
|
|
|
p->v.Compare.comparators = comparators;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
|
|
|
Call(expr_ty func, asdl_seq * args, asdl_seq * keywords, expr_ty starargs,
|
2006-03-02 06:49:05 +08:00
|
|
|
expr_ty kwargs, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!func) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field func is required for Call");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Call_kind;
|
|
|
|
p->v.Call.func = func;
|
|
|
|
p->v.Call.args = args;
|
|
|
|
p->v.Call.keywords = keywords;
|
|
|
|
p->v.Call.starargs = starargs;
|
|
|
|
p->v.Call.kwargs = kwargs;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Num(object n, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!n) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field n is required for Num");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Num_kind;
|
|
|
|
p->v.Num.n = n;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Str(string s, int lineno, int col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!s) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field s is required for Str");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Str_kind;
|
|
|
|
p->v.Str.s = s;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2007-02-24 03:56:57 +08:00
|
|
|
expr_ty
|
|
|
|
Bytes(string s, int lineno, int col_offset, PyArena *arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!s) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field s is required for Bytes");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2007-02-24 03:56:57 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Bytes_kind;
|
|
|
|
p->v.Bytes.s = s;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2006-09-06 15:06:08 +08:00
|
|
|
expr_ty
|
|
|
|
Ellipsis(int lineno, int col_offset, PyArena *arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2006-09-06 15:06:08 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Ellipsis_kind;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Attribute(expr_ty value, identifier attr, expr_context_ty ctx, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Attribute");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!attr) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field attr is required for Attribute");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for Attribute");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Attribute_kind;
|
|
|
|
p->v.Attribute.value = value;
|
|
|
|
p->v.Attribute.attr = attr;
|
|
|
|
p->v.Attribute.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Subscript(expr_ty value, slice_ty slice, expr_context_ty ctx, int lineno, int
|
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Subscript");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!slice) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field slice is required for Subscript");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for Subscript");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Subscript_kind;
|
|
|
|
p->v.Subscript.value = value;
|
|
|
|
p->v.Subscript.slice = slice;
|
|
|
|
p->v.Subscript.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
Merged revisions 55225-55227,55229-55269 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55238 | guido.van.rossum | 2007-05-10 16:46:05 -0700 (Thu, 10 May 2007) | 9 lines
Merged revisions 55227 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55227 | guido.van.rossum | 2007-05-10 10:20:15 -0700 (Thu, 10 May 2007) | 2 lines
Fix a bug in test_c_api() that caused a negative refcount.
........
................
r55246 | neal.norwitz | 2007-05-11 00:01:52 -0700 (Fri, 11 May 2007) | 1 line
Remove commands.getstatus() it is obsolete.
................
r55248 | neal.norwitz | 2007-05-11 00:29:05 -0700 (Fri, 11 May 2007) | 2 lines
Remove bsddb185 support.
................
r55249 | neal.norwitz | 2007-05-11 00:29:50 -0700 (Fri, 11 May 2007) | 1 line
Remove bsddb185 module too
................
r55250 | neal.norwitz | 2007-05-11 00:32:13 -0700 (Fri, 11 May 2007) | 1 line
bsddb185: Gotta remove from the file checked in, not Setup
................
r55251 | neal.norwitz | 2007-05-11 00:53:26 -0700 (Fri, 11 May 2007) | 1 line
Remove obsolete IRIX modules (as much as I could find, there is probably more)
................
r55252 | neal.norwitz | 2007-05-11 00:55:35 -0700 (Fri, 11 May 2007) | 1 line
Remove SGI turd.
................
r55254 | georg.brandl | 2007-05-11 03:11:01 -0700 (Fri, 11 May 2007) | 2 lines
Add a case for set comprehensions to the "cannot assign to" switch.
................
r55255 | georg.brandl | 2007-05-11 03:11:25 -0700 (Fri, 11 May 2007) | 2 lines
Fix wrong imports.
................
r55261 | georg.brandl | 2007-05-11 07:37:48 -0700 (Fri, 11 May 2007) | 2 lines
Remove removed tex files.
................
r55262 | georg.brandl | 2007-05-11 08:28:41 -0700 (Fri, 11 May 2007) | 2 lines
Commit PEP 3132 implementation.
................
r55264 | georg.brandl | 2007-05-11 08:50:19 -0700 (Fri, 11 May 2007) | 2 lines
Check in the inevitable AST version number and format Py_ssize_t with %zd.
................
r55265 | neal.norwitz | 2007-05-11 09:12:22 -0700 (Fri, 11 May 2007) | 1 line
Remove mention of os.popen* and popen2.* since these will be removed.
................
r55266 | neal.norwitz | 2007-05-11 09:19:57 -0700 (Fri, 11 May 2007) | 1 line
Get doc to build again (almost, the doc is fine)
................
r55267 | neal.norwitz | 2007-05-11 09:21:02 -0700 (Fri, 11 May 2007) | 1 line
Really get doc to build (remove use of string module)
................
r55269 | neal.norwitz | 2007-05-11 09:29:43 -0700 (Fri, 11 May 2007) | 1 line
Add some notes to cleanup later
................
2007-05-12 00:50:42 +08:00
|
|
|
expr_ty
|
|
|
|
Starred(expr_ty value, expr_context_ty ctx, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Starred");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for Starred");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
|
|
|
if (!p)
|
|
|
|
return NULL;
|
|
|
|
p->kind = Starred_kind;
|
|
|
|
p->v.Starred.value = value;
|
|
|
|
p->v.Starred.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Name(identifier id, expr_context_ty ctx, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!id) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field id is required for Name");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for Name");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Name_kind;
|
|
|
|
p->v.Name.id = id;
|
|
|
|
p->v.Name.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
List(asdl_seq * elts, expr_context_ty ctx, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for List");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = List_kind;
|
|
|
|
p->v.List.elts = elts;
|
|
|
|
p->v.List.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
expr_ty
|
2006-03-02 06:49:05 +08:00
|
|
|
Tuple(asdl_seq * elts, expr_context_ty ctx, int lineno, int col_offset, PyArena
|
|
|
|
*arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
expr_ty p;
|
|
|
|
if (!ctx) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field ctx is required for Tuple");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (expr_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Tuple_kind;
|
|
|
|
p->v.Tuple.elts = elts;
|
|
|
|
p->v.Tuple.ctx = ctx;
|
|
|
|
p->lineno = lineno;
|
2006-03-02 06:49:05 +08:00
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
slice_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Slice(expr_ty lower, expr_ty upper, expr_ty step, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
slice_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (slice_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Slice_kind;
|
|
|
|
p->v.Slice.lower = lower;
|
|
|
|
p->v.Slice.upper = upper;
|
|
|
|
p->v.Slice.step = step;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
slice_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
ExtSlice(asdl_seq * dims, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
slice_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (slice_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = ExtSlice_kind;
|
|
|
|
p->v.ExtSlice.dims = dims;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
slice_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
Index(expr_ty value, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
slice_ty p;
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for Index");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (slice_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->kind = Index_kind;
|
|
|
|
p->v.Index.value = value;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
comprehension_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
comprehension(expr_ty target, expr_ty iter, asdl_seq * ifs, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
comprehension_ty p;
|
|
|
|
if (!target) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field target is required for comprehension");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!iter) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field iter is required for comprehension");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (comprehension_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->target = target;
|
|
|
|
p->iter = iter;
|
|
|
|
p->ifs = ifs;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
excepthandler_ty
|
2008-03-31 13:14:30 +08:00
|
|
|
ExceptHandler(expr_ty type, identifier name, asdl_seq * body, int lineno, int
|
2006-04-21 18:40:58 +08:00
|
|
|
col_offset, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
excepthandler_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (excepthandler_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
2008-03-31 13:14:30 +08:00
|
|
|
p->kind = ExceptHandler_kind;
|
|
|
|
p->v.ExceptHandler.type = type;
|
|
|
|
p->v.ExceptHandler.name = name;
|
|
|
|
p->v.ExceptHandler.body = body;
|
2006-04-21 18:40:58 +08:00
|
|
|
p->lineno = lineno;
|
|
|
|
p->col_offset = col_offset;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
arguments_ty
|
2006-12-28 14:47:50 +08:00
|
|
|
arguments(asdl_seq * args, identifier vararg, expr_ty varargannotation,
|
|
|
|
asdl_seq * kwonlyargs, identifier kwarg, expr_ty kwargannotation,
|
|
|
|
asdl_seq * defaults, asdl_seq * kw_defaults, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
arguments_ty p;
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (arguments_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->args = args;
|
|
|
|
p->vararg = vararg;
|
2006-12-28 14:47:50 +08:00
|
|
|
p->varargannotation = varargannotation;
|
2006-10-28 07:31:49 +08:00
|
|
|
p->kwonlyargs = kwonlyargs;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->kwarg = kwarg;
|
2006-12-28 14:47:50 +08:00
|
|
|
p->kwargannotation = kwargannotation;
|
2005-10-21 03:59:25 +08:00
|
|
|
p->defaults = defaults;
|
2006-10-28 07:31:49 +08:00
|
|
|
p->kw_defaults = kw_defaults;
|
2005-10-21 03:59:25 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2006-12-28 14:47:50 +08:00
|
|
|
arg_ty
|
2007-05-16 02:46:22 +08:00
|
|
|
arg(identifier arg, expr_ty annotation, PyArena *arena)
|
2006-12-28 14:47:50 +08:00
|
|
|
{
|
|
|
|
arg_ty p;
|
|
|
|
if (!arg) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
2007-05-16 02:46:22 +08:00
|
|
|
"field arg is required for arg");
|
2006-12-28 14:47:50 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
p = (arg_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2006-12-28 14:47:50 +08:00
|
|
|
return NULL;
|
2007-05-16 02:46:22 +08:00
|
|
|
p->arg = arg;
|
|
|
|
p->annotation = annotation;
|
2006-12-28 14:47:50 +08:00
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
keyword_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
keyword(identifier arg, expr_ty value, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
keyword_ty p;
|
|
|
|
if (!arg) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field arg is required for keyword");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (!value) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field value is required for keyword");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (keyword_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->arg = arg;
|
|
|
|
p->value = value;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
alias_ty
|
2005-12-18 04:54:49 +08:00
|
|
|
alias(identifier name, identifier asname, PyArena *arena)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
|
|
|
alias_ty p;
|
|
|
|
if (!name) {
|
|
|
|
PyErr_SetString(PyExc_ValueError,
|
|
|
|
"field name is required for alias");
|
|
|
|
return NULL;
|
|
|
|
}
|
2005-12-18 04:54:49 +08:00
|
|
|
p = (alias_ty)PyArena_Malloc(arena, sizeof(*p));
|
2007-02-27 02:20:15 +08:00
|
|
|
if (!p)
|
2005-10-21 03:59:25 +08:00
|
|
|
return NULL;
|
|
|
|
p->name = name;
|
|
|
|
p->asname = asname;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2005-11-14 03:14:20 +08:00
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
PyObject*
|
|
|
|
ast2obj_mod(void* _o)
|
2005-11-14 03:14:20 +08:00
|
|
|
{
|
2006-02-27 03:42:26 +08:00
|
|
|
mod_ty o = (mod_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
2005-11-14 03:14:20 +08:00
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
switch (o->kind) {
|
|
|
|
case Module_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Module_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Module.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Interactive_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Interactive_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Interactive.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Expression_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Expression_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Expression.body);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Suite_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Suite_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Suite.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
}
|
2006-02-27 03:42:26 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
2005-10-21 03:59:25 +08:00
|
|
|
}
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
PyObject*
|
|
|
|
ast2obj_stmt(void* _o)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
2006-02-27 03:42:26 +08:00
|
|
|
stmt_ty o = (stmt_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
switch (o->kind) {
|
|
|
|
case FunctionDef_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(FunctionDef_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_identifier(o->v.FunctionDef.name);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "name", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_arguments(o->v.FunctionDef.args);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "args", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.FunctionDef.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
value = ast2obj_list(o->v.FunctionDef.decorator_list,
|
|
|
|
ast2obj_expr);
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!value) goto failed;
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
if (PyObject_SetAttrString(result, "decorator_list", value) ==
|
|
|
|
-1)
|
2006-02-27 03:42:26 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-12-28 14:47:50 +08:00
|
|
|
value = ast2obj_expr(o->v.FunctionDef.returns);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "returns", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case ClassDef_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(ClassDef_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_identifier(o->v.ClassDef.name);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "name", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.ClassDef.bases, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "bases", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2007-03-18 23:41:51 +08:00
|
|
|
value = ast2obj_list(o->v.ClassDef.keywords, ast2obj_keyword);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "keywords", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.ClassDef.starargs);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "starargs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.ClassDef.kwargs);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kwargs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
value = ast2obj_list(o->v.ClassDef.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
Merged revisions 55407-55513 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55413 | fred.drake | 2007-05-17 12:30:10 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
................
r55430 | jack.diederich | 2007-05-18 06:39:59 -0700 (Fri, 18 May 2007) | 1 line
Implements class decorators, PEP 3129.
................
r55432 | guido.van.rossum | 2007-05-18 08:09:41 -0700 (Fri, 18 May 2007) | 2 lines
obsubmit.
................
r55434 | guido.van.rossum | 2007-05-18 09:39:10 -0700 (Fri, 18 May 2007) | 3 lines
Fix bug in test_inspect. (I presume this is how it should be fixed;
Jack Diedrich, please verify.)
................
r55460 | brett.cannon | 2007-05-20 00:31:57 -0700 (Sun, 20 May 2007) | 4 lines
Remove the imageop module. With imgfile already removed in Python 3.0 and
rgbimg gone in Python 2.6 the unit tests themselves were made worthless. Plus
third-party libraries perform the same function much better.
................
r55469 | neal.norwitz | 2007-05-20 11:28:20 -0700 (Sun, 20 May 2007) | 118 lines
Merged revisions 55324-55467 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55348 | georg.brandl | 2007-05-15 13:19:34 -0700 (Tue, 15 May 2007) | 4 lines
HTML-escape the plain traceback in cgitb's HTML output, to prevent
the traceback inadvertently or maliciously closing the comment and
injecting HTML into the error page.
........
r55372 | neal.norwitz | 2007-05-15 21:33:50 -0700 (Tue, 15 May 2007) | 6 lines
Port rev 55353 from Guido:
Add what looks like a necessary call to PyErr_NoMemory() when PyMem_MALLOC()
fails.
Will backport.
........
r55377 | neal.norwitz | 2007-05-15 22:06:33 -0700 (Tue, 15 May 2007) | 1 line
Mention removal of some directories for obsolete platforms
........
r55380 | brett.cannon | 2007-05-15 22:50:03 -0700 (Tue, 15 May 2007) | 2 lines
Change the maintainer of the BeOS port.
........
r55383 | georg.brandl | 2007-05-16 06:44:18 -0700 (Wed, 16 May 2007) | 2 lines
Bug #1719995: don't use deprecated method in sets example.
........
r55386 | neal.norwitz | 2007-05-16 13:05:11 -0700 (Wed, 16 May 2007) | 5 lines
Fix bug in marshal where bad data would cause a segfault due to
lack of an infinite recursion check.
Contributed by Damien Miller at Google.
........
r55389 | brett.cannon | 2007-05-16 15:42:29 -0700 (Wed, 16 May 2007) | 6 lines
Remove the gopherlib module. It has been raising a DeprecationWarning since
Python 2.5.
Also remove gopher support from urllib/urllib2. As both imported gopherlib the
usage of the support would have raised a DeprecationWarning.
........
r55394 | raymond.hettinger | 2007-05-16 18:08:04 -0700 (Wed, 16 May 2007) | 1 line
calendar.py gets no benefit from xrange() instead of range()
........
r55395 | brett.cannon | 2007-05-16 19:02:56 -0700 (Wed, 16 May 2007) | 3 lines
Complete deprecation of BaseException.message. Some subclasses were directly
accessing the message attribute instead of using the descriptor.
........
r55396 | neal.norwitz | 2007-05-16 23:11:36 -0700 (Wed, 16 May 2007) | 4 lines
Reduce the max stack depth to see if this fixes the segfaults on
Windows and some other boxes. If this is successful, this rev should
be backported. I'm not sure how close to the limit we should push this.
........
r55397 | neal.norwitz | 2007-05-16 23:23:50 -0700 (Wed, 16 May 2007) | 4 lines
Set the depth to something very small to try to determine if the
crashes on Windows are really due to the stack size or possibly
some other problem.
........
r55398 | neal.norwitz | 2007-05-17 00:04:46 -0700 (Thu, 17 May 2007) | 4 lines
Last try for tweaking the max stack depth. 5000 was the original value,
4000 didn't work either. 1000 does work on Windows. If 2000 works,
that will hopefully be a reasonable balance.
........
r55412 | fred.drake | 2007-05-17 12:29:58 -0700 (Thu, 17 May 2007) | 1 line
fix argument name in documentation; match the implementation
........
r55427 | neal.norwitz | 2007-05-17 22:47:16 -0700 (Thu, 17 May 2007) | 1 line
Verify neither dumps or loads overflow the stack and segfault.
........
r55446 | collin.winter | 2007-05-18 16:11:24 -0700 (Fri, 18 May 2007) | 1 line
Backport PEP 3110's new 'except' syntax to 2.6.
........
r55448 | raymond.hettinger | 2007-05-18 18:11:16 -0700 (Fri, 18 May 2007) | 1 line
Improvements to NamedTuple's implementation, tests, and documentation
........
r55449 | raymond.hettinger | 2007-05-18 18:50:11 -0700 (Fri, 18 May 2007) | 1 line
Fix beginner mistake -- don't mix spaces and tabs.
........
r55450 | neal.norwitz | 2007-05-18 20:48:47 -0700 (Fri, 18 May 2007) | 1 line
Clear data so random memory does not get freed. Will backport.
........
r55452 | neal.norwitz | 2007-05-18 21:34:55 -0700 (Fri, 18 May 2007) | 3 lines
Whoops, need to pay attention to those test failures.
Move the clear to *before* the first use, not after.
........
r55453 | neal.norwitz | 2007-05-18 21:35:52 -0700 (Fri, 18 May 2007) | 1 line
Give some clue as to what happened if the test fails.
........
r55455 | georg.brandl | 2007-05-19 11:09:26 -0700 (Sat, 19 May 2007) | 2 lines
Fix docstring for add_package in site.py.
........
r55458 | brett.cannon | 2007-05-20 00:09:50 -0700 (Sun, 20 May 2007) | 2 lines
Remove the rgbimg module. It has been deprecated since Python 2.5.
........
r55465 | nick.coghlan | 2007-05-20 04:12:49 -0700 (Sun, 20 May 2007) | 1 line
Fix typo in example (should be backported, but my maintenance branch is woefully out of date)
........
................
r55472 | brett.cannon | 2007-05-20 12:06:18 -0700 (Sun, 20 May 2007) | 2 lines
Remove imageop from the Windows build process.
................
r55486 | neal.norwitz | 2007-05-20 23:59:52 -0700 (Sun, 20 May 2007) | 1 line
Remove callable() builtin
................
r55506 | neal.norwitz | 2007-05-22 00:43:29 -0700 (Tue, 22 May 2007) | 78 lines
Merged revisions 55468-55505 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55468 | neal.norwitz | 2007-05-20 11:06:27 -0700 (Sun, 20 May 2007) | 1 line
rotor is long gone.
........
r55470 | neal.norwitz | 2007-05-20 11:43:00 -0700 (Sun, 20 May 2007) | 1 line
Update directories/files at the top-level.
........
r55471 | brett.cannon | 2007-05-20 12:05:06 -0700 (Sun, 20 May 2007) | 2 lines
Try to remove rgbimg from Windows builds.
........
r55474 | brett.cannon | 2007-05-20 16:17:38 -0700 (Sun, 20 May 2007) | 4 lines
Remove the macfs module. This led to the deprecation of macostools.touched();
it completely relied on macfs and is a no-op on OS X according to code
comments.
........
r55476 | brett.cannon | 2007-05-20 16:56:18 -0700 (Sun, 20 May 2007) | 3 lines
Move imgfile import to the global namespace to trigger an import error ASAP to
prevent creation of a test file.
........
r55477 | brett.cannon | 2007-05-20 16:57:38 -0700 (Sun, 20 May 2007) | 3 lines
Cause posixfile to raise a DeprecationWarning. Documented as deprecated since
Ptyhon 1.5.
........
r55479 | andrew.kuchling | 2007-05-20 17:03:15 -0700 (Sun, 20 May 2007) | 1 line
Note removed modules
........
r55481 | martin.v.loewis | 2007-05-20 21:35:47 -0700 (Sun, 20 May 2007) | 2 lines
Add Alexandre Vassalotti.
........
r55482 | george.yoshida | 2007-05-20 21:41:21 -0700 (Sun, 20 May 2007) | 4 lines
fix against r55474 [Remove the macfs module]
Remove "libmacfs.tex" from Makefile.deps and mac/mac.tex.
........
r55487 | raymond.hettinger | 2007-05-21 01:13:35 -0700 (Mon, 21 May 2007) | 1 line
Replace assertion with straight error-checking.
........
r55489 | raymond.hettinger | 2007-05-21 09:40:10 -0700 (Mon, 21 May 2007) | 1 line
Allow all alphanumeric and underscores in type and field names.
........
r55490 | facundo.batista | 2007-05-21 10:32:32 -0700 (Mon, 21 May 2007) | 5 lines
Added timeout support to HTTPSConnection, through the
socket.create_connection function. Also added a small
test for this, and updated NEWS file.
........
r55495 | georg.brandl | 2007-05-21 13:34:16 -0700 (Mon, 21 May 2007) | 2 lines
Patch #1686487: you can now pass any mapping after '**' in function calls.
........
r55502 | neal.norwitz | 2007-05-21 23:03:36 -0700 (Mon, 21 May 2007) | 1 line
Document new params to HTTPSConnection
........
r55504 | neal.norwitz | 2007-05-22 00:16:10 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS
........
r55505 | neal.norwitz | 2007-05-22 00:16:44 -0700 (Tue, 22 May 2007) | 1 line
Stop using METH_OLDARGS implicitly
........
................
2007-05-23 02:11:13 +08:00
|
|
|
value = ast2obj_list(o->v.ClassDef.decorator_list,
|
|
|
|
ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "decorator_list", value) ==
|
|
|
|
-1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Return_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Return_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Return.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Delete_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Delete_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Delete.targets, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "targets", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Assign_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Assign_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Assign.targets, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "targets", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Assign.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case AugAssign_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(AugAssign_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.AugAssign.target);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "target", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_operator(o->v.AugAssign.op);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "op", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.AugAssign.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case For_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(For_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.For.target);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "target", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.For.iter);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "iter", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.For.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.For.orelse, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "orelse", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case While_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(While_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.While.test);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "test", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.While.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.While.orelse, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "orelse", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case If_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(If_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.If.test);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "test", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.If.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.If.orelse, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "orelse", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2006-02-28 06:32:47 +08:00
|
|
|
case With_kind:
|
|
|
|
result = PyType_GenericNew(With_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.With.context_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "context_expr", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.With.optional_vars);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "optional_vars", value) ==
|
|
|
|
-1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.With.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case Raise_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Raise_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
2007-08-31 08:04:24 +08:00
|
|
|
value = ast2obj_expr(o->v.Raise.exc);
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!value) goto failed;
|
2007-08-31 08:04:24 +08:00
|
|
|
if (PyObject_SetAttrString(result, "exc", value) == -1)
|
2006-02-27 03:42:26 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2007-08-31 08:04:24 +08:00
|
|
|
value = ast2obj_expr(o->v.Raise.cause);
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!value) goto failed;
|
2007-08-31 08:04:24 +08:00
|
|
|
if (PyObject_SetAttrString(result, "cause", value) == -1)
|
2006-02-27 03:42:26 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case TryExcept_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(TryExcept_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.TryExcept.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.TryExcept.handlers,
|
|
|
|
ast2obj_excepthandler);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "handlers", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.TryExcept.orelse, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "orelse", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case TryFinally_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(TryFinally_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.TryFinally.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.TryFinally.finalbody, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "finalbody", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Assert_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Assert_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Assert.test);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "test", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Assert.msg);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "msg", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Import_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Import_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Import.names, ast2obj_alias);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "names", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case ImportFrom_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(ImportFrom_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_identifier(o->v.ImportFrom.module);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "module", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.ImportFrom.names, ast2obj_alias);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "names", value) == -1)
|
2006-03-01 00:09:29 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_int(o->v.ImportFrom.level);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "level", value) == -1)
|
2006-02-27 03:42:26 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Global_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Global_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Global.names, ast2obj_identifier);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "names", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2007-02-27 14:50:52 +08:00
|
|
|
case Nonlocal_kind:
|
|
|
|
result = PyType_GenericNew(Nonlocal_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Nonlocal.names, ast2obj_identifier);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "names", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case Expr_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Expr_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Expr.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Pass_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Pass_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Break_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Break_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Continue_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Continue_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
}
|
2006-02-27 23:23:19 +08:00
|
|
|
value = ast2obj_int(o->lineno);
|
|
|
|
if (!value) goto failed;
|
2006-03-02 08:31:27 +08:00
|
|
|
if (PyObject_SetAttrString(result, "lineno", value) < 0)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-03-02 06:49:05 +08:00
|
|
|
value = ast2obj_int(o->col_offset);
|
|
|
|
if (!value) goto failed;
|
2006-03-02 08:31:27 +08:00
|
|
|
if (PyObject_SetAttrString(result, "col_offset", value) < 0)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
2005-10-21 03:59:25 +08:00
|
|
|
}
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
PyObject*
|
|
|
|
ast2obj_expr(void* _o)
|
2005-10-21 03:59:25 +08:00
|
|
|
{
|
2006-02-27 03:42:26 +08:00
|
|
|
expr_ty o = (expr_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
2005-10-21 03:59:25 +08:00
|
|
|
switch (o->kind) {
|
|
|
|
case BoolOp_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(BoolOp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_boolop(o->v.BoolOp.op);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "op", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.BoolOp.values, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "values", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case BinOp_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(BinOp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.BinOp.left);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "left", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_operator(o->v.BinOp.op);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "op", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.BinOp.right);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "right", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case UnaryOp_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(UnaryOp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_unaryop(o->v.UnaryOp.op);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "op", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.UnaryOp.operand);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "operand", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Lambda_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Lambda_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_arguments(o->v.Lambda.args);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "args", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Lambda.body);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2006-02-27 08:24:13 +08:00
|
|
|
case IfExp_kind:
|
|
|
|
result = PyType_GenericNew(IfExp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.IfExp.test);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "test", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.IfExp.body);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.IfExp.orelse);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "orelse", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case Dict_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Dict_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Dict.keys, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "keys", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.Dict.values, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "values", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2006-08-28 23:27:34 +08:00
|
|
|
case Set_kind:
|
|
|
|
result = PyType_GenericNew(Set_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Set.elts, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elts", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case ListComp_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(ListComp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.ListComp.elt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elt", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.ListComp.generators,
|
|
|
|
ast2obj_comprehension);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "generators", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2007-04-15 20:05:43 +08:00
|
|
|
case SetComp_kind:
|
|
|
|
result = PyType_GenericNew(SetComp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.SetComp.elt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elt", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.SetComp.generators,
|
|
|
|
ast2obj_comprehension);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "generators", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
Merged revisions 56154-56264 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56155 | neal.norwitz | 2007-07-03 08:59:08 +0300 (Tue, 03 Jul 2007) | 1 line
Get this test working after converting map to return an iterator
................
r56202 | neal.norwitz | 2007-07-09 04:30:09 +0300 (Mon, 09 Jul 2007) | 37 lines
Merged revisions 56124-56201 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56129 | georg.brandl | 2007-06-30 04:01:01 -0700 (Sat, 30 Jun 2007) | 2 lines
Document smtp.SMTPAuthenticationError.
........
r56137 | georg.brandl | 2007-07-01 01:11:35 -0700 (Sun, 01 Jul 2007) | 2 lines
Fix a few webbrowser.py problems.
........
r56143 | georg.brandl | 2007-07-02 04:54:28 -0700 (Mon, 02 Jul 2007) | 2 lines
Remove duplicate sentence from alarm() doc.
........
r56170 | mark.hammond | 2007-07-03 19:03:10 -0700 (Tue, 03 Jul 2007) | 3 lines
copy built files to the PCBuild directory, where tools like
distutils or external build processes can find them.
........
r56176 | kurt.kaiser | 2007-07-05 15:03:39 -0700 (Thu, 05 Jul 2007) | 10 lines
Many calls to tk.call involve an arglist containing a single tuple.
Calls using METH_OLDARGS unpack this tuple; calls using METH_VARARG
don't. Tcl's concatenation of args was affected; IDLE doesn't start.
Modify Tkapp_Call() to unpack single tuple arglists.
Bug 1733943
Ref http://mail.python.org/pipermail/python-checkins/2007-May/060454.html
........
r56177 | neal.norwitz | 2007-07-05 21:13:39 -0700 (Thu, 05 Jul 2007) | 1 line
Fix typo in comment
........
................
r56251 | neal.norwitz | 2007-07-11 10:01:01 +0300 (Wed, 11 Jul 2007) | 1 line
Get working with map returning an iterator (had to fix whitespace too)
................
r56255 | thomas.wouters | 2007-07-11 13:41:37 +0300 (Wed, 11 Jul 2007) | 6 lines
Clean up merge glitch or copy-paste error (the entire module was duplicated,
except the first half even had some more copy-paste errors, referring to
listcomps and genexps instead of setcomps)
................
r56256 | thomas.wouters | 2007-07-11 15:16:01 +0300 (Wed, 11 Jul 2007) | 14 lines
Dict comprehensions. Still needs doc changes (like many python-3000 features
;-). It generates bytecode similar to:
x = {}
for k, v in (generator here):
x[k] = v
except there is no tuple-packing and -unpacking involved. Trivial
measurement suggests it's significantly faster than dict(generator here) (in
the order of 2 to 3 times as fast) but I have not done extensive
measurements.
................
r56263 | guido.van.rossum | 2007-07-11 15:36:26 +0300 (Wed, 11 Jul 2007) | 3 lines
Patch 1724999 by Ali Gholami Rudi -- avoid complaints about dict size
change during iter in destroy call.
................
2007-07-11 21:09:30 +08:00
|
|
|
case DictComp_kind:
|
|
|
|
result = PyType_GenericNew(DictComp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.DictComp.key);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "key", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.DictComp.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.DictComp.generators,
|
|
|
|
ast2obj_comprehension);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "generators", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case GeneratorExp_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(GeneratorExp_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.GeneratorExp.elt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elt", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.GeneratorExp.generators,
|
|
|
|
ast2obj_comprehension);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "generators", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Yield_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Yield_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Yield.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Compare_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Compare_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Compare.left);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "left", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 04:51:25 +08:00
|
|
|
{
|
|
|
|
int i, n = asdl_seq_LEN(o->v.Compare.ops);
|
|
|
|
value = PyList_New(n);
|
|
|
|
if (!value) goto failed;
|
|
|
|
for(i = 0; i < n; i++)
|
|
|
|
PyList_SET_ITEM(value, i, ast2obj_cmpop((cmpop_ty)asdl_seq_GET(o->v.Compare.ops, i)));
|
|
|
|
}
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ops", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.Compare.comparators, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "comparators", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Call_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Call_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Call.func);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "func", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.Call.args, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "args", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.Call.keywords, ast2obj_keyword);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "keywords", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Call.starargs);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "starargs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Call.kwargs);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kwargs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Num_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Num_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_object(o->v.Num.n);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "n", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Str_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Str_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_string(o->v.Str.s);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "s", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
2007-02-24 03:56:57 +08:00
|
|
|
case Bytes_kind:
|
|
|
|
result = PyType_GenericNew(Bytes_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_string(o->v.Bytes.s);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "s", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2006-09-06 15:06:08 +08:00
|
|
|
case Ellipsis_kind:
|
|
|
|
result = PyType_GenericNew(Ellipsis_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case Attribute_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Attribute_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Attribute.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_identifier(o->v.Attribute.attr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "attr", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.Attribute.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Subscript_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Subscript_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Subscript.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_slice(o->v.Subscript.slice);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "slice", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.Subscript.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
Merged revisions 55225-55227,55229-55269 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55238 | guido.van.rossum | 2007-05-10 16:46:05 -0700 (Thu, 10 May 2007) | 9 lines
Merged revisions 55227 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55227 | guido.van.rossum | 2007-05-10 10:20:15 -0700 (Thu, 10 May 2007) | 2 lines
Fix a bug in test_c_api() that caused a negative refcount.
........
................
r55246 | neal.norwitz | 2007-05-11 00:01:52 -0700 (Fri, 11 May 2007) | 1 line
Remove commands.getstatus() it is obsolete.
................
r55248 | neal.norwitz | 2007-05-11 00:29:05 -0700 (Fri, 11 May 2007) | 2 lines
Remove bsddb185 support.
................
r55249 | neal.norwitz | 2007-05-11 00:29:50 -0700 (Fri, 11 May 2007) | 1 line
Remove bsddb185 module too
................
r55250 | neal.norwitz | 2007-05-11 00:32:13 -0700 (Fri, 11 May 2007) | 1 line
bsddb185: Gotta remove from the file checked in, not Setup
................
r55251 | neal.norwitz | 2007-05-11 00:53:26 -0700 (Fri, 11 May 2007) | 1 line
Remove obsolete IRIX modules (as much as I could find, there is probably more)
................
r55252 | neal.norwitz | 2007-05-11 00:55:35 -0700 (Fri, 11 May 2007) | 1 line
Remove SGI turd.
................
r55254 | georg.brandl | 2007-05-11 03:11:01 -0700 (Fri, 11 May 2007) | 2 lines
Add a case for set comprehensions to the "cannot assign to" switch.
................
r55255 | georg.brandl | 2007-05-11 03:11:25 -0700 (Fri, 11 May 2007) | 2 lines
Fix wrong imports.
................
r55261 | georg.brandl | 2007-05-11 07:37:48 -0700 (Fri, 11 May 2007) | 2 lines
Remove removed tex files.
................
r55262 | georg.brandl | 2007-05-11 08:28:41 -0700 (Fri, 11 May 2007) | 2 lines
Commit PEP 3132 implementation.
................
r55264 | georg.brandl | 2007-05-11 08:50:19 -0700 (Fri, 11 May 2007) | 2 lines
Check in the inevitable AST version number and format Py_ssize_t with %zd.
................
r55265 | neal.norwitz | 2007-05-11 09:12:22 -0700 (Fri, 11 May 2007) | 1 line
Remove mention of os.popen* and popen2.* since these will be removed.
................
r55266 | neal.norwitz | 2007-05-11 09:19:57 -0700 (Fri, 11 May 2007) | 1 line
Get doc to build again (almost, the doc is fine)
................
r55267 | neal.norwitz | 2007-05-11 09:21:02 -0700 (Fri, 11 May 2007) | 1 line
Really get doc to build (remove use of string module)
................
r55269 | neal.norwitz | 2007-05-11 09:29:43 -0700 (Fri, 11 May 2007) | 1 line
Add some notes to cleanup later
................
2007-05-12 00:50:42 +08:00
|
|
|
case Starred_kind:
|
|
|
|
result = PyType_GenericNew(Starred_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Starred.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.Starred.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
2005-10-21 03:59:25 +08:00
|
|
|
case Name_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Name_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_identifier(o->v.Name.id);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "id", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.Name.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case List_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(List_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.List.elts, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elts", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.List.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Tuple_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Tuple_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.Tuple.elts, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "elts", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr_context(o->v.Tuple.ctx);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ctx", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
|
|
|
}
|
2006-02-27 23:23:19 +08:00
|
|
|
value = ast2obj_int(o->lineno);
|
|
|
|
if (!value) goto failed;
|
2006-03-02 08:31:27 +08:00
|
|
|
if (PyObject_SetAttrString(result, "lineno", value) < 0)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-03-02 06:49:05 +08:00
|
|
|
value = ast2obj_int(o->col_offset);
|
|
|
|
if (!value) goto failed;
|
2006-03-02 08:31:27 +08:00
|
|
|
if (PyObject_SetAttrString(result, "col_offset", value) < 0)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyObject* ast2obj_expr_context(expr_context_ty o)
|
|
|
|
{
|
|
|
|
switch(o) {
|
|
|
|
case Load:
|
|
|
|
Py_INCREF(Load_singleton);
|
|
|
|
return Load_singleton;
|
|
|
|
case Store:
|
|
|
|
Py_INCREF(Store_singleton);
|
|
|
|
return Store_singleton;
|
|
|
|
case Del:
|
|
|
|
Py_INCREF(Del_singleton);
|
|
|
|
return Del_singleton;
|
|
|
|
case AugLoad:
|
|
|
|
Py_INCREF(AugLoad_singleton);
|
|
|
|
return AugLoad_singleton;
|
|
|
|
case AugStore:
|
|
|
|
Py_INCREF(AugStore_singleton);
|
|
|
|
return AugStore_singleton;
|
|
|
|
case Param:
|
|
|
|
Py_INCREF(Param_singleton);
|
|
|
|
return Param_singleton;
|
2008-03-31 04:03:44 +08:00
|
|
|
default:
|
|
|
|
/* should never happen, but just in case ... */
|
|
|
|
PyErr_Format(PyExc_SystemError, "unknown expr_context found");
|
|
|
|
return NULL;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
PyObject*
|
|
|
|
ast2obj_slice(void* _o)
|
|
|
|
{
|
|
|
|
slice_ty o = (slice_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
2005-10-21 03:59:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (o->kind) {
|
|
|
|
case Slice_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Slice_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Slice.lower);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "lower", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Slice.upper);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "upper", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->v.Slice.step);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "step", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case ExtSlice_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(ExtSlice_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_list(o->v.ExtSlice.dims, ast2obj_slice);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "dims", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2005-10-21 03:59:25 +08:00
|
|
|
break;
|
|
|
|
case Index_kind:
|
2006-02-27 03:42:26 +08:00
|
|
|
result = PyType_GenericNew(Index_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.Index.value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyObject* ast2obj_boolop(boolop_ty o)
|
|
|
|
{
|
|
|
|
switch(o) {
|
|
|
|
case And:
|
|
|
|
Py_INCREF(And_singleton);
|
|
|
|
return And_singleton;
|
|
|
|
case Or:
|
|
|
|
Py_INCREF(Or_singleton);
|
|
|
|
return Or_singleton;
|
2008-03-31 04:03:44 +08:00
|
|
|
default:
|
|
|
|
/* should never happen, but just in case ... */
|
|
|
|
PyErr_Format(PyExc_SystemError, "unknown boolop found");
|
|
|
|
return NULL;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
PyObject* ast2obj_operator(operator_ty o)
|
|
|
|
{
|
|
|
|
switch(o) {
|
|
|
|
case Add:
|
|
|
|
Py_INCREF(Add_singleton);
|
|
|
|
return Add_singleton;
|
|
|
|
case Sub:
|
|
|
|
Py_INCREF(Sub_singleton);
|
|
|
|
return Sub_singleton;
|
|
|
|
case Mult:
|
|
|
|
Py_INCREF(Mult_singleton);
|
|
|
|
return Mult_singleton;
|
|
|
|
case Div:
|
|
|
|
Py_INCREF(Div_singleton);
|
|
|
|
return Div_singleton;
|
|
|
|
case Mod:
|
|
|
|
Py_INCREF(Mod_singleton);
|
|
|
|
return Mod_singleton;
|
|
|
|
case Pow:
|
|
|
|
Py_INCREF(Pow_singleton);
|
|
|
|
return Pow_singleton;
|
|
|
|
case LShift:
|
|
|
|
Py_INCREF(LShift_singleton);
|
|
|
|
return LShift_singleton;
|
|
|
|
case RShift:
|
|
|
|
Py_INCREF(RShift_singleton);
|
|
|
|
return RShift_singleton;
|
|
|
|
case BitOr:
|
|
|
|
Py_INCREF(BitOr_singleton);
|
|
|
|
return BitOr_singleton;
|
|
|
|
case BitXor:
|
|
|
|
Py_INCREF(BitXor_singleton);
|
|
|
|
return BitXor_singleton;
|
|
|
|
case BitAnd:
|
|
|
|
Py_INCREF(BitAnd_singleton);
|
|
|
|
return BitAnd_singleton;
|
|
|
|
case FloorDiv:
|
|
|
|
Py_INCREF(FloorDiv_singleton);
|
|
|
|
return FloorDiv_singleton;
|
2008-03-31 04:03:44 +08:00
|
|
|
default:
|
|
|
|
/* should never happen, but just in case ... */
|
|
|
|
PyErr_Format(PyExc_SystemError, "unknown operator found");
|
|
|
|
return NULL;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
PyObject* ast2obj_unaryop(unaryop_ty o)
|
|
|
|
{
|
|
|
|
switch(o) {
|
|
|
|
case Invert:
|
|
|
|
Py_INCREF(Invert_singleton);
|
|
|
|
return Invert_singleton;
|
|
|
|
case Not:
|
|
|
|
Py_INCREF(Not_singleton);
|
|
|
|
return Not_singleton;
|
|
|
|
case UAdd:
|
|
|
|
Py_INCREF(UAdd_singleton);
|
|
|
|
return UAdd_singleton;
|
|
|
|
case USub:
|
|
|
|
Py_INCREF(USub_singleton);
|
|
|
|
return USub_singleton;
|
2008-03-31 04:03:44 +08:00
|
|
|
default:
|
|
|
|
/* should never happen, but just in case ... */
|
|
|
|
PyErr_Format(PyExc_SystemError, "unknown unaryop found");
|
|
|
|
return NULL;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
PyObject* ast2obj_cmpop(cmpop_ty o)
|
|
|
|
{
|
|
|
|
switch(o) {
|
|
|
|
case Eq:
|
|
|
|
Py_INCREF(Eq_singleton);
|
|
|
|
return Eq_singleton;
|
|
|
|
case NotEq:
|
|
|
|
Py_INCREF(NotEq_singleton);
|
|
|
|
return NotEq_singleton;
|
|
|
|
case Lt:
|
|
|
|
Py_INCREF(Lt_singleton);
|
|
|
|
return Lt_singleton;
|
|
|
|
case LtE:
|
|
|
|
Py_INCREF(LtE_singleton);
|
|
|
|
return LtE_singleton;
|
|
|
|
case Gt:
|
|
|
|
Py_INCREF(Gt_singleton);
|
|
|
|
return Gt_singleton;
|
|
|
|
case GtE:
|
|
|
|
Py_INCREF(GtE_singleton);
|
|
|
|
return GtE_singleton;
|
|
|
|
case Is:
|
|
|
|
Py_INCREF(Is_singleton);
|
|
|
|
return Is_singleton;
|
|
|
|
case IsNot:
|
|
|
|
Py_INCREF(IsNot_singleton);
|
|
|
|
return IsNot_singleton;
|
|
|
|
case In:
|
|
|
|
Py_INCREF(In_singleton);
|
|
|
|
return In_singleton;
|
|
|
|
case NotIn:
|
|
|
|
Py_INCREF(NotIn_singleton);
|
|
|
|
return NotIn_singleton;
|
2008-03-31 04:03:44 +08:00
|
|
|
default:
|
|
|
|
/* should never happen, but just in case ... */
|
|
|
|
PyErr_Format(PyExc_SystemError, "unknown cmpop found");
|
|
|
|
return NULL;
|
2006-02-27 03:42:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
PyObject*
|
|
|
|
ast2obj_comprehension(void* _o)
|
|
|
|
{
|
|
|
|
comprehension_ty o = (comprehension_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PyType_GenericNew(comprehension_type, NULL, NULL);
|
|
|
|
if (!result) return NULL;
|
|
|
|
value = ast2obj_expr(o->target);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "target", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->iter);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "iter", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->ifs, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "ifs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyObject*
|
|
|
|
ast2obj_excepthandler(void* _o)
|
|
|
|
{
|
|
|
|
excepthandler_ty o = (excepthandler_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
2008-03-31 13:14:30 +08:00
|
|
|
switch (o->kind) {
|
|
|
|
case ExceptHandler_kind:
|
|
|
|
result = PyType_GenericNew(ExceptHandler_type, NULL, NULL);
|
|
|
|
if (!result) goto failed;
|
|
|
|
value = ast2obj_expr(o->v.ExceptHandler.type);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "type", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_identifier(o->v.ExceptHandler.name);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "name", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->v.ExceptHandler.body, ast2obj_stmt);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "body", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
break;
|
|
|
|
}
|
2006-04-21 18:40:58 +08:00
|
|
|
value = ast2obj_int(o->lineno);
|
|
|
|
if (!value) goto failed;
|
2008-03-31 13:14:30 +08:00
|
|
|
if (PyObject_SetAttrString(result, "lineno", value) < 0)
|
2006-04-21 18:40:58 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_int(o->col_offset);
|
|
|
|
if (!value) goto failed;
|
2008-03-31 13:14:30 +08:00
|
|
|
if (PyObject_SetAttrString(result, "col_offset", value) < 0)
|
2006-04-21 18:40:58 +08:00
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyObject*
|
|
|
|
ast2obj_arguments(void* _o)
|
|
|
|
{
|
|
|
|
arguments_ty o = (arguments_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PyType_GenericNew(arguments_type, NULL, NULL);
|
|
|
|
if (!result) return NULL;
|
2006-12-28 14:47:50 +08:00
|
|
|
value = ast2obj_list(o->args, ast2obj_arg);
|
2006-02-27 03:42:26 +08:00
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "args", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_identifier(o->vararg);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "vararg", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-12-28 14:47:50 +08:00
|
|
|
value = ast2obj_expr(o->varargannotation);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "varargannotation", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_list(o->kwonlyargs, ast2obj_arg);
|
2006-10-28 07:31:49 +08:00
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kwonlyargs", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
value = ast2obj_identifier(o->kwarg);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kwarg", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-12-28 14:47:50 +08:00
|
|
|
value = ast2obj_expr(o->kwargannotation);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kwargannotation", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
value = ast2obj_list(o->defaults, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "defaults", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-10-28 07:31:49 +08:00
|
|
|
value = ast2obj_list(o->kw_defaults, ast2obj_expr);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "kw_defaults", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-02-27 03:42:26 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2006-12-28 14:47:50 +08:00
|
|
|
PyObject*
|
|
|
|
ast2obj_arg(void* _o)
|
|
|
|
{
|
|
|
|
arg_ty o = (arg_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
2007-05-16 02:46:22 +08:00
|
|
|
result = PyType_GenericNew(arg_type, NULL, NULL);
|
|
|
|
if (!result) return NULL;
|
|
|
|
value = ast2obj_identifier(o->arg);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "arg", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->annotation);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "annotation", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
2006-12-28 14:47:50 +08:00
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
PyObject*
|
|
|
|
ast2obj_keyword(void* _o)
|
|
|
|
{
|
|
|
|
keyword_ty o = (keyword_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PyType_GenericNew(keyword_type, NULL, NULL);
|
|
|
|
if (!result) return NULL;
|
|
|
|
value = ast2obj_identifier(o->arg);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "arg", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_expr(o->value);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "value", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
PyObject*
|
|
|
|
ast2obj_alias(void* _o)
|
|
|
|
{
|
|
|
|
alias_ty o = (alias_ty)_o;
|
|
|
|
PyObject *result = NULL, *value = NULL;
|
|
|
|
if (!o) {
|
|
|
|
Py_INCREF(Py_None);
|
|
|
|
return Py_None;
|
|
|
|
}
|
|
|
|
|
|
|
|
result = PyType_GenericNew(alias_type, NULL, NULL);
|
|
|
|
if (!result) return NULL;
|
|
|
|
value = ast2obj_identifier(o->name);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "name", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
value = ast2obj_identifier(o->asname);
|
|
|
|
if (!value) goto failed;
|
|
|
|
if (PyObject_SetAttrString(result, "asname", value) == -1)
|
|
|
|
goto failed;
|
|
|
|
Py_DECREF(value);
|
|
|
|
return result;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(value);
|
|
|
|
Py_XDECREF(result);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
int
|
|
|
|
obj2ast_mod(PyObject* obj, mod_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
if (obj == Py_None) {
|
|
|
|
*out = NULL;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Module_type)) {
|
|
|
|
asdl_seq* body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Module field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from Module");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Module(body, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Interactive_type)) {
|
|
|
|
asdl_seq* body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Interactive field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from Interactive");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Interactive(body, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Expression_type)) {
|
|
|
|
expr_ty body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &body, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from Expression");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Expression(body, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Suite_type)) {
|
|
|
|
asdl_seq* body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Suite field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from Suite");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Suite(body, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of mod, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_stmt(PyObject* obj, stmt_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
int lineno;
|
|
|
|
int col_offset;
|
|
|
|
|
|
|
|
if (obj == Py_None) {
|
|
|
|
*out = NULL;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "lineno")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "lineno");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &lineno, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"lineno\" missing from stmt");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "col_offset")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "col_offset");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &col_offset, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"col_offset\" missing from stmt");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)FunctionDef_type)) {
|
|
|
|
identifier name;
|
|
|
|
arguments_ty args;
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* decorator_list;
|
|
|
|
expr_ty returns;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "name")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "name");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &name, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"name\" missing from FunctionDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "args")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "args");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_arguments(tmp, &args, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"args\" missing from FunctionDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "FunctionDef field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from FunctionDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "decorator_list")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "decorator_list");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "FunctionDef field \"decorator_list\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
decorator_list = asdl_seq_new(len, arena);
|
|
|
|
if (decorator_list == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(decorator_list, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"decorator_list\" missing from FunctionDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "returns")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "returns");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &returns, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
returns = NULL;
|
|
|
|
}
|
|
|
|
*out = FunctionDef(name, args, body, decorator_list, returns,
|
|
|
|
lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)ClassDef_type)) {
|
|
|
|
identifier name;
|
|
|
|
asdl_seq* bases;
|
|
|
|
asdl_seq* keywords;
|
|
|
|
expr_ty starargs;
|
|
|
|
expr_ty kwargs;
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* decorator_list;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "name")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "name");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &name, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"name\" missing from ClassDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "bases")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "bases");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ClassDef field \"bases\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
bases = asdl_seq_new(len, arena);
|
|
|
|
if (bases == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(bases, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"bases\" missing from ClassDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "keywords")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "keywords");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ClassDef field \"keywords\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
keywords = asdl_seq_new(len, arena);
|
|
|
|
if (keywords == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
keyword_ty value;
|
|
|
|
res = obj2ast_keyword(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(keywords, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"keywords\" missing from ClassDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "starargs")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "starargs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &starargs, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
starargs = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kwargs")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kwargs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &kwargs, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
kwargs = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ClassDef field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from ClassDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "decorator_list")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "decorator_list");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ClassDef field \"decorator_list\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
decorator_list = asdl_seq_new(len, arena);
|
|
|
|
if (decorator_list == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(decorator_list, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"decorator_list\" missing from ClassDef");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = ClassDef(name, bases, keywords, starargs, kwargs, body,
|
|
|
|
decorator_list, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Return_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
value = NULL;
|
|
|
|
}
|
|
|
|
*out = Return(value, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Delete_type)) {
|
|
|
|
asdl_seq* targets;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "targets")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "targets");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Delete field \"targets\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
targets = asdl_seq_new(len, arena);
|
|
|
|
if (targets == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(targets, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"targets\" missing from Delete");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Delete(targets, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Assign_type)) {
|
|
|
|
asdl_seq* targets;
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "targets")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "targets");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Assign field \"targets\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
targets = asdl_seq_new(len, arena);
|
|
|
|
if (targets == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(targets, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"targets\" missing from Assign");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Assign");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Assign(targets, value, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)AugAssign_type)) {
|
|
|
|
expr_ty target;
|
|
|
|
operator_ty op;
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "target")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "target");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &target, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"target\" missing from AugAssign");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "op")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "op");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_operator(tmp, &op, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"op\" missing from AugAssign");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from AugAssign");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = AugAssign(target, op, value, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)For_type)) {
|
|
|
|
expr_ty target;
|
|
|
|
expr_ty iter;
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* orelse;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "target")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "target");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &target, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"target\" missing from For");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "iter")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "iter");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &iter, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"iter\" missing from For");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "For field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from For");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "orelse")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "orelse");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "For field \"orelse\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
orelse = asdl_seq_new(len, arena);
|
|
|
|
if (orelse == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(orelse, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"orelse\" missing from For");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = For(target, iter, body, orelse, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)While_type)) {
|
|
|
|
expr_ty test;
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* orelse;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "test")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "test");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &test, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"test\" missing from While");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "While field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from While");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "orelse")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "orelse");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "While field \"orelse\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
orelse = asdl_seq_new(len, arena);
|
|
|
|
if (orelse == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(orelse, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"orelse\" missing from While");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = While(test, body, orelse, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)If_type)) {
|
|
|
|
expr_ty test;
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* orelse;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "test")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "test");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &test, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"test\" missing from If");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "If field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from If");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "orelse")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "orelse");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "If field \"orelse\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
orelse = asdl_seq_new(len, arena);
|
|
|
|
if (orelse == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(orelse, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"orelse\" missing from If");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = If(test, body, orelse, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)With_type)) {
|
|
|
|
expr_ty context_expr;
|
|
|
|
expr_ty optional_vars;
|
|
|
|
asdl_seq* body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "context_expr")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "context_expr");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &context_expr, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"context_expr\" missing from With");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "optional_vars")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "optional_vars");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &optional_vars, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
optional_vars = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "With field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from With");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = With(context_expr, optional_vars, body, lineno,
|
|
|
|
col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Raise_type)) {
|
|
|
|
expr_ty exc;
|
|
|
|
expr_ty cause;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "exc")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "exc");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &exc, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
exc = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "cause")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "cause");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &cause, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
cause = NULL;
|
|
|
|
}
|
|
|
|
*out = Raise(exc, cause, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)TryExcept_type)) {
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* handlers;
|
|
|
|
asdl_seq* orelse;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "TryExcept field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from TryExcept");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "handlers")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "handlers");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "TryExcept field \"handlers\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
handlers = asdl_seq_new(len, arena);
|
|
|
|
if (handlers == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
excepthandler_ty value;
|
|
|
|
res = obj2ast_excepthandler(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(handlers, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"handlers\" missing from TryExcept");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "orelse")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "orelse");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "TryExcept field \"orelse\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
orelse = asdl_seq_new(len, arena);
|
|
|
|
if (orelse == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(orelse, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"orelse\" missing from TryExcept");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = TryExcept(body, handlers, orelse, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)TryFinally_type)) {
|
|
|
|
asdl_seq* body;
|
|
|
|
asdl_seq* finalbody;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "TryFinally field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from TryFinally");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "finalbody")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "finalbody");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "TryFinally field \"finalbody\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
finalbody = asdl_seq_new(len, arena);
|
|
|
|
if (finalbody == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(finalbody, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"finalbody\" missing from TryFinally");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = TryFinally(body, finalbody, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Assert_type)) {
|
|
|
|
expr_ty test;
|
|
|
|
expr_ty msg;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "test")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "test");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &test, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"test\" missing from Assert");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "msg")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "msg");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &msg, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
msg = NULL;
|
|
|
|
}
|
|
|
|
*out = Assert(test, msg, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Import_type)) {
|
|
|
|
asdl_seq* names;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "names")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "names");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Import field \"names\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
names = asdl_seq_new(len, arena);
|
|
|
|
if (names == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
alias_ty value;
|
|
|
|
res = obj2ast_alias(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(names, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"names\" missing from Import");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Import(names, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)ImportFrom_type)) {
|
|
|
|
identifier module;
|
|
|
|
asdl_seq* names;
|
|
|
|
int level;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "module")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "module");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &module, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"module\" missing from ImportFrom");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "names")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "names");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ImportFrom field \"names\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
names = asdl_seq_new(len, arena);
|
|
|
|
if (names == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
alias_ty value;
|
|
|
|
res = obj2ast_alias(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(names, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"names\" missing from ImportFrom");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "level")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "level");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &level, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
level = 0;
|
|
|
|
}
|
|
|
|
*out = ImportFrom(module, names, level, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Global_type)) {
|
|
|
|
asdl_seq* names;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "names")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "names");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Global field \"names\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
names = asdl_seq_new(len, arena);
|
|
|
|
if (names == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
identifier value;
|
|
|
|
res = obj2ast_identifier(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(names, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"names\" missing from Global");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Global(names, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Nonlocal_type)) {
|
|
|
|
asdl_seq* names;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "names")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "names");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Nonlocal field \"names\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
names = asdl_seq_new(len, arena);
|
|
|
|
if (names == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
identifier value;
|
|
|
|
res = obj2ast_identifier(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(names, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"names\" missing from Nonlocal");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Nonlocal(names, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Expr_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Expr");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Expr(value, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Pass_type)) {
|
|
|
|
|
|
|
|
*out = Pass(lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Break_type)) {
|
|
|
|
|
|
|
|
*out = Break(lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Continue_type)) {
|
|
|
|
|
|
|
|
*out = Continue(lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of stmt, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_expr(PyObject* obj, expr_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
int lineno;
|
|
|
|
int col_offset;
|
|
|
|
|
|
|
|
if (obj == Py_None) {
|
|
|
|
*out = NULL;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "lineno")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "lineno");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &lineno, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"lineno\" missing from expr");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "col_offset")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "col_offset");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &col_offset, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"col_offset\" missing from expr");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)BoolOp_type)) {
|
|
|
|
boolop_ty op;
|
|
|
|
asdl_seq* values;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "op")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "op");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_boolop(tmp, &op, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"op\" missing from BoolOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "values")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "values");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "BoolOp field \"values\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
values = asdl_seq_new(len, arena);
|
|
|
|
if (values == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(values, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"values\" missing from BoolOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = BoolOp(op, values, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)BinOp_type)) {
|
|
|
|
expr_ty left;
|
|
|
|
operator_ty op;
|
|
|
|
expr_ty right;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "left")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "left");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &left, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"left\" missing from BinOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "op")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "op");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_operator(tmp, &op, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"op\" missing from BinOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "right")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "right");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &right, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"right\" missing from BinOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = BinOp(left, op, right, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)UnaryOp_type)) {
|
|
|
|
unaryop_ty op;
|
|
|
|
expr_ty operand;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "op")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "op");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_unaryop(tmp, &op, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"op\" missing from UnaryOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "operand")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "operand");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &operand, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"operand\" missing from UnaryOp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = UnaryOp(op, operand, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Lambda_type)) {
|
|
|
|
arguments_ty args;
|
|
|
|
expr_ty body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "args")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "args");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_arguments(tmp, &args, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"args\" missing from Lambda");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &body, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from Lambda");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Lambda(args, body, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)IfExp_type)) {
|
|
|
|
expr_ty test;
|
|
|
|
expr_ty body;
|
|
|
|
expr_ty orelse;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "test")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "test");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &test, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"test\" missing from IfExp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &body, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from IfExp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "orelse")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "orelse");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &orelse, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"orelse\" missing from IfExp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = IfExp(test, body, orelse, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Dict_type)) {
|
|
|
|
asdl_seq* keys;
|
|
|
|
asdl_seq* values;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "keys")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "keys");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Dict field \"keys\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
keys = asdl_seq_new(len, arena);
|
|
|
|
if (keys == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(keys, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"keys\" missing from Dict");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "values")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "values");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Dict field \"values\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
values = asdl_seq_new(len, arena);
|
|
|
|
if (values == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(values, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"values\" missing from Dict");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Dict(keys, values, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Set_type)) {
|
|
|
|
asdl_seq* elts;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elts")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elts");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Set field \"elts\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
elts = asdl_seq_new(len, arena);
|
|
|
|
if (elts == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(elts, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elts\" missing from Set");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Set(elts, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)ListComp_type)) {
|
|
|
|
expr_ty elt;
|
|
|
|
asdl_seq* generators;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elt")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elt");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &elt, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elt\" missing from ListComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "generators")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "generators");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ListComp field \"generators\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
generators = asdl_seq_new(len, arena);
|
|
|
|
if (generators == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
comprehension_ty value;
|
|
|
|
res = obj2ast_comprehension(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(generators, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"generators\" missing from ListComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = ListComp(elt, generators, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)SetComp_type)) {
|
|
|
|
expr_ty elt;
|
|
|
|
asdl_seq* generators;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elt")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elt");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &elt, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elt\" missing from SetComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "generators")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "generators");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "SetComp field \"generators\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
generators = asdl_seq_new(len, arena);
|
|
|
|
if (generators == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
comprehension_ty value;
|
|
|
|
res = obj2ast_comprehension(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(generators, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"generators\" missing from SetComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = SetComp(elt, generators, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)DictComp_type)) {
|
|
|
|
expr_ty key;
|
|
|
|
expr_ty value;
|
|
|
|
asdl_seq* generators;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "key")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "key");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &key, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"key\" missing from DictComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from DictComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "generators")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "generators");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "DictComp field \"generators\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
generators = asdl_seq_new(len, arena);
|
|
|
|
if (generators == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
comprehension_ty value;
|
|
|
|
res = obj2ast_comprehension(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(generators, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"generators\" missing from DictComp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = DictComp(key, value, generators, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)GeneratorExp_type)) {
|
|
|
|
expr_ty elt;
|
|
|
|
asdl_seq* generators;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elt")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elt");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &elt, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elt\" missing from GeneratorExp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "generators")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "generators");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "GeneratorExp field \"generators\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
generators = asdl_seq_new(len, arena);
|
|
|
|
if (generators == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
comprehension_ty value;
|
|
|
|
res = obj2ast_comprehension(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(generators, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"generators\" missing from GeneratorExp");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = GeneratorExp(elt, generators, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Yield_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
value = NULL;
|
|
|
|
}
|
|
|
|
*out = Yield(value, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Compare_type)) {
|
|
|
|
expr_ty left;
|
|
|
|
asdl_int_seq* ops;
|
|
|
|
asdl_seq* comparators;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "left")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "left");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &left, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"left\" missing from Compare");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ops")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ops");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Compare field \"ops\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
ops = asdl_int_seq_new(len, arena);
|
|
|
|
if (ops == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
cmpop_ty value;
|
|
|
|
res = obj2ast_cmpop(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(ops, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ops\" missing from Compare");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "comparators")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "comparators");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Compare field \"comparators\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
comparators = asdl_seq_new(len, arena);
|
|
|
|
if (comparators == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(comparators, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"comparators\" missing from Compare");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Compare(left, ops, comparators, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Call_type)) {
|
|
|
|
expr_ty func;
|
|
|
|
asdl_seq* args;
|
|
|
|
asdl_seq* keywords;
|
|
|
|
expr_ty starargs;
|
|
|
|
expr_ty kwargs;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "func")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "func");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &func, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"func\" missing from Call");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "args")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "args");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Call field \"args\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
args = asdl_seq_new(len, arena);
|
|
|
|
if (args == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(args, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"args\" missing from Call");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "keywords")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "keywords");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Call field \"keywords\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
keywords = asdl_seq_new(len, arena);
|
|
|
|
if (keywords == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
keyword_ty value;
|
|
|
|
res = obj2ast_keyword(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(keywords, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"keywords\" missing from Call");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "starargs")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "starargs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &starargs, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
starargs = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kwargs")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kwargs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &kwargs, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
kwargs = NULL;
|
|
|
|
}
|
|
|
|
*out = Call(func, args, keywords, starargs, kwargs, lineno,
|
|
|
|
col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Num_type)) {
|
|
|
|
object n;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "n")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "n");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_object(tmp, &n, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"n\" missing from Num");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Num(n, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Str_type)) {
|
|
|
|
string s;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "s")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "s");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_string(tmp, &s, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"s\" missing from Str");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Str(s, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Bytes_type)) {
|
|
|
|
string s;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "s")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "s");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_string(tmp, &s, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"s\" missing from Bytes");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Bytes(s, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Ellipsis_type)) {
|
|
|
|
|
|
|
|
*out = Ellipsis(lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Attribute_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
identifier attr;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Attribute");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "attr")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "attr");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &attr, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"attr\" missing from Attribute");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from Attribute");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Attribute(value, attr, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Subscript_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
slice_ty slice;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Subscript");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "slice")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "slice");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_slice(tmp, &slice, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"slice\" missing from Subscript");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from Subscript");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Subscript(value, slice, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Starred_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Starred");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from Starred");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Starred(value, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Name_type)) {
|
|
|
|
identifier id;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "id")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "id");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &id, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"id\" missing from Name");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from Name");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Name(id, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)List_type)) {
|
|
|
|
asdl_seq* elts;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elts")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elts");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "List field \"elts\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
elts = asdl_seq_new(len, arena);
|
|
|
|
if (elts == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(elts, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elts\" missing from List");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from List");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = List(elts, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Tuple_type)) {
|
|
|
|
asdl_seq* elts;
|
|
|
|
expr_context_ty ctx;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "elts")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "elts");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "Tuple field \"elts\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
elts = asdl_seq_new(len, arena);
|
|
|
|
if (elts == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(elts, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"elts\" missing from Tuple");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ctx")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ctx");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr_context(tmp, &ctx, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ctx\" missing from Tuple");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Tuple(elts, ctx, lineno, col_offset, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of expr, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_expr_context(PyObject* obj, expr_context_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Load_type)) {
|
|
|
|
*out = Load;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Store_type)) {
|
|
|
|
*out = Store;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Del_type)) {
|
|
|
|
*out = Del;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)AugLoad_type)) {
|
|
|
|
*out = AugLoad;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)AugStore_type)) {
|
|
|
|
*out = AugStore;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Param_type)) {
|
|
|
|
*out = Param;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of expr_context, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_slice(PyObject* obj, slice_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
if (obj == Py_None) {
|
|
|
|
*out = NULL;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Slice_type)) {
|
|
|
|
expr_ty lower;
|
|
|
|
expr_ty upper;
|
|
|
|
expr_ty step;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "lower")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "lower");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &lower, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
lower = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "upper")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "upper");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &upper, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
upper = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "step")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "step");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &step, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
step = NULL;
|
|
|
|
}
|
|
|
|
*out = Slice(lower, upper, step, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)ExtSlice_type)) {
|
|
|
|
asdl_seq* dims;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "dims")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "dims");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ExtSlice field \"dims\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
dims = asdl_seq_new(len, arena);
|
|
|
|
if (dims == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
slice_ty value;
|
|
|
|
res = obj2ast_slice(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(dims, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"dims\" missing from ExtSlice");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = ExtSlice(dims, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Index_type)) {
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from Index");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = Index(value, arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of slice, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_boolop(PyObject* obj, boolop_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)And_type)) {
|
|
|
|
*out = And;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Or_type)) {
|
|
|
|
*out = Or;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of boolop, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_operator(PyObject* obj, operator_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Add_type)) {
|
|
|
|
*out = Add;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Sub_type)) {
|
|
|
|
*out = Sub;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Mult_type)) {
|
|
|
|
*out = Mult;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Div_type)) {
|
|
|
|
*out = Div;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Mod_type)) {
|
|
|
|
*out = Mod;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Pow_type)) {
|
|
|
|
*out = Pow;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)LShift_type)) {
|
|
|
|
*out = LShift;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)RShift_type)) {
|
|
|
|
*out = RShift;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)BitOr_type)) {
|
|
|
|
*out = BitOr;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)BitXor_type)) {
|
|
|
|
*out = BitXor;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)BitAnd_type)) {
|
|
|
|
*out = BitAnd;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)FloorDiv_type)) {
|
|
|
|
*out = FloorDiv;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of operator, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_unaryop(PyObject* obj, unaryop_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Invert_type)) {
|
|
|
|
*out = Invert;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Not_type)) {
|
|
|
|
*out = Not;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)UAdd_type)) {
|
|
|
|
*out = UAdd;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)USub_type)) {
|
|
|
|
*out = USub;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of unaryop, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_cmpop(PyObject* obj, cmpop_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Eq_type)) {
|
|
|
|
*out = Eq;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)NotEq_type)) {
|
|
|
|
*out = NotEq;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Lt_type)) {
|
|
|
|
*out = Lt;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)LtE_type)) {
|
|
|
|
*out = LtE;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Gt_type)) {
|
|
|
|
*out = Gt;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)GtE_type)) {
|
|
|
|
*out = GtE;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)Is_type)) {
|
|
|
|
*out = Is;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)IsNot_type)) {
|
|
|
|
*out = IsNot;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)In_type)) {
|
|
|
|
*out = In;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)NotIn_type)) {
|
|
|
|
*out = NotIn;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of cmpop, but got %.400s", PyString_AS_STRING(tmp));
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_comprehension(PyObject* obj, comprehension_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
expr_ty target;
|
|
|
|
expr_ty iter;
|
|
|
|
asdl_seq* ifs;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "target")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "target");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &target, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"target\" missing from comprehension");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "iter")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "iter");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &iter, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"iter\" missing from comprehension");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "ifs")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "ifs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "comprehension field \"ifs\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
ifs = asdl_seq_new(len, arena);
|
|
|
|
if (ifs == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(ifs, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"ifs\" missing from comprehension");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = comprehension(target, iter, ifs, arena);
|
|
|
|
return 0;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_excepthandler(PyObject* obj, excepthandler_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
2008-03-31 13:14:30 +08:00
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
int lineno;
|
|
|
|
int col_offset;
|
|
|
|
|
2008-03-31 13:14:30 +08:00
|
|
|
if (obj == Py_None) {
|
|
|
|
*out = NULL;
|
|
|
|
return 0;
|
2008-03-31 04:03:44 +08:00
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "lineno")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "lineno");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &lineno, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"lineno\" missing from excepthandler");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "col_offset")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "col_offset");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_int(tmp, &col_offset, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"col_offset\" missing from excepthandler");
|
|
|
|
return 1;
|
|
|
|
}
|
2008-03-31 13:14:30 +08:00
|
|
|
if (PyObject_IsInstance(obj, (PyObject*)ExceptHandler_type)) {
|
|
|
|
expr_ty type;
|
|
|
|
identifier name;
|
|
|
|
asdl_seq* body;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "type")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "type");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &type, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
type = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "name")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "name");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &name, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
name = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "body")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "body");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "ExceptHandler field \"body\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
body = asdl_seq_new(len, arena);
|
|
|
|
if (body == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
stmt_ty value;
|
|
|
|
res = obj2ast_stmt(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(body, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"body\" missing from ExceptHandler");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = ExceptHandler(type, name, body, lineno, col_offset,
|
|
|
|
arena);
|
|
|
|
if (*out == NULL) goto failed;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = PyObject_Repr(obj);
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected some sort of excepthandler, but got %.400s", PyString_AS_STRING(tmp));
|
2008-03-31 04:03:44 +08:00
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_arguments(PyObject* obj, arguments_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
asdl_seq* args;
|
|
|
|
identifier vararg;
|
|
|
|
expr_ty varargannotation;
|
|
|
|
asdl_seq* kwonlyargs;
|
|
|
|
identifier kwarg;
|
|
|
|
expr_ty kwargannotation;
|
|
|
|
asdl_seq* defaults;
|
|
|
|
asdl_seq* kw_defaults;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "args")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "args");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "arguments field \"args\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
args = asdl_seq_new(len, arena);
|
|
|
|
if (args == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
arg_ty value;
|
|
|
|
res = obj2ast_arg(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(args, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"args\" missing from arguments");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "vararg")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "vararg");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &vararg, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
vararg = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "varargannotation")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "varargannotation");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &varargannotation, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
varargannotation = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kwonlyargs")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kwonlyargs");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "arguments field \"kwonlyargs\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
kwonlyargs = asdl_seq_new(len, arena);
|
|
|
|
if (kwonlyargs == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
arg_ty value;
|
|
|
|
res = obj2ast_arg(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(kwonlyargs, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"kwonlyargs\" missing from arguments");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kwarg")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kwarg");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &kwarg, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
kwarg = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kwargannotation")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kwargannotation");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &kwargannotation, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
kwargannotation = NULL;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "defaults")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "defaults");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "arguments field \"defaults\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
defaults = asdl_seq_new(len, arena);
|
|
|
|
if (defaults == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(defaults, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"defaults\" missing from arguments");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "kw_defaults")) {
|
|
|
|
int res;
|
|
|
|
Py_ssize_t len;
|
|
|
|
Py_ssize_t i;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "kw_defaults");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
if (!PyList_Check(tmp)) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "arguments field \"kw_defaults\" must be a list, not a %.200s", tmp->ob_type->tp_name);
|
|
|
|
goto failed;
|
|
|
|
}
|
|
|
|
len = PyList_GET_SIZE(tmp);
|
|
|
|
kw_defaults = asdl_seq_new(len, arena);
|
|
|
|
if (kw_defaults == NULL) goto failed;
|
|
|
|
for (i = 0; i < len; i++) {
|
|
|
|
expr_ty value;
|
|
|
|
res = obj2ast_expr(PyList_GET_ITEM(tmp, i), &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
asdl_seq_SET(kw_defaults, i, value);
|
|
|
|
}
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"kw_defaults\" missing from arguments");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = arguments(args, vararg, varargannotation, kwonlyargs, kwarg,
|
|
|
|
kwargannotation, defaults, kw_defaults, arena);
|
|
|
|
return 0;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_arg(PyObject* obj, arg_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
identifier arg;
|
|
|
|
expr_ty annotation;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "arg")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "arg");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &arg, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"arg\" missing from arg");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "annotation")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "annotation");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &annotation, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
annotation = NULL;
|
|
|
|
}
|
|
|
|
*out = arg(arg, annotation, arena);
|
|
|
|
return 0;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_keyword(PyObject* obj, keyword_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
identifier arg;
|
|
|
|
expr_ty value;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "arg")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "arg");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &arg, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"arg\" missing from keyword");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "value")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "value");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_expr(tmp, &value, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"value\" missing from keyword");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
*out = keyword(arg, value, arena);
|
|
|
|
return 0;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
obj2ast_alias(PyObject* obj, alias_ty* out, PyArena* arena)
|
|
|
|
{
|
|
|
|
PyObject* tmp = NULL;
|
|
|
|
identifier name;
|
|
|
|
identifier asname;
|
|
|
|
|
|
|
|
if (PyObject_HasAttrString(obj, "name")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "name");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &name, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
PyErr_SetString(PyExc_TypeError, "required field \"name\" missing from alias");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (PyObject_HasAttrString(obj, "asname")) {
|
|
|
|
int res;
|
|
|
|
tmp = PyObject_GetAttrString(obj, "asname");
|
|
|
|
if (tmp == NULL) goto failed;
|
|
|
|
res = obj2ast_identifier(tmp, &asname, arena);
|
|
|
|
if (res != 0) goto failed;
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
tmp = NULL;
|
|
|
|
} else {
|
|
|
|
asname = NULL;
|
|
|
|
}
|
|
|
|
*out = alias(name, asname, arena);
|
|
|
|
return 0;
|
|
|
|
failed:
|
|
|
|
Py_XDECREF(tmp);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-02-27 23:23:19 +08:00
|
|
|
PyMODINIT_FUNC
|
|
|
|
init_ast(void)
|
|
|
|
{
|
|
|
|
PyObject *m, *d;
|
|
|
|
if (!init_types()) return;
|
|
|
|
m = Py_InitModule3("_ast", NULL, NULL);
|
|
|
|
if (!m) return;
|
|
|
|
d = PyModule_GetDict(m);
|
2008-03-31 12:42:11 +08:00
|
|
|
if (PyDict_SetItemString(d, "AST", (PyObject*)&AST_type) < 0) return;
|
2006-02-27 23:23:19 +08:00
|
|
|
if (PyModule_AddIntConstant(m, "PyCF_ONLY_AST", PyCF_ONLY_AST) < 0)
|
|
|
|
return;
|
Merged revisions 61440-61441,61443,61445-61448,61451-61452,61455-61457,61459-61464,61466-61467,61469-61470,61476-61477,61479,61481-61482,61485,61487,61490,61493-61494,61497,61499-61502,61505-61506,61508,61511-61514,61519,61521-61522,61530-61531,61533-61537,61541-61555,61557-61558,61561-61562,61566-61569,61572-61574,61578-61579,61583-61584,61588-61589,61592,61594,61598-61601,61603-61604,61607-61612,61617,61619-61620,61624,61626,61628-61630,61635-61638,61640-61643,61645,61648,61653-61655,61659-61662,61664,61666,61668-61671,61673,61675,61679-61680,61682,61685-61686,61689-61695,61697-61699,61701-61703,61706,61710,61713,61717,61723,61726-61730,61736,61738,61740,61742,61745-61752,61754-61760,61762-61764,61768,61770-61772,61774-61775,61784-61787,61789-61792,61794-61795,61797-61806,61808-61809,61811-61812,61814-61819,61824,61826-61833,61835-61840,61843-61845,61848,61850,61854-61862,61865-61866,61868,61872-61873,61876-61877,61883-61888,61890-61891,61893-61899,61901-61903,61905-61912,61914,61917,61920-61921,61927,61930,61932-61934,61939,61941-61942,61944-61951,61955,61960-61963,61980,61982-61983,61991,61994-61996,62001-62003,62008-62010,62016-62017,62022,62024,62027,62031-62034,62041,62045-62046,62048,62050-62051,62055-62066,62068-62074,62076-62078 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r62048 | georg.brandl | 2008-03-29 23:53:55 -0700 (Sat, 29 Mar 2008) | 2 lines
Adapt test_ast to the new ExceptHandler type.
........
r62050 | georg.brandl | 2008-03-30 00:09:22 -0700 (Sun, 30 Mar 2008) | 2 lines
Convert test_ast to unittest and add a test for r62049.
........
r62051 | georg.brandl | 2008-03-30 12:00:49 -0700 (Sun, 30 Mar 2008) | 2 lines
Make _fields attr for no fields consistent with _attributes attr.
........
r62059 | georg.brandl | 2008-03-30 13:20:39 -0700 (Sun, 30 Mar 2008) | 2 lines
Make AST nodes pickleable.
........
2008-03-31 13:29:39 +08:00
|
|
|
if (PyModule_AddStringConstant(m, "__version__", "62078") < 0)
|
2006-02-28 08:32:31 +08:00
|
|
|
return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "mod", (PyObject*)mod_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Module", (PyObject*)Module_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Interactive", (PyObject*)Interactive_type)
|
|
|
|
< 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Expression", (PyObject*)Expression_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Suite", (PyObject*)Suite_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "stmt", (PyObject*)stmt_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "FunctionDef", (PyObject*)FunctionDef_type)
|
|
|
|
< 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "ClassDef", (PyObject*)ClassDef_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Return", (PyObject*)Return_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Delete", (PyObject*)Delete_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Assign", (PyObject*)Assign_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "AugAssign", (PyObject*)AugAssign_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "For", (PyObject*)For_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "While", (PyObject*)While_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "If", (PyObject*)If_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "With", (PyObject*)With_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Raise", (PyObject*)Raise_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "TryExcept", (PyObject*)TryExcept_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "TryFinally", (PyObject*)TryFinally_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Assert", (PyObject*)Assert_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Import", (PyObject*)Import_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "ImportFrom", (PyObject*)ImportFrom_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Global", (PyObject*)Global_type) < 0)
|
|
|
|
return;
|
2007-02-27 14:50:52 +08:00
|
|
|
if (PyDict_SetItemString(d, "Nonlocal", (PyObject*)Nonlocal_type) < 0)
|
|
|
|
return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "Expr", (PyObject*)Expr_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Pass", (PyObject*)Pass_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Break", (PyObject*)Break_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Continue", (PyObject*)Continue_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "expr", (PyObject*)expr_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "BoolOp", (PyObject*)BoolOp_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "BinOp", (PyObject*)BinOp_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "UnaryOp", (PyObject*)UnaryOp_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Lambda", (PyObject*)Lambda_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "IfExp", (PyObject*)IfExp_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Dict", (PyObject*)Dict_type) < 0) return;
|
2006-08-28 23:27:34 +08:00
|
|
|
if (PyDict_SetItemString(d, "Set", (PyObject*)Set_type) < 0) return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "ListComp", (PyObject*)ListComp_type) < 0)
|
|
|
|
return;
|
2007-04-15 20:05:43 +08:00
|
|
|
if (PyDict_SetItemString(d, "SetComp", (PyObject*)SetComp_type) < 0)
|
|
|
|
return;
|
Merged revisions 56154-56264 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56155 | neal.norwitz | 2007-07-03 08:59:08 +0300 (Tue, 03 Jul 2007) | 1 line
Get this test working after converting map to return an iterator
................
r56202 | neal.norwitz | 2007-07-09 04:30:09 +0300 (Mon, 09 Jul 2007) | 37 lines
Merged revisions 56124-56201 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56129 | georg.brandl | 2007-06-30 04:01:01 -0700 (Sat, 30 Jun 2007) | 2 lines
Document smtp.SMTPAuthenticationError.
........
r56137 | georg.brandl | 2007-07-01 01:11:35 -0700 (Sun, 01 Jul 2007) | 2 lines
Fix a few webbrowser.py problems.
........
r56143 | georg.brandl | 2007-07-02 04:54:28 -0700 (Mon, 02 Jul 2007) | 2 lines
Remove duplicate sentence from alarm() doc.
........
r56170 | mark.hammond | 2007-07-03 19:03:10 -0700 (Tue, 03 Jul 2007) | 3 lines
copy built files to the PCBuild directory, where tools like
distutils or external build processes can find them.
........
r56176 | kurt.kaiser | 2007-07-05 15:03:39 -0700 (Thu, 05 Jul 2007) | 10 lines
Many calls to tk.call involve an arglist containing a single tuple.
Calls using METH_OLDARGS unpack this tuple; calls using METH_VARARG
don't. Tcl's concatenation of args was affected; IDLE doesn't start.
Modify Tkapp_Call() to unpack single tuple arglists.
Bug 1733943
Ref http://mail.python.org/pipermail/python-checkins/2007-May/060454.html
........
r56177 | neal.norwitz | 2007-07-05 21:13:39 -0700 (Thu, 05 Jul 2007) | 1 line
Fix typo in comment
........
................
r56251 | neal.norwitz | 2007-07-11 10:01:01 +0300 (Wed, 11 Jul 2007) | 1 line
Get working with map returning an iterator (had to fix whitespace too)
................
r56255 | thomas.wouters | 2007-07-11 13:41:37 +0300 (Wed, 11 Jul 2007) | 6 lines
Clean up merge glitch or copy-paste error (the entire module was duplicated,
except the first half even had some more copy-paste errors, referring to
listcomps and genexps instead of setcomps)
................
r56256 | thomas.wouters | 2007-07-11 15:16:01 +0300 (Wed, 11 Jul 2007) | 14 lines
Dict comprehensions. Still needs doc changes (like many python-3000 features
;-). It generates bytecode similar to:
x = {}
for k, v in (generator here):
x[k] = v
except there is no tuple-packing and -unpacking involved. Trivial
measurement suggests it's significantly faster than dict(generator here) (in
the order of 2 to 3 times as fast) but I have not done extensive
measurements.
................
r56263 | guido.van.rossum | 2007-07-11 15:36:26 +0300 (Wed, 11 Jul 2007) | 3 lines
Patch 1724999 by Ali Gholami Rudi -- avoid complaints about dict size
change during iter in destroy call.
................
2007-07-11 21:09:30 +08:00
|
|
|
if (PyDict_SetItemString(d, "DictComp", (PyObject*)DictComp_type) < 0)
|
|
|
|
return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "GeneratorExp",
|
|
|
|
(PyObject*)GeneratorExp_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Yield", (PyObject*)Yield_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Compare", (PyObject*)Compare_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Call", (PyObject*)Call_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Num", (PyObject*)Num_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Str", (PyObject*)Str_type) < 0) return;
|
2007-02-24 03:56:57 +08:00
|
|
|
if (PyDict_SetItemString(d, "Bytes", (PyObject*)Bytes_type) < 0) return;
|
2006-09-06 15:06:08 +08:00
|
|
|
if (PyDict_SetItemString(d, "Ellipsis", (PyObject*)Ellipsis_type) < 0)
|
|
|
|
return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "Attribute", (PyObject*)Attribute_type) <
|
|
|
|
0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Subscript", (PyObject*)Subscript_type) <
|
|
|
|
0) return;
|
Merged revisions 55225-55227,55229-55269 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r55238 | guido.van.rossum | 2007-05-10 16:46:05 -0700 (Thu, 10 May 2007) | 9 lines
Merged revisions 55227 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r55227 | guido.van.rossum | 2007-05-10 10:20:15 -0700 (Thu, 10 May 2007) | 2 lines
Fix a bug in test_c_api() that caused a negative refcount.
........
................
r55246 | neal.norwitz | 2007-05-11 00:01:52 -0700 (Fri, 11 May 2007) | 1 line
Remove commands.getstatus() it is obsolete.
................
r55248 | neal.norwitz | 2007-05-11 00:29:05 -0700 (Fri, 11 May 2007) | 2 lines
Remove bsddb185 support.
................
r55249 | neal.norwitz | 2007-05-11 00:29:50 -0700 (Fri, 11 May 2007) | 1 line
Remove bsddb185 module too
................
r55250 | neal.norwitz | 2007-05-11 00:32:13 -0700 (Fri, 11 May 2007) | 1 line
bsddb185: Gotta remove from the file checked in, not Setup
................
r55251 | neal.norwitz | 2007-05-11 00:53:26 -0700 (Fri, 11 May 2007) | 1 line
Remove obsolete IRIX modules (as much as I could find, there is probably more)
................
r55252 | neal.norwitz | 2007-05-11 00:55:35 -0700 (Fri, 11 May 2007) | 1 line
Remove SGI turd.
................
r55254 | georg.brandl | 2007-05-11 03:11:01 -0700 (Fri, 11 May 2007) | 2 lines
Add a case for set comprehensions to the "cannot assign to" switch.
................
r55255 | georg.brandl | 2007-05-11 03:11:25 -0700 (Fri, 11 May 2007) | 2 lines
Fix wrong imports.
................
r55261 | georg.brandl | 2007-05-11 07:37:48 -0700 (Fri, 11 May 2007) | 2 lines
Remove removed tex files.
................
r55262 | georg.brandl | 2007-05-11 08:28:41 -0700 (Fri, 11 May 2007) | 2 lines
Commit PEP 3132 implementation.
................
r55264 | georg.brandl | 2007-05-11 08:50:19 -0700 (Fri, 11 May 2007) | 2 lines
Check in the inevitable AST version number and format Py_ssize_t with %zd.
................
r55265 | neal.norwitz | 2007-05-11 09:12:22 -0700 (Fri, 11 May 2007) | 1 line
Remove mention of os.popen* and popen2.* since these will be removed.
................
r55266 | neal.norwitz | 2007-05-11 09:19:57 -0700 (Fri, 11 May 2007) | 1 line
Get doc to build again (almost, the doc is fine)
................
r55267 | neal.norwitz | 2007-05-11 09:21:02 -0700 (Fri, 11 May 2007) | 1 line
Really get doc to build (remove use of string module)
................
r55269 | neal.norwitz | 2007-05-11 09:29:43 -0700 (Fri, 11 May 2007) | 1 line
Add some notes to cleanup later
................
2007-05-12 00:50:42 +08:00
|
|
|
if (PyDict_SetItemString(d, "Starred", (PyObject*)Starred_type) < 0)
|
|
|
|
return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "Name", (PyObject*)Name_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "List", (PyObject*)List_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Tuple", (PyObject*)Tuple_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "expr_context",
|
|
|
|
(PyObject*)expr_context_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Load", (PyObject*)Load_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Store", (PyObject*)Store_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Del", (PyObject*)Del_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "AugLoad", (PyObject*)AugLoad_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "AugStore", (PyObject*)AugStore_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Param", (PyObject*)Param_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "slice", (PyObject*)slice_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Slice", (PyObject*)Slice_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "ExtSlice", (PyObject*)ExtSlice_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Index", (PyObject*)Index_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "boolop", (PyObject*)boolop_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "And", (PyObject*)And_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Or", (PyObject*)Or_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "operator", (PyObject*)operator_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Add", (PyObject*)Add_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Sub", (PyObject*)Sub_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Mult", (PyObject*)Mult_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Div", (PyObject*)Div_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Mod", (PyObject*)Mod_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Pow", (PyObject*)Pow_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "LShift", (PyObject*)LShift_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "RShift", (PyObject*)RShift_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "BitOr", (PyObject*)BitOr_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "BitXor", (PyObject*)BitXor_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "BitAnd", (PyObject*)BitAnd_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "FloorDiv", (PyObject*)FloorDiv_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "unaryop", (PyObject*)unaryop_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Invert", (PyObject*)Invert_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "Not", (PyObject*)Not_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "UAdd", (PyObject*)UAdd_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "USub", (PyObject*)USub_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "cmpop", (PyObject*)cmpop_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Eq", (PyObject*)Eq_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "NotEq", (PyObject*)NotEq_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Lt", (PyObject*)Lt_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "LtE", (PyObject*)LtE_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Gt", (PyObject*)Gt_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "GtE", (PyObject*)GtE_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "Is", (PyObject*)Is_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "IsNot", (PyObject*)IsNot_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "In", (PyObject*)In_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "NotIn", (PyObject*)NotIn_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "comprehension",
|
|
|
|
(PyObject*)comprehension_type) < 0) return;
|
|
|
|
if (PyDict_SetItemString(d, "excepthandler",
|
|
|
|
(PyObject*)excepthandler_type) < 0) return;
|
2008-03-31 13:14:30 +08:00
|
|
|
if (PyDict_SetItemString(d, "ExceptHandler",
|
|
|
|
(PyObject*)ExceptHandler_type) < 0) return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "arguments", (PyObject*)arguments_type) <
|
|
|
|
0) return;
|
2006-12-28 14:47:50 +08:00
|
|
|
if (PyDict_SetItemString(d, "arg", (PyObject*)arg_type) < 0) return;
|
2006-04-21 18:40:58 +08:00
|
|
|
if (PyDict_SetItemString(d, "keyword", (PyObject*)keyword_type) < 0)
|
|
|
|
return;
|
|
|
|
if (PyDict_SetItemString(d, "alias", (PyObject*)alias_type) < 0) return;
|
2006-02-27 23:23:19 +08:00
|
|
|
}
|
|
|
|
|
2006-02-27 03:42:26 +08:00
|
|
|
|
|
|
|
PyObject* PyAST_mod2obj(mod_ty t)
|
|
|
|
{
|
|
|
|
init_types();
|
|
|
|
return ast2obj_mod(t);
|
2005-10-21 03:59:25 +08:00
|
|
|
}
|
2007-06-10 17:51:05 +08:00
|
|
|
|
2008-03-31 12:20:05 +08:00
|
|
|
/* mode is 0 for "exec", 1 for "eval" and 2 for "single" input */
|
|
|
|
mod_ty PyAST_obj2mod(PyObject* ast, PyArena* arena, int mode)
|
2008-03-31 04:03:44 +08:00
|
|
|
{
|
|
|
|
mod_ty res;
|
2008-03-31 12:20:05 +08:00
|
|
|
PyObject *req_type[] = {(PyObject*)Module_type, (PyObject*)Expression_type,
|
|
|
|
(PyObject*)Interactive_type};
|
|
|
|
char *req_name[] = {"Module", "Expression", "Interactive"};
|
|
|
|
assert(0 <= mode && mode <= 2);
|
|
|
|
|
2008-03-31 04:03:44 +08:00
|
|
|
init_types();
|
2008-03-31 12:20:05 +08:00
|
|
|
|
|
|
|
if (!PyObject_IsInstance(ast, req_type[mode])) {
|
|
|
|
PyErr_Format(PyExc_TypeError, "expected %s node, got %.400s",
|
|
|
|
req_name[mode], Py_TYPE(ast)->tp_name);
|
2008-03-31 04:03:44 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
if (obj2ast_mod(ast, &res, arena) != 0)
|
|
|
|
return NULL;
|
|
|
|
else
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
int PyAST_Check(PyObject* obj)
|
|
|
|
{
|
|
|
|
init_types();
|
2008-03-31 12:42:11 +08:00
|
|
|
return PyObject_IsInstance(obj, (PyObject*)&AST_type);
|
2008-03-31 04:03:44 +08:00
|
|
|
}
|
|
|
|
|
2007-06-10 17:51:05 +08:00
|
|
|
|