PaIRS-UniNa 0.2.8__cp312-cp312-win_amd64.whl → 0.2.10__cp312-cp312-win_amd64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. PaIRS_UniNa/Calibration_Tab.py +16 -0
  2. PaIRS_UniNa/Changes.txt +21 -0
  3. PaIRS_UniNa/Explorer.py +3312 -3126
  4. PaIRS_UniNa/FolderLoop.py +561 -561
  5. PaIRS_UniNa/Input_Tab.py +824 -826
  6. PaIRS_UniNa/Input_Tab_CalVi.py +1 -0
  7. PaIRS_UniNa/Input_Tab_tools.py +3020 -3019
  8. PaIRS_UniNa/PaIRS.py +17 -17
  9. PaIRS_UniNa/PaIRS_pypacks.py +18 -65
  10. PaIRS_UniNa/Process_Tab.py +19 -15
  11. PaIRS_UniNa/Process_Tab_Disp.py +8 -1
  12. PaIRS_UniNa/SPIVCalHelp.py +155 -0
  13. PaIRS_UniNa/Saving_tools.py +279 -277
  14. PaIRS_UniNa/TabTools.py +165 -6
  15. PaIRS_UniNa/Vis_Tab.py +11 -4
  16. PaIRS_UniNa/Vis_Tab_CalVi.py +1 -2
  17. PaIRS_UniNa/_PaIRS_PIV.pyd +0 -0
  18. PaIRS_UniNa/__init__.py +3 -3
  19. PaIRS_UniNa/addwidgets_ps.py +570 -70
  20. PaIRS_UniNa/gPaIRS.py +3933 -3889
  21. PaIRS_UniNa/icons/information.png +0 -0
  22. PaIRS_UniNa/icons/information2.png +0 -0
  23. PaIRS_UniNa/icons/spiv_setup_no.png +0 -0
  24. PaIRS_UniNa/icons/spiv_setup_ok.png +0 -0
  25. PaIRS_UniNa/listLib.py +301 -301
  26. PaIRS_UniNa/parForMulti.py +433 -433
  27. PaIRS_UniNa/rqrdpckgs.txt +7 -7
  28. PaIRS_UniNa/tabSplitter.py +606 -606
  29. PaIRS_UniNa/ui_Calibration_Tab.py +576 -543
  30. PaIRS_UniNa/ui_Custom_Top.py +294 -294
  31. PaIRS_UniNa/ui_Input_Tab.py +1098 -1098
  32. PaIRS_UniNa/ui_Input_Tab_CalVi.py +1280 -1280
  33. PaIRS_UniNa/ui_Log_Tab.py +261 -261
  34. PaIRS_UniNa/ui_Output_Tab.py +2360 -2360
  35. PaIRS_UniNa/ui_Process_Tab.py +3808 -3808
  36. PaIRS_UniNa/ui_Process_Tab_CalVi.py +1547 -1547
  37. PaIRS_UniNa/ui_Process_Tab_Disp.py +1139 -1139
  38. PaIRS_UniNa/ui_Process_Tab_Min.py +435 -435
  39. PaIRS_UniNa/ui_ResizePopup.py +203 -203
  40. PaIRS_UniNa/ui_Vis_Tab.py +1626 -1626
  41. PaIRS_UniNa/ui_Vis_Tab_CalVi.py +1249 -1249
  42. PaIRS_UniNa/ui_Whatsnew.py +131 -131
  43. PaIRS_UniNa/ui_gPairs.py +873 -873
  44. PaIRS_UniNa/ui_infoPaIRS.py +550 -550
  45. PaIRS_UniNa/whatsnew.txt +2 -4
  46. {pairs_unina-0.2.8.dist-info → pairs_unina-0.2.10.dist-info}/METADATA +7 -13
  47. {pairs_unina-0.2.8.dist-info → pairs_unina-0.2.10.dist-info}/RECORD +49 -45
  48. {pairs_unina-0.2.8.dist-info → pairs_unina-0.2.10.dist-info}/WHEEL +0 -0
  49. {pairs_unina-0.2.8.dist-info → pairs_unina-0.2.10.dist-info}/top_level.txt +0 -0
@@ -1,20 +1,20 @@
1
- FLAG_SERIALIZED=True
2
-
3
- import os, json, pickle, traceback
1
+ FLAG_SERIALIZED=True
2
+
3
+ import os, json, pickle, traceback
4
4
  from .PaIRS_pypacks import pri
5
-
5
+
6
6
  from .TabTools import TABpar
