]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Merged revisions 72599 via svnmerge from
authorR. David Murray <rdmurray@bitdance.com>
Wed, 13 May 2009 12:53:18 +0000 (12:53 +0000)
committerR. David Murray <rdmurray@bitdance.com>
Wed, 13 May 2009 12:53:18 +0000 (12:53 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/py3k

................
  r72599 | r.david.murray | 2009-05-13 08:27:21 -0400 (Wed, 13 May 2009) | 9 lines

  Merged revisions 72597 via svnmerge from
  svn+ssh://pythondev@svn.python.org/python/trunk

  ........
    r72597 | r.david.murray | 2009-05-12 20:30:29 -0400 (Tue, 12 May 2009) | 2 lines

    Issue 5994: add docstrings to marshal.
  ........
................

Misc/NEWS
Python/marshal.c

index 9c5c10e6846e6f9451f04c364fd93bf1cf73bb44..ae36caef243e8211c29fd9dda86010df76da040e 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -12,6 +12,8 @@ What's New in Python 3.0.2?
 Core and Builtins
 -----------------
 
+- Issue #5994: the marshal module now has docstrings.
+
 - Issue #5981: Fix two minor inf/nan issues in float.fromhex: (1) inf
   and nan strings with trailing whitespace were incorrectly rejected
   and (2) the interpretation of fromhex('-nan') didn't match that of
index e7981b8eb902bee8c661740a6df6caa4a7aa40ce..300139fe0201fc725c6c8532e3e137555d838126 100644 (file)
@@ -1120,6 +1120,19 @@ marshal_dump(PyObject *self, PyObject *args)
        return res;
 }
 
+PyDoc_STRVAR(dump_doc,
+"dump(value, file[, version])\n\
+\n\
+Write the value on the open file. The value must be a supported type.\n\
+The file must be an open file object such as sys.stdout or returned by\n\
+open() or os.popen(). It must be opened in binary mode ('wb' or 'w+b').\n\
+\n\
+If the value has (or contains an object that has) an unsupported type, a\n\
+ValueError exception is raised — but garbage data will also be written\n\
+to the file. The object will not be properly read back by load()\n\
+\n\
+The version argument indicates the data format that dump should use.");
+
 static PyObject *
 marshal_load(PyObject *self, PyObject *f)
 {
@@ -1154,6 +1167,19 @@ marshal_load(PyObject *self, PyObject *f)
        return result;
 }
 
+PyDoc_STRVAR(load_doc,
+"load(file)\n\
+\n\
+Read one value from the open file and return it. If no valid value is\n\
+read (e.g. because the data has a different Python version’s\n\
+incompatible marshal format), raise EOFError, ValueError or TypeError.\n\
+The file must be an open file object opened in binary mode ('rb' or\n\
+'r+b').\n\
+\n\
+Note: If an object containing an unsupported type was marshalled with\n\
+dump(), load() will substitute None for the unmarshallable type.");
+
+
 static PyObject *
 marshal_dumps(PyObject *self, PyObject *args)
 {
@@ -1164,6 +1190,16 @@ marshal_dumps(PyObject *self, PyObject *args)
        return PyMarshal_WriteObjectToString(x, version);
 }
 
+PyDoc_STRVAR(dumps_doc,
+"dumps(value[, version])\n\
+\n\
+Return the string that would be written to a file by dump(value, file).\n\
+The value must be a supported type. Raise a ValueError exception if\n\
+value has (or contains an object that has) an unsupported type.\n\
+\n\
+The version argument indicates the data format that dumps should use.");
+
+
 static PyObject *
 marshal_loads(PyObject *self, PyObject *args)
 {
@@ -1187,18 +1223,56 @@ marshal_loads(PyObject *self, PyObject *args)
        return result;
 }
 
+PyDoc_STRVAR(loads_doc,
+"loads(string)\n\
+\n\
+Convert the string to a value. If no valid value is found, raise\n\
+EOFError, ValueError or TypeError. Extra characters in the string are\n\
+ignored.");
+
 static PyMethodDef marshal_methods[] = {
-       {"dump",        marshal_dump,   METH_VARARGS},
-       {"load",        marshal_load,   METH_O},
-       {"dumps",       marshal_dumps,  METH_VARARGS},
-       {"loads",       marshal_loads,  METH_VARARGS},
+       {"dump",        marshal_dump,   METH_VARARGS,   dump_doc},
+       {"load",        marshal_load,   METH_O,         load_doc},
+       {"dumps",       marshal_dumps,  METH_VARARGS,   dumps_doc},
+       {"loads",       marshal_loads,  METH_VARARGS,   loads_doc},
        {NULL,          NULL}           /* sentinel */
 };
 
+
+PyDoc_STRVAR(module_doc,
+"This module contains functions that can read and write Python values in\n\
+a binary format. The format is specific to Python, but independent of\n\
+machine architecture issues.\n\
+\n\
+Not all Python object types are supported; in general, only objects\n\
+whose value is independent from a particular invocation of Python can be\n\
+written and read by this module. The following types are supported:\n\
+None, integers, floating point numbers, strings, bytes, bytearrays,\n\
+tuples, lists, sets, dictionaries, and code objects, where it\n\
+should be understood that tuples, lists and dictionaries are only\n\
+supported as long as the values contained therein are themselves\n\
+supported; and recursive lists and dictionaries should not be written\n\
+(they will cause infinite loops).\n\
+\n\
+Variables:\n\
+\n\
+version -- indicates the format that the module uses. Version 0 is the\n\
+    historical format, version 1 shares interned strings and version 2\n\
+    uses a binary format for floating point numbers.\n\
+\n\
+Functions:\n\
+\n\
+dump() -- write value to a file\n\
+load() -- read value from a file\n\
+dumps() -- write value to a string\n\
+loads() -- read value from a string");
+
+
+
 static struct PyModuleDef marshalmodule = {
        PyModuleDef_HEAD_INIT,
        "marshal",
-       NULL,
+       module_doc,
        0,
        marshal_methods,
        NULL,
@@ -1207,8 +1281,6 @@ static struct PyModuleDef marshalmodule = {
        NULL
 };
 
-
-
 PyMODINIT_FUNC
 PyMarshal_Init(void)
 {