org.smartdeveloperhub.jenkins.crawler.infrastructure.persistence.LockManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ci-jenkins-crawler Show documentation
Show all versions of ci-jenkins-crawler Show documentation
The Crawler for the Jenkins integration for the Continuous Integration Harvester of the Smart Developer Hub project
The newest version!
/**
* #-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=#
* This file is part of the Smart Developer Hub Project:
* http://www.smartdeveloperhub.org/
*
* Center for Open Middleware
* http://www.centeropenmiddleware.com/
* #-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=#
* Copyright (C) 2015-2016 Center for Open Middleware.
* #-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=#
* 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.
* #-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=#
* Artifact : org.smartdeveloperhub.harvesters.ci.jenkins:ci-jenkins-crawler:0.3.0
* Bundle : ci-jenkins-crawler-0.3.0.jar
* #-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=#
*/
package org.smartdeveloperhub.jenkins.crawler.infrastructure.persistence;
import java.net.URI;
import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
import com.google.common.collect.Maps;
final class LockManager {
interface Operation {
}
interface RunnableOperation extends Operation {
void execute() throws E;
}
interface CallableOperation extends Operation {
T execute() throws E;
}
private final ConcurrentMap locks;
LockManager() {
this.locks=Maps.newConcurrentMap();
}
private ReadWriteLock register(final URI uri) {
final ReadWriteLock newLock = new ReentrantReadWriteLock();
ReadWriteLock result=this.locks.put(uri, newLock);
if(result==null) {
result=newLock;
}
return result;
}
void read(final URI uri, final RunnableOperation operation) throws E{
final ReadWriteLock lock = register(uri);
lock.readLock().lock();
try {
operation.execute();
} finally {
lock.readLock().unlock();
}
}
T read(final URI uri, final CallableOperation operation) throws E {
final ReadWriteLock lock = register(uri);
lock.readLock().lock();
try {
return operation.execute();
} finally {
lock.readLock().unlock();
}
}
void write(final URI uri, final RunnableOperation operation) throws E{
final ReadWriteLock lock = register(uri);
lock.writeLock().lock();
try {
operation.execute();
} finally {
lock.writeLock().unlock();
}
}
T write(final URI uri, final CallableOperation operation) throws E {
final ReadWriteLock lock = register(uri);
lock.writeLock().lock();
try {
return operation.execute();
} finally {
lock.writeLock().unlock();
}
}
} © 2015 - 2025 Weber Informatics LLC | Privacy Policy