summaryrefslogtreecommitdiffstats
path: root/Doc/whatsnew/whatsnew22.tex
blob: 241b36b0f9650dfdf6027732c1604b0e99bdc082 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
\documentclass{howto}

% $Id$

\title{What's New in Python 2.2}
\release{0.01}
\author{A.M. Kuchling}
\authoraddress{\email{amk1@bigfoot.com}}
\begin{document}
\maketitle\tableofcontents

\section{Introduction}

{\large This document is a draft, and is subject to change until the
final version of Python 2.2 is released.  Currently it's not up to
date at all.  Please send any comments, bug reports, or questions, no
matter how minor, to \email{amk1@bigfoot.com}.  }

This article explains the new features in Python 2.2.  
Python 2.2 includes some significant changes that go far toward cleaning up
the language's darkest corners.

This article doesn't attempt to provide a complete specification for
the new features, but instead provides a convenient overview of the
new features.  For full details, you should refer to 2.2 documentation
such as the Library Reference and the Reference Guide, or to the PEP
for a particular new feature.

The final release of Python 2.2 is planned for October 2001.

%======================================================================
\section{PEP 234: Iterators}

XXX

\begin{seealso}

\seepep{234}{Iterators}{Written by Ka-Ping Yee and GvR; implemented 
by the Python Labs crew, mostly by GvR and Tim Peters.}

\end{seealso}

%======================================================================
\section{PEP 252: Type and Class Changes}

XXX

\begin{seealso}

\seepep{252}{Making Types Look More Like Classes}{Written and implemented 
by GvR.}

\end{seealso}

%======================================================================
\section{New and Improved Modules}

\begin{itemize}

  \item XXX

\end{itemize}


%======================================================================
\section{Other Changes and Fixes}

XXX

\begin{itemize}

  \item XXX Nested scoping enabled by default

  \item XXX C API: Reorganization of object calling 

  \item XXX .encode(), .decode() string methods.  Interesting new codecs such
as zlib.

%Original log message:
 
%The call_object() function, originally in ceval.c, begins a new life
%as the official API PyObject_Call().  It is also much simplified: all
%it does is call the tp_call slot, or raise an exception if that's
%NULL.
 
%The subsidiary functions (call_eval_code2(), call_cfunction(),
%call_instance(), and call_method()) have all been moved to the file
%implementing their particular object type, renamed according to the
%local convention, and added to the type's tp_call slot.  Note that
%call_eval_code2() became function_call(); the tp_slot for class
%objects now simply points to PyInstance_New(), which already has the
%correct signature.
 
%Because of these moves, there are some more new APIs that expose
%helpers in ceval.c that are now needed outside: PyEval_GetFuncName(),
%PyEval_GetFuncDesc(), PyEval_EvalCodeEx() (formerly get_func_name(),
%get_func_desc(), and eval_code2().

\end{itemize}



%======================================================================
\section{Acknowledgements}

The author would like to thank the following people for offering
suggestions on various drafts of this article: No one yet.

\end{document}