diff options
author | alexanders@b2ef00c0-3703-41da-baef-cfe82387ac0c <none@none> | 2010-02-03 00:50:41 +0000 |
---|---|---|
committer | alexanders@b2ef00c0-3703-41da-baef-cfe82387ac0c <none@none> | 2010-02-03 00:50:41 +0000 |
commit | 89bda83e0570ab87c6e449f5955613d5385e90b3 (patch) | |
tree | beae82eff98e4b6e18e1521c49d48d087a8cef55 /trunk/infrastructure/net.appjet.oui/synchronizer.scala | |
parent | d912ef9675f2e516df4eba081107729afbffe10c (diff) | |
download | etherpad-89bda83e0570ab87c6e449f5955613d5385e90b3.tar.gz etherpad-89bda83e0570ab87c6e449f5955613d5385e90b3.tar.xz etherpad-89bda83e0570ab87c6e449f5955613d5385e90b3.zip |
removed obsolete svn folder from hg tree
--HG--
extra : convert_revision : svn%3Ab2ef00c0-3703-41da-baef-cfe82387ac0c/trunk%408
Diffstat (limited to 'trunk/infrastructure/net.appjet.oui/synchronizer.scala')
-rw-r--r-- | trunk/infrastructure/net.appjet.oui/synchronizer.scala | 69 |
1 files changed, 0 insertions, 69 deletions
diff --git a/trunk/infrastructure/net.appjet.oui/synchronizer.scala b/trunk/infrastructure/net.appjet.oui/synchronizer.scala deleted file mode 100644 index 2a6d9c1..0000000 --- a/trunk/infrastructure/net.appjet.oui/synchronizer.scala +++ /dev/null @@ -1,69 +0,0 @@ -/** - * Copyright 2009 Google Inc. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS-IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package net.appjet.oui; - -class Synchronizer { - import java.util.concurrent.locks.ReentrantLock; - import java.util.concurrent.ConcurrentHashMap; - - private val lockMap = new ConcurrentHashMap[Object, Lock]; - private val monitor = new Object {}; - - private class Lock { - var users = 0; - val impl = new ReentrantLock; - } - - def acquire(key: Object) { - val lock = monitor.synchronized { - var lck = lockMap.get(key); - if (lck == null) { - lck = new Lock; - lockMap.put(key, lck); - } - lck.users += 1; - lck; - } - lock.impl.lock(); - } - - def isHeld(key: Object): Boolean = { - monitor.synchronized { - val lck = lockMap.get(key); - if (lck == null) { - false; - } - else { - lck.impl.isLocked; - } - } - } - - def release(key: Object) { - val lock = monitor.synchronized { - var lck = lockMap.get(key); - lck.users -= 1; - if (lck.users == 0) { - lockMap.remove(key); - } - lck; - } - lock.impl.unlock(); - } -} - -object GlobalSynchronizer extends Synchronizer; |