Source code for apptools.naming.object_serializer

# (C) Copyright 2005-2024 Enthought, Inc., Austin, TX
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in LICENSE.txt and may be redistributed only under
# the conditions described in the aforementioned license. The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
#
# Thanks for using Enthought open source!
""" The base class for all object serializers. """


# Standard library imports.
import logging
from traceback import print_exc
from os.path import splitext
import pickle

# Enthought library imports.
from apptools.persistence.versioned_unpickler import VersionedUnpickler
from traits.api import HasTraits, Str


# Setup a logger for this module.
logger = logging.getLogger(__name__)


[docs]class ObjectSerializer(HasTraits): """ The base class for all object serializers. """ #### 'ObjectSerializer' interface ######################################### # The file extension recognized by this serializer. ext = Str(".pickle") ########################################################################### # 'ObjectSerializer' interface. ###########################################################################
[docs] def can_load(self, path): """ Returns True if the serializer can load a file. """ rest, ext = splitext(path) return ext == self.ext
[docs] def load(self, path): """ Loads an object from a file. """ # Unpickle the object. f = open(path, "rb") try: try: obj = VersionedUnpickler(f).load() except Exception as ex: print_exc() logger.exception( "Failed to load pickle file: %s, %s" % (path, ex) ) raise finally: f.close() return obj
[docs] def can_save(self, obj): """ Returns True if the serializer can save an object. """ return True
[docs] def save(self, path, obj): """ Saves an object to a file. """ if not path.endswith(self.ext): actual_path = path + self.ext else: actual_path = path # Pickle the object. f = open(actual_path, "wb") try: pickle.dump(obj, f, 1) except Exception as ex: logger.exception( "Failed to pickle into file: %s, %s, object:%s" % (path, ex, obj) ) print_exc() f.close() return actual_path