import org.simantics.acorn.GraphClientImpl2;
import org.simantics.acorn.exception.AcornAccessVerificationException;
import org.simantics.acorn.exception.IllegalAcornStateException;
-import org.simantics.db.common.utils.Logger;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
/*
* The order rule of synchronization for LRU and LRUObject is:
- * § Always lock LRUObject first!
+ * � Always lock LRUObject first!
*
*/
public class LRU<MapKey,MapValue extends LRUObject<MapKey, MapValue>> {
-
+
+ private static final Logger LOGGER = LoggerFactory.getLogger(LRU.class);
+
public static boolean VERIFY = true;
final private long swapTime = 5L*1000000000L;
}
}
+
+
+ public MapValue purge(MapKey id) {
+ return map.remove(id);
+ }
+
public MapValue get(MapKey key) throws AcornAccessVerificationException {
if(VERIFY) verifyAccess();
manager.notSafeToMakeSnapshot(new IllegalAcornStateException(t));
}
t.printStackTrace();
- Logger.defaultLogError(t);
+ LOGGER.error("Exception happened in WriteRunnable.run", t);
}
}
runWithMutex();
done = true;
} else {
- System.err.println("Retry mutex acquire");
+ LOGGER.warn("Retry mutex acquire");
gotMutex = impl.tryAcquireMutex();
}