1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2024 CEA, EDF, OPEN CASCADE
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License, or (at your option) any later version.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 ## \defgroup salome_kernel salome.kernel
23 # \details Package containing the KERNEL python utilities
24 # \defgroup deprecation
28 # \defgroup uiexception
29 # \defgroup datamodeler
33 # \defgroup unittester
34 # \defgroup pyunittester
37 __all__ = [ "deprecation", "logger", "termcolor", "logconfig" ]
38 __version__ = "@SALOMEKERNEL_GIT_SHA1@"
39 __config_datetime__ = "@SALOMEKERNEL_CONFIG_TIME@"
41 # WARN: This file SHOULD NOT import salome stuff so that modules of the
42 # package could be used outside of a SALOME session context when
43 # possible. For example logger.py, datamodeler.py, enumerate.py,
44 # diclookup.py, ... does not need a SALOME running application.
47 # ==============================================================================
48 # Generic serialization functions for the module datamodeler
49 # ==============================================================================
53 def serialize(dataToSerialize):
55 Creates a string description of the specified data.
56 .. attribute:: dataToSerialize
57 a data object to serialize
59 serialstring = pickle.dumps(dataToSerialize)
62 def unserialize(stringToUnserialize):
64 Creates a data object from its string description. The string description
65 is supposed to be obtained by a call to serialize.
66 .. attribute:: stringToUnserialize
67 a string description of the object
69 data = pickle.loads(stringToUnserialize)
74 This class is used to create class-method (see MetaData)
76 def __init__(self, anycallable):
77 self.__call__ = anycallable
79 # ==============================================================================
80 # Basic use cases and unit tests
81 # ==============================================================================
84 def TEST_serialization():
85 from .testdata import TestData
86 ref_name = "my study case"
87 studyData = TestData()
88 studyData.setName(ref_name)
90 print("serialize data ...")
91 serialString = serialize(studyData)
92 print("unserialize data ...")
93 unserialData = unserialize(serialString)
95 res_name = unserialData.getName()
97 if ( ref_name != res_name ):
101 unserialData.setName("an other name")
105 if __name__ == "__main__":
106 from . import unittester
107 unittester.run("salome/kernel/__init__","TEST_serialization")