Codebase list core-async-clojure / 66303a4 src / main / clojure / clojure / core / async / impl / mutex.clj
66303a4

Tree @66303a4 (Download .tar.gz)

mutex.clj @66303a4raw · history · blame

;;   Copyright (c) Rich Hickey and contributors. All rights reserved.
;;   The use and distribution terms for this software are covered by the
;;   Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
;;   which can be found in the file epl-v10.html at the root of this distribution.
;;   By using this software in any fashion, you are agreeing to be bound by
;;   the terms of this license.
;;   You must not remove this notice, or any other, from this software.

(ns ^{:skip-wiki true}
  clojure.core.async.impl.mutex
  (:require [clojure.core.async.impl.protocols :as impl])
  (:import [java.util.concurrent.locks Lock ReentrantLock]))

(defn mutex []
  (let [m (ReentrantLock.)]
    (reify
     Lock
     (lock [_] (.lock m))
     (unlock [_] (.unlock m)))))

#_(defn mutex []
  (let [cas (java.util.concurrent.atomic.AtomicInteger.)]
    (reify
     Lock
     (lock [_] (loop [got (.compareAndSet cas 0 1)]
                 (if got
                   nil
                   (recur (.compareAndSet cas 0 1)))))
     (unlock [_] (.set cas 0)))))