All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.smartdeveloperhub.jenkins.crawler.infrastructure.persistence.LockManager Maven / Gradle / Ivy

Go to download

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