summaryrefslogtreecommitdiffstats
path: root/Doc/whatsnew/whatsnew22.tex
blob: 3ebb803f0359adb2cfc16b65cf4753765ce6c69b (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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
\documentclass{howto}

% $Id$

\title{What's New in Python 2.2}
\release{0.01}
\author{A.M. Kuchling}
\authoraddress{\email{akuchlin@mems-exchange.org}}
\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{akuchlin@mems-exchange.org}.  }

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, and some exciting new features.

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 255: Simple Generators}

XXX

\begin{seealso}

\seepep{255}{Simple Generators}{Written by Neil Schemenauer, 
Tim Peters, Magnus Lie Hetland.  Implemented mostly by Neil
Schemenauer, with fixes from the Python Labs crew, mostly by GvR and
Tim Peters.}

\end{seealso}

%======================================================================
% It looks like this set of changes isn't going to be getting into 2.2,
% unless someone plans to merge the descr-branch back into the mainstream
% very quickly.
%\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{Unicode Changes}

XXX I have to figure out what the changes mean to users.
(--enable-unicode configure switch)

References: http://mail.python.org/pipermail/i18n-sig/2001-June/001107.html  
and following thread.


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

\begin{itemize}

  \item xmlrpclib added to standard library.

\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}