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

io.continual.util.nv.impl.nvReadableStack Maven / Gradle / Ivy

There is a newer version: 0.3.14
Show newest version
/*
 *	Copyright 2019, Continual.io
 *
 *	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.
 */
package io.continual.util.nv.impl;

import java.util.Collection;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map;
import java.util.TreeSet;

import io.continual.util.nv.NvReadable;

public class nvReadableStack extends nvBaseReadable
{
	public nvReadableStack ()
	{
		super ();
		fStack = new LinkedList ();
	}

	public nvReadableStack push ( NvReadable p )
	{
		fStack.addFirst ( p );
		return this;
	}

	public nvReadableStack pushBelow ( NvReadable below, NvReadable above )
	{
		int i = fStack.indexOf ( above );
		if ( i < 0 )
		{
			push ( below );
		}
		else
		{
			fStack.add ( i+1, below );
		}
		return this;
	}

	public String getString ( String key ) throws MissingReqdSettingException
	{
		String result = null;
		boolean found = false;
		for ( NvReadable p : fStack )
		{
			if ( p.hasValueFor ( key ) )
			{
				result = p.getString ( key );
				found = true;
				break;
			}
		}

		if ( !found )
		{
			throw new MissingReqdSettingException ( key );
		}

		return eval ( result );
	}

	// different implementations handle string sets differently; we can't assume that getString returns a comma-delimited array
	@Override
	public String[] getStrings ( String key ) throws MissingReqdSettingException
	{
		String[] result = null;
		boolean found = false;
		for ( NvReadable p : fStack )
		{
			if ( p.hasValueFor ( key ) )
			{
				result = p.getStrings ( key );
				found = true;
				break;
			}
		}

		if ( !found )
		{
			throw new MissingReqdSettingException ( key );
		}

		if ( result != null )
		{
			for ( int i=0; i fStack;

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

	@Override
	public Collection getAllKeys ()
	{
		final TreeSet set = new TreeSet ();
		for ( NvReadable r : fStack )
		{
			set.addAll ( r.getAllKeys () );
		}
		return set;
	}

	@Override
	public Map getCopyAsMap ()
	{
		// this could be faster, but it's an easy way to get the correct values
		final HashMap map = new HashMap ();
		for ( String key : getAllKeys () )
		{
			final String val = getString ( key, null );
			if ( val != null )
			{
				map.put ( key, val );
			}
		}
		return map;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy