Track whether loading is underway
authorJeremy Stanley <fungi@yuggoth.org>
Mon, 31 Jul 2017 14:56:57 +0000 (14:56 +0000)
committerJeremy Stanley <fungi@yuggoth.org>
Mon, 31 Jul 2017 14:56:57 +0000 (14:56 +0000)
In preparation for safeguards preventing alteration of elements from
read-only backing files, we need a way to identify that loading
updated files is in progress; that's the only time elements from
read-only files should ever change.

mudpy/misc.py

index af5427a..4e32ccc 100644 (file)
@@ -347,6 +347,7 @@ class Universe:
         self.contents = {}
         self.default_origins = {}
         self.directions = set()
+        self.loading = False
         self.loglines = []
         self.private_files = []
         self.reload_flag = False
@@ -375,6 +376,9 @@ class Universe:
     def load(self):
         """Load universe data from persistent storage."""
 
+        # while loading, it's safe to update elements from read-only files
+        self.loading = True
+
         # it's possible for this to enter before logging configuration is read
         pending_loglines = []
 
@@ -425,6 +429,10 @@ class Universe:
         for element in self.contents.values():
             element.update_location()
             element.clean_contents()
+
+        # done loading, so disallow updating elements from read-only files
+        self.loading = False
+
         return pending_loglines
 
     def new(self):