/******************************************************************************* * Copyright (c) 2014, 2016 Association for Decentralized Information Management * in Industry THTH ry. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * VTT Technical Research Centre of Finland - initial API and implementation *******************************************************************************/ package org.simantics.r.scl.variable; import org.rosuda.REngine.REXP; import org.rosuda.REngine.REXPMismatchException; import org.rosuda.REngine.RList; public class RListItemNode implements RVariableNode { private RVariableNode parent; private int index; public RListItemNode(RVariableNode parent, int index) { this.index = index; this.parent = parent; } @Override public REXP getValue() { REXP parentValue = parent.getValue(); if (parentValue == null || ! parentValue.isList()) return null; RList list; try { list = parentValue.asList(); } catch (REXPMismatchException e) { // Should never happen return null; } return list.at(index); } @Override public String getName() { return RNodeManager.INDEXED_ITEM_NAME_PREFIX + Integer.toString(index); } @Override public RVariableNode getParent() { return parent; } }