Berry persist hide errors when saving (#18686)

This commit is contained in:
s-hadinger 2023-05-17 22:43:13 +02:00 committed by GitHub
parent 2b76e8e668
commit 2d8ea8f51c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 217 additions and 207 deletions

View File

@ -10,17 +10,14 @@
#@ solidify:persist_module #@ solidify:persist_module
var persist_module = module("persist") var persist_module = module("persist")
persist_module.init = def (m)
class Persist class Persist
var _filename static var _filename = '_persist.json'
var _p var _p
var _dirty var _dirty
#- persist can be initialized with pre-existing values. The map is not copied so any change will be reflected -# #- persist can be initialized with pre-existing values. The map is not copied so any change will be reflected -#
def init(m) def init(m)
# print("Persist init") # print("Persist init")
self._filename = '_persist.json'
if isinstance(m,map) if isinstance(m,map)
self._p = m.copy() # need to copy instead? self._p = m.copy() # need to copy instead?
else else
@ -97,9 +94,13 @@ persist_module.init = def (m)
f.close() f.close()
except .. as e, m except .. as e, m
if f != nil f.close() end if f != nil f.close() end
f = nil
try
f = open(self._filename, "w") f = open(self._filename, "w")
f.write('{}') # fallback write empty map f.write('{}') # fallback write empty map
f.close() except ..
end
if f != nil f.close() end
raise e, m raise e, m
end end
self._dirty = false self._dirty = false
@ -154,9 +155,10 @@ persist_module.init = def (m)
end end
end end
end end
persist_module.Persist = Persist
persist_module.init = def (m)
return Persist() # return an instance of this class return m.Persist() # return an instance of this class
end end
return persist_module return persist_module

View File

@ -4,6 +4,34 @@
\********************************************************************/ \********************************************************************/
#include "be_constobj.h" #include "be_constobj.h"
/********************************************************************
** Solidified function: _anonymous_
********************************************************************/
be_local_closure(persist__anonymous_, /* name */
be_nested_proto(
3, /* nstack */
1, /* argc */
0, /* varg */
0, /* has upvals */
NULL, /* no upvals */
0, /* has sup protos */
NULL, /* no sub protos */
1, /* has constants */
( &(const bvalue[ 1]) { /* constants */
/* K0 */ be_nested_str(Persist),
}),
&be_const_str__anonymous_,
&be_const_str_solidified,
( &(const binstruction[ 3]) { /* code */
0x8C040100, // 0000 GETMET R1 R0 K0
0x7C040200, // 0001 CALL R1 1
0x80040200, // 0002 RET 1 R1
})
)
);
/*******************************************************************/
extern const bclass be_class_Persist; extern const bclass be_class_Persist;
/******************************************************************** /********************************************************************
@ -331,7 +359,7 @@ be_local_closure(Persist_save, /* name */
}), }),
&be_const_str_save, &be_const_str_save,
&be_const_str_solidified, &be_const_str_solidified,
( &(const binstruction[37]) { /* code */ ( &(const binstruction[48]) { /* code */
0x4C040000, // 0000 LDNIL R1 0x4C040000, // 0000 LDNIL R1
0xA802000B, // 0001 EXBLK 0 #000E 0xA802000B, // 0001 EXBLK 0 #000E
0x60080011, // 0002 GETGBL R2 G17 0x60080011, // 0002 GETGBL R2 G17
@ -345,30 +373,41 @@ be_local_closure(Persist_save, /* name */
0x8C080303, // 000A GETMET R2 R1 K3 0x8C080303, // 000A GETMET R2 R1 K3
0x7C080200, // 000B CALL R2 1 0x7C080200, // 000B CALL R2 1
0xA8040001, // 000C EXBLK 1 1 0xA8040001, // 000C EXBLK 1 1
0x70020013, // 000D JMP #0022 0x7002001E, // 000D JMP #002D
0xAC080002, // 000E CATCH R2 0 2 0xAC080002, // 000E CATCH R2 0 2
0x70020010, // 000F JMP #0021 0x7002001B, // 000F JMP #002C
0x4C100000, // 0010 LDNIL R4 0x4C100000, // 0010 LDNIL R4
0x20100204, // 0011 NE R4 R1 R4 0x20100204, // 0011 NE R4 R1 R4
0x78120001, // 0012 JMPF R4 #0015 0x78120001, // 0012 JMPF R4 #0015
0x8C100303, // 0013 GETMET R4 R1 K3 0x8C100303, // 0013 GETMET R4 R1 K3
0x7C100200, // 0014 CALL R4 1 0x7C100200, // 0014 CALL R4 1
0x60100011, // 0015 GETGBL R4 G17 0x4C040000, // 0015 LDNIL R1
0x88140100, // 0016 GETMBR R5 R0 K0 0xA8020009, // 0016 EXBLK 0 #0021
0x58180001, // 0017 LDCONST R6 K1 0x60100011, // 0017 GETGBL R4 G17
0x7C100400, // 0018 CALL R4 2 0x88140100, // 0018 GETMBR R5 R0 K0
0x5C040800, // 0019 MOVE R1 R4 0x58180001, // 0019 LDCONST R6 K1
0x8C100304, // 001A GETMET R4 R1 K4 0x7C100400, // 001A CALL R4 2
0x58180005, // 001B LDCONST R6 K5 0x5C040800, // 001B MOVE R1 R4
0x7C100400, // 001C CALL R4 2 0x8C100304, // 001C GETMET R4 R1 K4
0x8C100303, // 001D GETMET R4 R1 K3 0x58180005, // 001D LDCONST R6 K5
0x7C100200, // 001E CALL R4 1 0x7C100400, // 001E CALL R4 2
0xB0040403, // 001F RAISE 1 R2 R3 0xA8040001, // 001F EXBLK 1 1
0x70020000, // 0020 JMP #0022 0x70020003, // 0020 JMP #0025
0xB0080000, // 0021 RAISE 2 R0 R0 0xAC100000, // 0021 CATCH R4 0 0
0x50080000, // 0022 LDBOOL R2 0 0 0x70020000, // 0022 JMP #0024
0x90020C02, // 0023 SETMBR R0 K6 R2 0x70020000, // 0023 JMP #0025
0x80000000, // 0024 RET 0 0xB0080000, // 0024 RAISE 2 R0 R0
0x4C100000, // 0025 LDNIL R4
0x20100204, // 0026 NE R4 R1 R4
0x78120001, // 0027 JMPF R4 #002A
0x8C100303, // 0028 GETMET R4 R1 K3
0x7C100200, // 0029 CALL R4 1
0xB0040403, // 002A RAISE 1 R2 R3
0x70020000, // 002B JMP #002D
0xB0080000, // 002C RAISE 2 R0 R0
0x50080000, // 002D LDBOOL R2 0 0
0x90020C02, // 002E SETMBR R0 K6 R2
0x80000000, // 002F RET 0
}) })
) )
); );
@ -505,37 +544,35 @@ be_local_closure(Persist_init, /* name */
0, /* has sup protos */ 0, /* has sup protos */
NULL, /* no sub protos */ NULL, /* no sub protos */
1, /* has constants */ 1, /* has constants */
( &(const bvalue[ 6]) { /* constants */ ( &(const bvalue[ 5]) { /* constants */
/* K0 */ be_nested_str(_filename), /* K0 */ be_nested_str(_p),
/* K1 */ be_nested_str(_persist_X2Ejson), /* K1 */ be_nested_str(copy),
/* K2 */ be_nested_str(_p), /* K2 */ be_nested_str(load),
/* K3 */ be_nested_str(copy), /* K3 */ be_nested_str(_filename),
/* K4 */ be_nested_str(load), /* K4 */ be_nested_str(_dirty),
/* K5 */ be_nested_str(_dirty),
}), }),
&be_const_str_init, &be_const_str_init,
&be_const_str_solidified, &be_const_str_solidified,
( &(const binstruction[20]) { /* code */ ( &(const binstruction[19]) { /* code */
0x90020101, // 0000 SETMBR R0 K0 K1 0x6008000F, // 0000 GETGBL R2 G15
0x6008000F, // 0001 GETGBL R2 G15 0x5C0C0200, // 0001 MOVE R3 R1
0x5C0C0200, // 0002 MOVE R3 R1 0x60100013, // 0002 GETGBL R4 G19
0x60100013, // 0003 GETGBL R4 G19 0x7C080400, // 0003 CALL R2 2
0x7C080400, // 0004 CALL R2 2 0x780A0003, // 0004 JMPF R2 #0009
0x780A0003, // 0005 JMPF R2 #000A 0x8C080301, // 0005 GETMET R2 R1 K1
0x8C080303, // 0006 GETMET R2 R1 K3 0x7C080200, // 0006 CALL R2 1
0x7C080200, // 0007 CALL R2 1 0x90020002, // 0007 SETMBR R0 K0 R2
0x90020402, // 0008 SETMBR R0 K2 R2 0x70020002, // 0008 JMP #000C
0x70020002, // 0009 JMP #000D 0x60080013, // 0009 GETGBL R2 G19
0x60080013, // 000A GETGBL R2 G19 0x7C080000, // 000A CALL R2 0
0x7C080000, // 000B CALL R2 0 0x90020002, // 000B SETMBR R0 K0 R2
0x90020402, // 000C SETMBR R0 K2 R2 0x8C080102, // 000C GETMET R2 R0 K2
0x8C080104, // 000D GETMET R2 R0 K4 0x88100100, // 000D GETMBR R4 R0 K0
0x88100102, // 000E GETMBR R4 R0 K2 0x88140103, // 000E GETMBR R5 R0 K3
0x88140100, // 000F GETMBR R5 R0 K0 0x7C080600, // 000F CALL R2 3
0x7C080600, // 0010 CALL R2 3 0x50080000, // 0010 LDBOOL R2 0 0
0x50080000, // 0011 LDBOOL R2 0 0 0x90020802, // 0011 SETMBR R0 K4 R2
0x90020A02, // 0012 SETMBR R0 K5 R2 0x80000000, // 0012 RET 0
0x80000000, // 0013 RET 0
}) })
) )
); );
@ -634,7 +671,7 @@ be_local_closure(Persist_has, /* name */
** Solidified class: Persist ** Solidified class: Persist
********************************************************************/ ********************************************************************/
be_local_class(Persist, be_local_class(Persist,
3, 2,
NULL, NULL,
be_nested_map(16, be_nested_map(16,
( (struct bmapnode*) &(const bmapnode[]) { ( (struct bmapnode*) &(const bmapnode[]) {
@ -648,54 +685,25 @@ be_local_class(Persist,
{ be_const_key(find, -1), be_const_closure(Persist_find_closure) }, { be_const_key(find, -1), be_const_closure(Persist_find_closure) },
{ be_const_key(save, -1), be_const_closure(Persist_save_closure) }, { be_const_key(save, -1), be_const_closure(Persist_save_closure) },
{ be_const_key(json_fdump_any, 12), be_const_closure(Persist_json_fdump_any_closure) }, { be_const_key(json_fdump_any, 12), be_const_closure(Persist_json_fdump_any_closure) },
{ be_const_key(_p, 7), be_const_var(1) }, { be_const_key(_p, 7), be_const_var(0) },
{ be_const_key(_filename, -1), be_const_var(0) }, { be_const_key(_filename, -1), be_nested_str(_persist_X2Ejson) },
{ be_const_key(load, -1), be_const_closure(Persist_load_closure) }, { be_const_key(load, -1), be_const_closure(Persist_load_closure) },
{ be_const_key(json_fdump_map, 5), be_const_closure(Persist_json_fdump_map_closure) }, { be_const_key(json_fdump_map, 5), be_const_closure(Persist_json_fdump_map_closure) },
{ be_const_key(_dirty, -1), be_const_var(2) }, { be_const_key(_dirty, -1), be_const_var(1) },
{ be_const_key(member, -1), be_const_closure(Persist_member_closure) }, { be_const_key(member, -1), be_const_closure(Persist_member_closure) },
})), })),
(bstring*) &be_const_str_Persist (bstring*) &be_const_str_Persist
); );
/********************************************************************
** Solidified function: _anonymous_
********************************************************************/
be_local_closure(persist__anonymous_, /* name */
be_nested_proto(
3, /* nstack */
1, /* argc */
0, /* varg */
0, /* has upvals */
NULL, /* no upvals */
0, /* has sup protos */
NULL, /* no sub protos */
1, /* has constants */
( &(const bvalue[ 1]) { /* constants */
/* K0 */ be_const_class(be_class_Persist),
}),
&be_const_str__anonymous_,
&be_const_str_solidified,
( &(const binstruction[ 5]) { /* code */
0x58040000, // 0000 LDCONST R1 K0
0xB4000000, // 0001 CLASS K0
0x5C080200, // 0002 MOVE R2 R1
0x7C080000, // 0003 CALL R2 0
0x80040400, // 0004 RET 1 R2
})
)
);
/*******************************************************************/
/******************************************************************** /********************************************************************
** Solidified module: persist ** Solidified module: persist
********************************************************************/ ********************************************************************/
be_local_module(persist, be_local_module(persist,
"persist", "persist",
be_nested_map(1, be_nested_map(2,
( (struct bmapnode*) &(const bmapnode[]) { ( (struct bmapnode*) &(const bmapnode[]) {
{ be_const_key(init, -1), be_const_closure(persist__anonymous__closure) }, { be_const_key(Persist, -1), be_const_class(be_class_Persist) },
{ be_const_key(init, 0), be_const_closure(persist__anonymous__closure) },
})) }))
); );
BE_EXPORT_VARIABLE be_define_const_native_module(persist); BE_EXPORT_VARIABLE be_define_const_native_module(persist);