[yast-devel] Important Changes to Storage
Hi Hackers, for fate #302971 I had to implement a lock for libstorage. This has some consequences for everyone using storage in YaST. The initialisation of libstorage fails if there is another process holding a lock. I have extended Storage::InitLibstorage to display a popup in that case (unfinished). The user can retry to initialise libstorage. The problem is that so far nobody explicitly initialises libstorage. This is more or less required now since you have to take action when locking fails (e.g. gracefully abort). So call Storage::InitLibstorage(readonly) before doing any other storage calls. You can set readonly to true if you are sure your code and no code you call modifies storage. If you do not call Storage::InitLibstorage() the first storage function will do so. But if initialisation fails all storage functions requiring libstorage return nil (if they return anything) or crash (if they don't check for proper initialisation). Comments for improvement to the situation are welcome. ciao Arvin -- Arvin Schnell, <aschnell@suse.de> Software Engineer, Research & Development SUSE LINUX Products GmbH, GF: Markus Rex, HRB 16746 (AG Nürnberg) -- To unsubscribe, e-mail: yast-devel+unsubscribe@opensuse.org For additional commands, e-mail: yast-devel+help@opensuse.org
On Sun, Aug 03, 2008 at 05:08:02PM +0200, Arvin Schnell wrote:
Hi Hackers,
for fate #302971 I had to implement a lock for libstorage. This has some consequences for everyone using storage in YaST.
Two more notes: - In trunk/storage/libstorage/examples you can find the program TestLock to test locking. - With the env. var. YAST2_STORAGE_NO_LOCKING you can disable locking. Might be useful for testsuites. ciao Arvin -- To unsubscribe, e-mail: yast-devel+unsubscribe@opensuse.org For additional commands, e-mail: yast-devel+help@opensuse.org
participants (1)
-
Arvin Schnell