/***************************************************************************
* Copyright (C) 2010 by Fabrizio Montesi <famontesi@gmail.com> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU Library General Public License as *
* published by the Free Software Foundation; either version 2 of the *
* License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
* *
* For details about the authors of this software, see the AUTHORS file. *
***************************************************************************/
package joliex.storage.types;
import java.util.Iterator;
import java.util.NoSuchElementException;
import jolie.runtime.Value;
import jolie.runtime.ValueVector;
import joliex.storage.types.StoragePath.Node;
/**
*
* @author Fabrizio Montesi
*/
public class StoragePath implements Iterable< Node >
{
public static class Node
{
private final String name;
private final int index;
private Node( String name, int index )
{
this.name = name;
this.index = index;
}
public String name()
{
return name;
}
public int index()
{
return index;
}
}
private static class ArrayIterator< T > implements Iterator< T >
{
private final T[] array;
private int index = 0;
public ArrayIterator( T[] array )
{
this.array = array;
}
public T next()
{
if ( index + 1 >= array.length ) {
throw new NoSuchElementException();
}
return array[ index++ ];
}
public boolean hasNext()
{
return index + 1 < array.length;
}
public void remove()
{
throw new UnsupportedOperationException();
}
}
private final Node[] nodes;
private StoragePath( Node[] nodes )
{
this.nodes = nodes;
}
public Node[] nodes()
{
return nodes;
}
public Iterator< Node > iterator()
{
return new ArrayIterator< Node >( nodes );
}
public static StoragePath fromValue( Value value )
{
ValueVector nodesVector = value.getChildren( "node" );
Node[] nodes = new Node[ nodesVector.size() ];
int i = 0;
for( Value nodeValue : nodesVector ) {
nodes[ i++ ] = new Node(
nodeValue.getFirstChild( "name" ).strValue(),
nodeValue.getFirstChild( "index" ).intValue()
);
}
return new StoragePath( nodes );
}
public static Value toValue( StoragePath path )
{
ValueVector nodesVector = ValueVector.create();
Value nodeValue;
for( Node node : path.nodes ) {
nodeValue = Value.create();
nodeValue.getFirstChild( "name" ).setValue( node.name() );
nodeValue.getFirstChild( "index" ).setValue( node.index() );
nodesVector.add( nodeValue );
}
nodeValue = Value.create();
nodeValue.children().put( "node", nodesVector );
return nodeValue;
}
}