7
7
  from .procTools import dataTreePar, CompMin, MediaPIV
8
8
  from .Explorer import TREpar, ITEpar, currentTimeString
9
9
  from .Input_Tab import INPpar
10
- globals()['ImportPar'] = INPpar.ImportPar
10
+ globals()['ImportPar'] = INPpar.ImportPar
11
11
  from .Input_Tab_tools import ImageSet
12
12
  from .Output_Tab import OUTpar
13
13
  from .Process_Tab import PROpar
14
14
  from .Log_Tab import LOGpar
15
15
  from .Vis_Tab import VISpar, NamesPIV
16
- globals()['OUT'] = VISpar.OUT
17
- globals()['PRO'] = VISpar.PRO
16
+ globals()['OUT'] = VISpar.OUT
17
+ globals()['PRO'] = VISpar.PRO
18
18
  from .Process_Tab_Min import PROpar_Min
19
19
  from .Process_Tab_Disp import PROpar_Disp
20
20
  from .Calibration_Tab import CALpar
@@ -24,273 +24,275 @@ from .Vis_Tab_CalVi import VISpar_CalVi
24
24
  from .tabSplitter import SPLpar
25
25
  from .PaIRS_pypacks import identifierName, fontPixelSize, printTypes
26
26
  from .__init__ import __version__,__subversion__,__year__,__mail__,__website__
