Kaydet (Commit) f6e8316b authored tarafından Guido van Rossum's avatar Guido van Rossum

Initialize __version__ to the correct version string regardless of

what RCS checkout options are used.  Problem first diagnosed by Marc
Lemburg.
üst 06ba34c5
...@@ -3881,10 +3881,21 @@ init_stuff(PyObject *module, PyObject *module_dict) { ...@@ -3881,10 +3881,21 @@ init_stuff(PyObject *module, PyObject *module_dict) {
void void
initcPickle() { initcPickle() {
PyObject *m, *d, *v; PyObject *m, *d, *v;
char *rev="$Revision$"; static char revbuf[] = "$Revision$";
char *rev = revbuf;
PyObject *format_version; PyObject *format_version;
PyObject *compatible_formats; PyObject *compatible_formats;
/* Fix up the revision number */
if (rev[0] == '$') {
char *p = strchr(rev, ' ');
if (p) {
rev = p+1;
p = strrchr(rev, ' ');
if (p)
*p = '\0';
}
}
/* Create the module and add the functions */ /* Create the module and add the functions */
m = Py_InitModule4("cPickle", cPickle_methods, m = Py_InitModule4("cPickle", cPickle_methods,
...@@ -3896,8 +3907,8 @@ initcPickle() { ...@@ -3896,8 +3907,8 @@ initcPickle() {
/* Add some symbolic constants to the module */ /* Add some symbolic constants to the module */
d = PyModule_GetDict(m); d = PyModule_GetDict(m);
PyDict_SetItemString(d,"__version__", v = PyString_FromString(rev);
v = PyString_FromStringAndSize(rev+11,strlen(rev+11)-2)); PyDict_SetItemString(d,"__version__", v);
Py_XDECREF(v); Py_XDECREF(v);
#ifdef FORMAT_1_3 #ifdef FORMAT_1_3
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment