001/* 002 * Licensed to the Apache Software Foundation (ASF) under one 003 * or more contributor license agreements. See the NOTICE file 004 * distributed with this work for additional information 005 * regarding copyright ownership. The ASF licenses this file 006 * to you under the Apache License, Version 2.0 (the 007 * "License"); you may not use this file except in compliance 008 * with the License. You may obtain a copy of the License at 009 * 010 * http://www.apache.org/licenses/LICENSE-2.0 011 * 012 * Unless required by applicable law or agreed to in writing, 013 * software distributed under the License is distributed on an 014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 015 * KIND, either express or implied. See the License for the 016 * specific language governing permissions and limitations 017 * under the License. 018 */ 019package org.eclipse.aether.named.providers; 020 021import javax.inject.Named; 022import javax.inject.Singleton; 023 024import java.util.concurrent.Semaphore; 025import java.util.concurrent.TimeUnit; 026 027import org.eclipse.aether.named.support.AdaptedSemaphoreNamedLock; 028import org.eclipse.aether.named.support.NamedLockFactorySupport; 029 030/** 031 * A JVM-local named lock factory that uses named {@link Semaphore}s. 032 */ 033@Singleton 034@Named(LocalSemaphoreNamedLockFactory.NAME) 035public class LocalSemaphoreNamedLockFactory extends NamedLockFactorySupport { 036 public static final String NAME = "semaphore-local"; 037 038 @Override 039 protected AdaptedSemaphoreNamedLock createLock(final String name) { 040 Semaphore semaphore = new Semaphore(Integer.MAX_VALUE); 041 return new AdaptedSemaphoreNamedLock(name, this, new JVMSemaphore(semaphore)); 042 } 043 044 /** 045 * Adapted JVM {@link java.util.concurrent.Semaphore}. 046 */ 047 private static final class JVMSemaphore implements AdaptedSemaphoreNamedLock.AdaptedSemaphore { 048 private final Semaphore semaphore; 049 050 private JVMSemaphore(final Semaphore semaphore) { 051 this.semaphore = semaphore; 052 } 053 054 @Override 055 public boolean tryAcquire(final int perms, final long time, final TimeUnit unit) throws InterruptedException { 056 return semaphore.tryAcquire(perms, time, unit); 057 } 058 059 @Override 060 public void release(final int perms) { 061 semaphore.release(perms); 062 } 063 } 064}