27
-
28
- class GPApar(TABpar):
29
- def __init__(self):
30
- self.setup()
31
- super().__init__(self.name,'gPaIRS')
32
- self.unchecked_fields+=[]
33
-
34
- def setup(self):
35
- self.name_work, self.username, self.version = identifierName(typeObject='wksp')
36
- self.outName = ''
37
- self.createdDate = currentTimeString()
38
- self.modifiedDate = self.createdDate
39
- self.savedDate = ''
40
- self.FlagSaved = False
41
- self.FlagQueue = True
42
- self.FlagRunnable = True
43
-
44
- self.name = 'Workspace'
45
- self.date = f'Created: {self.createdDate}'
46
- self.icon = 'workspace.png'
47
-
48
- self.infoFields=[f for f,_ in self.__dict__.items()]
49
-
50
- self.Geometry = None
51
- self.WindowState = None
52
- self.SplitterSizes = {}
53
- self.ScrollAreaValues = {}
54
-
55
- #legacy
56
- self.FloatGeometry = []
57
- self.FloatVisible = []
58
-
59
- self.paletteType = 2 #-1,2=standard, 0=light, 1=dark
60
- self.fontPixelSize = fontPixelSize
61
- self.FlagOutDated = 0
62
- self.currentVersion = __version__
63
- self.latestVersion = ''
64
-
65
- self.printTypes = printTypes
66
- self.NumCores = 0
67
-
68
- self.stateFields=[f for f,_ in self.__dict__.items() if f not in self.infoFields]
69
-
70
- def saveBullet(self):
71
- return '' if self.FlagSaved else '<span style="color: #7A8B8B;"><sup>&#9679;</sup></span>'
72
-
73
- def InfoMessage(self):
74
- InfoMessage=f'{self.name}'
75
- if self.FlagSaved:
76
- InfoMessage+=f'\nFile location: {self.outName}'
77
- else:
78
- if self.savedDate:
79
- InfoMessage+=' (unsaved)'
80
- else:
81
- InfoMessage+=' (never saved)'
82
- InfoMessage+=f'\n\nCreated : {self.createdDate}'
83
- InfoMessage+=f'\nModified: {self.modifiedDate}'
84
- if self.savedDate: InfoMessage+=f'\nSaved : {self.savedDate}'
85
- InfoMessage+=f'\n\nUser: {self.username}'
86
- InfoMessage+=f'\nPaIRS version: {self.version}'
87
- return InfoMessage
88
-
89
- def save_list_to_file_serialized(l, filename, flagJSON=False):
90
- basename = os.path.splitext(filename)[0]
91
- pickle_data = {}
92
- pickle_counter = 0
93
- info_pickle =[]
94
-
95
- def serialize_element(elem:TABpar, idx_path):
96
- nonlocal pickle_counter
97
- if elem is None:
98
- return None
99
- data = {}
100
- for field in elem.fields:
101
- value = getattr(elem, field)
102
- if isinstance(value, TABpar):
103
- data[field] = serialize_element(value, idx_path + [field])
104
- elif isinstance(value, CompMin) or isinstance(value, MediaPIV):
105
- data[field] = {'__file_ref__': value.outName,
106
- 'varClass': value.__class__.__name__}
107
- if isinstance(value, MediaPIV):
108
- data[field]['stepType']=value.stepType
109
- try:
110
- if value.outName:
111
- with open(value.outName, 'wb') as file:
112
- pickle.dump(value, file)
113
- except Exception as e:
114
- print(f'Error while saving the file {filename}!\n{e}\n')
115
- elif is_non_json_serializable(value):
116
- info=f'Element: {elem.__class__.__name__} --> field: {field} --> value type: {type(value)}'
117
- info_pickle.append(info)
118
- key = f"ref_{pickle_counter}"
119
- pickle_data[key] = value
120
- data[field] = {'__file_ref__': key}
121
- pickle_counter += 1
122
- else:
123
- data[field] = value
124
- data['parClass'] = elem.__class__.__name__
125
- return data
126
-
127
- def serialize_list(lst, idx_path=[]):
128
- if isinstance(lst, list):
129
- return [serialize_list(item, idx_path + [i]) for i, item in enumerate(lst)]
130
- else:
131
- return serialize_element(lst, idx_path)
132
-
133
- serialized_list = serialize_list(l)
134
-
135
- try:
136
- if flagJSON:
137
- with open(filename, 'w') as file:
138
- json.dump(serialized_list, file, indent=2)
139
- else:
140
- with open(filename, 'wb') as file:
141
- pickle.dump(serialized_list, file)
142
- except Exception as e:
143
- print(f'Error while saving the file {filename}!\n{e}\n')
144
-
145
- if pickle_counter:
146
- pri.IOError.yellow(f'The following non-json serializable items were found in {filename}:\n'+"\n".join(info_pickle))
147
- pickle_filename = basename+'.pairs_data'
148
- try:
149
- with open(pickle_filename, 'wb') as file:
150
- pickle.dump(pickle_data, file)
151
- except Exception as e:
152
- print(f'Error while saving the file {pickle_filename}!\n{e}\n')
153
-
154
-
155
- def load_list_from_file_serialized(filename):
156
- basename = os.path.basename(filename)
157
- pickle_filename = basename+'.pairs_data'
158
-
159
- serialized_list=None
160
- error=''
161
- try:
162
- with open(filename, 'rb') as file:
163
- first_byte = file.read(1)
164
- if first_byte in [b'{', b'[']:
165
- file.seek(0)
166
- try:
167
- serialized_list=json.load(file)
168
- except Exception as e:
169
- error=e
170
- else:
171
- file.seek(0)
172
- try:
173
- import numpy
174
- serialized_list=pickle.load(file)
175
- except Exception as e:
176
- error=e
177
- except Exception as e:
178
- error=e
179
- if error:
180
- pri.IOError.red(f'Error while loading the file {filename}!\n{error}\n')
181
- return serialized_list, str(error)
182
-
183
- error=''
184
- pickle_data = None
185
- if os.path.exists(pickle_filename):
186
- try:
187
- with open(pickle_filename, 'rb') as file:
188
- pickle_data = pickle.load(file)
189
- except Exception as e:
190
- pri.IOError.red(f'Error while loading the file {pickle_filename}!\n{e}\n')
191
- error+=str(e)
192
-
193
- info_pickle=[]
194
-
195
- def deserialize_element(data):
196
- if data is None:
197
- return None
198
- try:
199
- cls_name = data.pop('parClass')
200
- except:
201
- pass
202
- cls = globals()[cls_name]
203
- if cls_name=='dataTreePar':
204
- pass
205
- instance:TABpar = cls()
206
- fields = {}
207
- for key, value in data.items():
208
- if isinstance(value, dict) and 'parClass' in value:
209
- fields[key] = deserialize_element(value)
210
- elif isinstance(value, dict) and 'varClass' in value:
211
- filename = value['__file_ref__']
212
- field_cls_name = value['varClass']
213
- field_cls = globals()[field_cls_name]
214
- if field_cls==MediaPIV:
215
- new_instance:MediaPIV=field_cls(value['stepType'])
216
- else:
217
- new_instance:CompMin=field_cls()
218
- if filename:
219
- try:
220
- if os.path.exists(filename):
221
- with open(filename, 'rb') as file:
222
- loaded_instance:CompMin=pickle.load(file)
223
- for f in loaded_instance.fields:
224
- v_loaded=getattr(loaded_instance,f)
225
- if isinstance(v_loaded,TABpar):
226
- v_new:TABpar=getattr(new_instance,f)
227
- v_new.copyfrom(v_loaded)
228
- else:
229
- setattr(new_instance,f,v_loaded)
230
- except Exception as e:
231
- pri.IOError.red(f'Error while reading the file {filename} (setting "{key}" field of {cls_name} item)\n{traceback.format_exc()}\n')
232
- fields[key] = new_instance
233
- elif isinstance(value, dict) and '__file_ref__' in value:
234
- ref_key = value['__file_ref__']
235
- if pickle_data:
236
- fields[key] = pickle_data[ref_key]
237
- else:
238
- fields[key] = None
239
- info=f'Element: {cls_name} --> field: {key} --> value type: {type(value)}'
240
- info_pickle.append(info)
241
- None
242
- else:
243
- fields[key] = value
244
- for f,v in fields.items():
245
- if f in instance.fields: setattr(instance,f,v)
246
- #instance.copyfromdiz(fields)
247
- return instance
248
-
249
- def deserialize_list(lst):
250
- if isinstance(lst, list):
251
- return [deserialize_list(item) for item in lst]
252
- else:
253
- return deserialize_element(lst)
254
-
255
- if info_pickle:
256
- pri.IOError.red(f'The following non-json serializable items were not found in {filename}:\n'+"\n".join(info_pickle))
257
- l=None
258
- try:
259
- l=deserialize_list(serialized_list)
260
- except Exception as e:
261
- pri.IOError.red(f'Error while loading the file {filename}!\n{e}\n{traceback.format_exc()}\n')
262
- error+=str(e)
263
- return l, error
264
-
265
- def is_non_json_serializable(value):
266
- try:
267
- json.dumps(value)
268
- return False
269
- except (TypeError, OverflowError):
270
- return True
271
-
272
-
273
- def save_list_to_file(l,filename):
274
- try:
275
- with open(filename, 'wb') as file:
276
- pickle.dump(l, file)
277
- except Exception as e:
278
- print(f'Error while saving the file {filename}!\n{e}\n')
279
-
280
- def load_list_from_file(filename):
281
- l=None
282
- errorMessage=''
283
- try:
284
- with open(filename, 'rb') as file:
285
- l=pickle.load(file)
286
- except Exception as e:
287
- errorMessage=f'Error while loading the file {filename}!\n{e}\n'
288
- pri.IOError.red(errorMessage)
289
- return l, errorMessage
290
-
291
- if FLAG_SERIALIZED:
292
- saveList=save_list_to_file_serialized
293
- loadList=load_list_from_file_serialized
294
- else:
295
- saveList=save_list_to_file
296
- loadList=load_list_from_file
27
+
28
+ class GPApar(TABpar):
29
+ def __init__(self):
30
+ self.setup()
31
+ super().__init__(self.name,'gPaIRS')
32
+ self.unchecked_fields+=[]
33
+
34
+ def setup(self):
35
+ self.name_work, self.username, self.version = identifierName(typeObject='wksp')
36
+ self.outName = ''
37
+ self.createdDate = currentTimeString()
38
+ self.modifiedDate = self.createdDate
39
+ self.savedDate = ''
40
+ self.FlagSaved = False
41
+ self.FlagQueue = True
42
+ self.FlagRunnable = True
43
+
44
+ self.name = 'Workspace'
45
+ self.date = f'Created: {self.createdDate}'
46
+ self.icon = 'workspace.png'
47
+
48
+ self.infoFields=[f for f,_ in self.__dict__.items()]
49
+
50
+ self.Geometry = None
51
+ self.WindowState = None
52
+ self.SplitterSizes = {}
53
+ self.ScrollAreaValues = {}
54
+
55
+ #legacy
56
+ self.FloatGeometry = []
57
+ self.FloatVisible = []
58
+
59
+ self.paletteType = 2 #-1,2=standard, 0=light, 1=dark
60
+ self.fontPixelSize = fontPixelSize
61
+ self.FlagOutDated = 0
62
+ self.currentVersion = __version__
63
+ self.latestVersion = ''
64
+
65
+ self.printTypes = printTypes
66
+ self.NumCores = 0
67
+ self.globalVals = {}
68
+ self.globalExceptions = {'Calibration': ['FlagSPIVCal']}
69
+
70
+ self.stateFields=[f for f,_ in self.__dict__.items() if f not in self.infoFields]
71
+
72
+ def saveBullet(self):
73
+ return '' if self.FlagSaved else '<span style="color: #7A8B8B;"><sup>&#9679;</sup></span>'
74
+
75
+ def InfoMessage(self):
76
+ InfoMessage=f'{self.name}'
77
+ if self.FlagSaved:
78
+ InfoMessage+=f'\nFile location: {self.outName}'
79
+ else:
80
+ if self.savedDate:
81
+ InfoMessage+=' (unsaved)'
82
+ else:
83
+ InfoMessage+=' (never saved)'
84
+ InfoMessage+=f'\n\nCreated : {self.createdDate}'
85
+ InfoMessage+=f'\nModified: {self.modifiedDate}'
86
+ if self.savedDate: InfoMessage+=f'\nSaved : {self.savedDate}'
87
+ InfoMessage+=f'\n\nUser: {self.username}'
88
+ InfoMessage+=f'\nPaIRS version: {self.version}'
89
+ return InfoMessage
90
+
91
+ def save_list_to_file_serialized(l, filename, flagJSON=False):
92
+ basename = os.path.splitext(filename)[0]
93
+ pickle_data = {}
94
+ pickle_counter = 0
95
+ info_pickle =[]
96
+
97
+ def serialize_element(elem:TABpar, idx_path):
98
+ nonlocal pickle_counter
99
+ if elem is None:
100
+ return None
101
+ data = {}
102
+ for field in elem.fields:
103
+ value = getattr(elem, field)
104
+ if isinstance(value, TABpar):
105
+ data[field] = serialize_element(value, idx_path + [field])
106
+ elif isinstance(value, CompMin) or isinstance(value, MediaPIV):
107
+ data[field] = {'__file_ref__': value.outName,
108
+ 'varClass': value.__class__.__name__}
109
+ if isinstance(value, MediaPIV):
110
+ data[field]['stepType']=value.stepType
111
+ try:
112
+ if value.outName:
113
+ with open(value.outName, 'wb') as file:
114
+ pickle.dump(value, file)
115
+ except Exception as e:
116
+ print(f'Error while saving the file {filename}!\n{e}\n')
117
+ elif is_non_json_serializable(value):
118
+ info=f'Element: {elem.__class__.__name__} --> field: {field} --> value type: {type(value)}'
119
+ info_pickle.append(info)
120
+ key = f"ref_{pickle_counter}"
121
+ pickle_data[key] = value
122
+ data[field] = {'__file_ref__': key}
123
+ pickle_counter += 1
124
+ else:
125
+ data[field] = value
126
+ data['parClass'] = elem.__class__.__name__
127
+ return data
128
+
129
+ def serialize_list(lst, idx_path=[]):
130
+ if isinstance(lst, list):
131
+ return [serialize_list(item, idx_path + [i]) for i, item in enumerate(lst)]
132
+ else:
133
+ return serialize_element(lst, idx_path)
134
+
135
+ serialized_list = serialize_list(l)
136
+
137
+ try:
138
+ if flagJSON:
139
+ with open(filename, 'w') as file:
140
+ json.dump(serialized_list, file, indent=2)
141
+ else:
142
+ with open(filename, 'wb') as file:
143
+ pickle.dump(serialized_list, file)
144
+ except Exception as e:
145
+ print(f'Error while saving the file {filename}!\n{e}\n')
146
+
147
+ if pickle_counter:
148
+ pri.IOError.yellow(f'The following non-json serializable items were found in {filename}:\n'+"\n".join(info_pickle))
149
+ pickle_filename = basename+'.pairs_data'
150
+ try:
151
+ with open(pickle_filename, 'wb') as file:
152
+ pickle.dump(pickle_data, file)
153
+ except Exception as e:
154
+ print(f'Error while saving the file {pickle_filename}!\n{e}\n')
155
+
156
+
157
+ def load_list_from_file_serialized(filename):
158
+ basename = os.path.basename(filename)
159
+ pickle_filename = basename+'.pairs_data'
160
+
161
+ serialized_list=None
162
+ error=''
163
+ try:
164
+ with open(filename, 'rb') as file:
165
+ first_byte = file.read(1)
166
+ if first_byte in [b'{', b'[']:
167
+ file.seek(0)
168
+ try:
169
+ serialized_list=json.load(file)
170
+ except Exception as e:
171
+ error=e
172
+ else:
173
+ file.seek(0)
174
+ try:
175
+ import numpy
176
+ serialized_list=pickle.load(file)
177
+ except Exception as e:
178
+ error=e
179
+ except Exception as e:
180
+ error=e
181
+ if error:
182
+ pri.IOError.red(f'Error while loading the file {filename}!\n{error}\n')
183
+ return serialized_list, str(error)
184
+
185
+ error=''
186
+ pickle_data = None
187
+ if os.path.exists(pickle_filename):
188
+ try:
189
+ with open(pickle_filename, 'rb') as file:
190
+ pickle_data = pickle.load(file)
191
+ except Exception as e:
192
+ pri.IOError.red(f'Error while loading the file {pickle_filename}!\n{e}\n')
193
+ error+=str(e)
194
+
195
+ info_pickle=[]
196
+
197
+ def deserialize_element(data):
198
+ if data is None:
199
+ return None
200
+ try:
201
+ cls_name = data.pop('parClass')
202
+ except:
203
+ pass
204
+ cls = globals()[cls_name]
205
+ if cls_name=='dataTreePar':
206
+ pass
207
+ instance:TABpar = cls()
208
+ fields = {}
209
+ for key, value in data.items():
210
+ if isinstance(value, dict) and 'parClass' in value:
211
+ fields[key] = deserialize_element(value)
212
+ elif isinstance(value, dict) and 'varClass' in value:
213
+ filename = value['__file_ref__']
214
+ field_cls_name = value['varClass']
215
+ field_cls = globals()[field_cls_name]
216
+ if field_cls==MediaPIV:
217
+ new_instance:MediaPIV=field_cls(value['stepType'])
218
+ else:
219
+ new_instance:CompMin=field_cls()
220
+ if filename:
221
+ try:
222
+ if os.path.exists(filename):
223
+ with open(filename, 'rb') as file:
224
+ loaded_instance:CompMin=pickle.load(file)
225
+ for f in loaded_instance.fields:
226
+ v_loaded=getattr(loaded_instance,f)
227
+ if isinstance(v_loaded,TABpar):
228
+ v_new:TABpar=getattr(new_instance,f)
229
+ v_new.copyfrom(v_loaded)
230
+ else:
231
+ setattr(new_instance,f,v_loaded)
232
+ except Exception as e:
233
+ pri.IOError.red(f'Error while reading the file {filename} (setting "{key}" field of {cls_name} item)\n{traceback.format_exc()}\n')
234
+ fields[key] = new_instance
235
+ elif isinstance(value, dict) and '__file_ref__' in value:
236
+ ref_key = value['__file_ref__']
237
+ if pickle_data:
238
+ fields[key] = pickle_data[ref_key]
239
+ else:
240
+ fields[key] = None
241
+ info=f'Element: {cls_name} --> field: {key} --> value type: {type(value)}'
242
+ info_pickle.append(info)
243
+ None
244
+ else:
245
+ fields[key] = value
246
+ for f,v in fields.items():
247
+ if f in instance.fields: setattr(instance,f,v)
248
+ #instance.copyfromdiz(fields)
249
+ return instance
250
+
251
+ def deserialize_list(lst):
252
+ if isinstance(lst, list):
253
+ return [deserialize_list(item) for item in lst]
254
+ else:
255
+ return deserialize_element(lst)
256
+
257
+ if info_pickle:
258
+ pri.IOError.red(f'The following non-json serializable items were not found in {filename}:\n'+"\n".join(info_pickle))
259
+ l=None
260
+ try:
261
+ l=deserialize_list(serialized_list)
262
+ except Exception as e:
263
+ pri.IOError.red(f'Error while loading the file {filename}!\n{e}\n{traceback.format_exc()}\n')
264
+ error+=str(e)
265
+ return l, error
266
+
267
+ def is_non_json_serializable(value):
268
+ try:
269
+ json.dumps(value)
270
+ return False
271
+ except (TypeError, OverflowError):
272
+ return True
273
+
274
+
275
+ def save_list_to_file(l,filename):
276
+ try:
277
+ with open(filename, 'wb') as file:
278
+ pickle.dump(l, file)
279
+ except Exception as e:
280
+ print(f'Error while saving the file {filename}!\n{e}\n')
281
+
282
+ def load_list_from_file(filename):
283
+ l=None
284
+ errorMessage=''
285
+ try:
286
+ with open(filename, 'rb') as file:
287
+ l=pickle.load(file)
288
+ except Exception as e:
289
+ errorMessage=f'Error while loading the file {filename}!\n{e}\n'
290
+ pri.IOError.red(errorMessage)
291
+ return l, errorMessage
292
+
293
+ if FLAG_SERIALIZED:
294
+ saveList=save_list_to_file_serialized
295
+ loadList=load_list_from_file_serialized
296
+ else:
297
+ saveList=save_list_to_file
298
+ loadList=load_list_from_file