No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

picklefile.py 1.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. #
  2. # This file is part of Lodel 2 (https://github.com/OpenEdition)
  3. #
  4. # Copyright (C) 2015-2017 Cléo UMS-3287
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU Affero General Public License as published
  8. # by the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU Affero General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU Affero General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. ##@package lodel.editorial_model.translator.picklefile
  20. # This module handles the file storage of an editorial model
  21. import pickle
  22. from pickle import Pickler
  23. ##@brief Saves a model in a file
  24. # @param model EditorialModel : the model to save
  25. # @param filename str|None : if None return the model as pickle bytes (by default : None)
  26. # @return None if filename is a string, else returns bytes representation of model
  27. def save(model, filename = None):
  28. with open(filename, 'w+b') as ffd:
  29. pickle.dump(model, ffd)
  30. return filename
  31. ##@brief Loads a model from a file
  32. # @param filename str : the filename to use to load the model
  33. # @return EditorialModel
  34. def load(filename):
  35. with open(filename, 'rb') as ffd:
  36. edmod = pickle.load(ffd)
  37. return edmod