/* * Galaxy * Copyright (c) 2012-2014, Parallel Universe Software Co. All rights reserved. * * This program and the accompanying materials are dual-licensed under * either the terms of the Eclipse Public License v1.0 as published by * the Eclipse Foundation * * or (per the licensee's choosing) * * under the terms of the GNU Lesser General Public License version 3.0 * as published by the Free Software Foundation. */ package co.paralleluniverse.galaxy.objects; import co.paralleluniverse.galaxy.Cache; import co.paralleluniverse.galaxy.CacheListener; /** * Wraps T and implements Distributed interface * * @author eitan * @param <T> */ public class DistributedReferenceStore<R extends DistributedReference<T>, T> { private final Cache cache; public DistributedReferenceStore(Cache cache) { this.cache = cache; } public R newRef(long id, T obj) { if (id <= 0) return null; assert cache.getListener(id) == null; final R ref = createRef(id, obj); cache.setListener(id, ref); return ref; } public R getOrCreateRef(long id) { if (id <= 0) return null; final CacheListener ref = cache.getListener(id); return (R) (ref != null ? ref : cache.setListenerIfAbsent(id, createRef(id, null))); } protected R createRef(long id, T obj) { return (R) new DistributedReference<T>(id, obj); } public static <T> DistributedReference<T> newRef(Cache cache, long id, T obj) { if (id <= 0) return null; assert cache.getListener(id) == null; final DistributedReference<T> ref = new DistributedReference<T>(id, obj); cache.setListener(id, ref); return ref; } public static <T> DistributedReference<T> getOrCreateRef(Cache cache, long id) { if (id <= 0) return null; final CacheListener ref = cache.getListener(id); return (DistributedReference<T>) (ref != null ? ref : cache.setListenerIfAbsent(id, new DistributedReference<T>(id, null))); } }