[Python-bugs-list] [ python-Bugs-749831 ] pickle raises SystemError when __getstate__ refers to class

SourceForge.net noreply@sourceforge.net
Thu, 05 Jun 2003 15:04:03 -0700


Bugs item #749831, was opened at 2003-06-05 22:04
Message generated for change (Tracker Item Submitted) made by Item Submitter
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=749831&group_id=5470

Category: Python Library
Group: Python 2.3
Status: Open
Resolution: None
Priority: 5
Submitted By: Gerrit Holl (gerrit)
Assigned to: Nobody/Anonymous (nobody)
Summary: pickle raises SystemError when __getstate__ refers to class

Initial Comment:
I'm sorry that I'm so far unable to track this down
better, but my app is quite complex I think. But if I'm
right cPickle should never raise a SystemError:

$ ./brian.py
mcop warning: user defined signal handler found for
SIG_PIPE, overriding
Traceback (most recent call last):
  File "./brian.py", line 265, in ?
    main()
  File "./brian.py", line 235, in main
    game.mainloop()
  File "./brian.py", line 100, in mainloop
    self.save(self.savefile)
  File "./brian.py", line 216, in save
    self.level.save(fp)
  File "level.py", line 113, in save
    cPickle.dump(self, f, -1)
SystemError: NULL object passed to Py_BuildValue
$ python -c 'import sys;print sys.version'
2.3b1+ (#2, Jun  4 2003, 17:16:59)
[GCC 3.2.2 20030222 (Red Hat Linux 3.2.2-5)]

When I use (Py)pickle instead of cPickle, the traceback
becomes:

$ ./brian.py
mcop warning: user defined signal handler found for
SIG_PIPE, overriding
Traceback (most recent call last):
  File "./brian.py", line 266, in ?
    main()
  File "./brian.py", line 236, in main
    game.mainloop()
  File "./brian.py", line 100, in mainloop
    self.save(self.savefile)
  File "./brian.py", line 217, in save
    self.level.save(fp)
  File "/home/gerrit/cvs/brian/level.py", line 114, in save
    cPickle.dump(self, f, -1)
  File "/usr/local/lib/python2.3/pickle.py", line 1382,
in dump
    Pickler(file, protocol, bin).dump(obj)
  File "/usr/local/lib/python2.3/pickle.py", line 231,
in dump
    self.save(obj)
  File "/usr/local/lib/python2.3/pickle.py", line 338,
in save
    self.save_reduce(obj=obj, *rv)
  File "/usr/local/lib/python2.3/pickle.py", line 433,
in save_reduce
    save(state)
  File "/usr/local/lib/python2.3/pickle.py", line 293,
in save
    f(self, obj) # Call unbound method with explicit self
  File "/usr/local/lib/python2.3/pickle.py", line 663,
in save_dict
    self._batch_setitems(obj.iteritems())
  File "/usr/local/lib/python2.3/pickle.py", line 695,
in _batch_setitems
    save(v)
  File "/usr/local/lib/python2.3/pickle.py", line 313,
in save
    rv = reduce(self.proto)
SystemError: NULL object passed to Py_BuildValue

'self' is an object whose __dict__ has 4 items. The
'data' item is a set (Sets.set) with approx. 450 items.
Those are all instances of a class Sprite or one of its
subclasses. This is where it goes wrong.

The interesting part is that if a reference to
__class__ in __getstate__ of this Sprite is commented
out, (line 200 of
http://cvs.sourceforge.net/cgi-bin/viewcvs.cgi/pybrian/brian/basesprites.py?annotate=1.18)
this bug no longer occurs. The file then pickled is
attached (it is gzipped). Unfortunately, the
__getstate__ relies on some images available.

The full CVS tree of the app concerned is available via
SF:
http://cvs.sourceforge.net/cgi-bin/viewcvs.cgi/pybrian/brian/
When 'brian' is called without basesprites.py#200
commented out, this error occurs for Python 2.3.

I am going to try to track this down further tomorrow
and beyond, because I think that with the line in
getstate I am very far already.

Gerrit.

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=749831&group_id=5470