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

monniasza.collects.datalayer.IndexedDatalayerMap Maven / Gradle / Ivy

Go to download

Dependency for the MultiMachineBuilder, a voxel game about building an industrial empire in a finite world. THIS RELEASE IS NOT PLAYABLE. To play the game, donwload from >ITCH.IO LINK HERE< or >GH releases link here<

The newest version!
/**
 * 
 */
package monniasza.collects.datalayer;

import java.util.AbstractMap;
import java.util.AbstractSet;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.function.Function;

import com.google.common.collect.Iterators;

import mmb.NN;
import mmb.Nil;
import monniasza.collects.alloc.AllocationListener;
import monniasza.collects.alloc.Allocator;
import monniasza.collects.alloc.Indexable;

/**
 * A specialized map used by data layers
 * @author oskar
 * @param  type of keys
 * @param  type of values
 */                                                                //not overriding equals(), because the existing implementation meets a contract
public class IndexedDatalayerMap<@NN K extends Indexable, V> extends AbstractMap{//NOSONAR ^^^
	private final ArrayList values0;
	private final Function populator;
	private final Allocator allocator;
	
	public IndexedDatalayerMap(Allocator allocator, Function populator){
		values0 = new ArrayList<>(allocator.size());
		this.populator = populator;
		AllocationListener listener = new Listener();
		this.allocator = allocator;
		allocator.addAllocationListener(listener);
		
		//Populate the array list
		for(int i = 0; i < allocator.size(); i++) {
			K key = allocator.get(i);
			V value = key==null?populator.apply(key):null;
			values0.add(value);
		}
	}
	
	private class Listener implements AllocationListener<@NN K>{
		@Override
		public void allocated(int index, K obj) {
			if(index == values0.size()) 
				values0.add(populator.apply(obj));
			else
				values0.set(index, populator.apply(obj));
		}

		@Override
		public void deallocated(int index, K obj) {
			//unused
		}
	}
	private class KeySet extends AbstractSet{
		@SuppressWarnings("null")
		@Override
		public @NN Iterator iterator() {
			return Iterators.unmodifiableIterator(allocator.iterator());
		}

		@Override
		public int size() {
			return allocator.size();
		}

		@Override
		public boolean contains(@Nil Object o) {
			return containsKey(o);
		}
	}
	private class EntrySet extends AbstractSet>{
		@SuppressWarnings("null")
		@Override
		public @NN Iterator> iterator() {
			return Iterators.transform(allocator.iterator(), key -> new AbstractMap.SimpleImmutableEntry<>(key, get(key)));
		}

		@Override
		public int size() {
			return allocator.size();
		}

		@Override
		public boolean contains(@Nil Object o) {
			return containsKey(o);
		}
	}
	
	@Override
	public Set> entrySet() {
		return new EntrySet();
	}

	/**
	 * Checks if this map contains a key.
	 */
	@Override
	public boolean containsKey(@Nil Object key) {
		if(!(key instanceof Indexable)) return false;
		Indexable k0 = (Indexable) key;
		if(k0.index() != allocator) return false;
		return allocator.isAllocated(k0.ordinal());
	}

	/**
	 * @param key key to check
	 * @return index of given key, or -1 if not found
	 */
	public int indexof(@Nil Object key) {
		if(!(key instanceof Indexable)) return -1;
		Indexable k0 = (Indexable) key;
		if(k0.index() != allocator) return -1;
		return k0.ordinal();
	}
	
	@Override
	@Nil public V get(@Nil Object key) {
		int index = indexof(key);
		if(index >= 0) return values0.get(index);
		return null;
	}

	@Override
	public V put(K key, V value) {
		int idx = indexof(key);
		if(idx < 0) return null;
		V old = values0.get(idx);
		values0.set(idx, value);
		return old;	
	}

	@Override
	public void putAll(Map m) {
		for(Entry e : m.entrySet()) {
			int idx = indexof(e.getKey());
			if(idx < 0) continue;
			values0.set(idx, e.getValue());
		}
	}

	@Override
	public Set keySet() {
		return new KeySet();
	}
	
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy