Prechádzať zdrojové kódy

Change Store object internal mapping strucuture from object to an actual Map

Lucas de Souza 6 rokov pred
rodič
commit
c8c6684a2e
1 zmenil súbory, kde vykonal 12 pridanie a 12 odobranie
  1. 12 12
      js/processor/store/store.js

+ 12 - 12
js/processor/store/store.js

@@ -26,7 +26,7 @@ export class Store {
 
 
   constructor(name) {
   constructor(name) {
     this.name = name;
     this.name = name;
-    this.store = {};
+    this.store = new Map();
     this.nextStore = null;
     this.nextStore = null;
     this.mode = Modes.RUN; 
     this.mode = Modes.RUN; 
   }
   }
@@ -36,22 +36,22 @@ export class Store {
   }
   }
 
 
   applyStore (id) {
   applyStore (id) {
-    if(!this.store[id]) {
+    if(!this.store.has(id)) {
       if (this.nextStore !== null) {
       if (this.nextStore !== null) {
         return this.nextStore.applyStore(id);
         return this.nextStore.applyStore(id);
       } else {
       } else {
         throw new Error(`Variable ${id} not found.`);
         throw new Error(`Variable ${id} not found.`);
       }
       }
     }
     }
-    const val = this.store[id];
+    const val = this.store.get(id);
     if (val.isRef) {
     if (val.isRef) {
       return val.getRefObj();
       return val.getRefObj();
     }
     }
-    return this.store[id];
+    return val;
   }
   }
 
 
   updateStore (id, stoObj) {
   updateStore (id, stoObj) {
-    if(!this.store[id]) {
+    if(!this.store.has(id)) {
       if(this.nextStore !== null) {
       if(this.nextStore !== null) {
         this.nextStore.updateStore(id, stoObj);
         this.nextStore.updateStore(id, stoObj);
         return this;
         return this;
@@ -60,7 +60,7 @@ export class Store {
         throw new Error(`Variable ${id} not found.`);
         throw new Error(`Variable ${id} not found.`);
       }
       }
     } else {
     } else {
-      const oldObj = this.store[id];
+      const oldObj = this.store.get(id);
       if(oldObj.readOnly) {
       if(oldObj.readOnly) {
         // TODO: better error message
         // TODO: better error message
         throw new Error("Cannot change value of a read only variable: " + id);
         throw new Error("Cannot change value of a read only variable: " + id);
@@ -72,8 +72,8 @@ export class Store {
         const newObj = stoObj.copy();
         const newObj = stoObj.copy();
         stoObj.destroy();
         stoObj.destroy();
         newObj.setID(id);
         newObj.setID(id);
-        this.store[id].destroy();
-        this.store[id] = newObj;
+        this.store.get(id).destroy();
+        this.store.set(id, newObj);
         return this;
         return this;
       } else {
       } else {
         const oldType = oldObj.type;
         const oldType = oldObj.type;
@@ -89,12 +89,12 @@ export class Store {
   // updateStoreRef(id, stoObjAddress) {...}
   // updateStoreRef(id, stoObjAddress) {...}
 
 
   insertStore (id, stoObj) {
   insertStore (id, stoObj) {
-    if (this.store[id]) {
+    if (this.store.has(id)) {
       // TODO: better error message
       // TODO: better error message
       throw new Error(`${id} is already defined`);
       throw new Error(`${id} is already defined`);
     }
     }
     stoObj.setID(id);
     stoObj.setID(id);
-    this.store[id] = stoObj;
+    this.store.set(id, stoObj);
     return this;
     return this;
   }
   }
   /**
   /**
@@ -102,13 +102,13 @@ export class Store {
    * applyStore will return the refferenced object if the object in the store is a ref
    * applyStore will return the refferenced object if the object in the store is a ref
    */
    */
   getStoreObject (id) {
   getStoreObject (id) {
-    if(!this.store[id]) {
+    if(!this.store.has(id)) {
       if (this.nextStore !== null) {
       if (this.nextStore !== null) {
         return this.nextStore.getStoreObject(id);
         return this.nextStore.getStoreObject(id);
       } else {
       } else {
         throw new Error(`Variable ${id} not found.`);
         throw new Error(`Variable ${id} not found.`);
       }
       }
     }
     }
-    return this.store[id];
+    return this.store.get(id);
   }
   }
 }
 }