X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.spreadsheet.common%2Fsrc%2Forg%2Fsimantics%2Fspreadsheet%2Fcommon%2Fexpression%2Fnode%2FAAddressValue.java;fp=bundles%2Forg.simantics.spreadsheet.common%2Fsrc%2Forg%2Fsimantics%2Fspreadsheet%2Fcommon%2Fexpression%2Fnode%2FAAddressValue.java;h=30067a377757087e6b77013435370e4f61430e57;hp=0000000000000000000000000000000000000000;hb=969bd23cab98a79ca9101af33334000879fb60c5;hpb=866dba5cd5a3929bbeae85991796acb212338a08 diff --git a/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/expression/node/AAddressValue.java b/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/expression/node/AAddressValue.java new file mode 100644 index 000000000..30067a377 --- /dev/null +++ b/bundles/org.simantics.spreadsheet.common/src/org/simantics/spreadsheet/common/expression/node/AAddressValue.java @@ -0,0 +1,148 @@ +/******************************************************************************* + * Copyright (c) 2007, 2010 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 + *******************************************************************************/ +/* This file was generated by SableCC (http://www.sablecc.org/). */ + +package org.simantics.spreadsheet.common.expression.node; + +import org.simantics.spreadsheet.common.expression.analysis.*; + +@SuppressWarnings("nls") +public final class AAddressValue extends PValue +{ + private TAmpersand _ampersand_; + private PRange _range_; + + public AAddressValue() + { + // Constructor + } + + public AAddressValue( + @SuppressWarnings("hiding") TAmpersand _ampersand_, + @SuppressWarnings("hiding") PRange _range_) + { + // Constructor + setAmpersand(_ampersand_); + + setRange(_range_); + + } + + @Override + public Object clone() + { + return new AAddressValue( + cloneNode(this._ampersand_), + cloneNode(this._range_)); + } + + public void apply(Switch sw) + { + ((Analysis) sw).caseAAddressValue(this); + } + + public TAmpersand getAmpersand() + { + return this._ampersand_; + } + + public void setAmpersand(TAmpersand node) + { + if(this._ampersand_ != null) + { + this._ampersand_.parent(null); + } + + if(node != null) + { + if(node.parent() != null) + { + node.parent().removeChild(node); + } + + node.parent(this); + } + + this._ampersand_ = node; + } + + public PRange getRange() + { + return this._range_; + } + + public void setRange(PRange node) + { + if(this._range_ != null) + { + this._range_.parent(null); + } + + if(node != null) + { + if(node.parent() != null) + { + node.parent().removeChild(node); + } + + node.parent(this); + } + + this._range_ = node; + } + + @Override + public String toString() + { + return "" + + toString(this._ampersand_) + + toString(this._range_); + } + + @Override + void removeChild(@SuppressWarnings("unused") Node child) + { + // Remove child + if(this._ampersand_ == child) + { + this._ampersand_ = null; + return; + } + + if(this._range_ == child) + { + this._range_ = null; + return; + } + + throw new RuntimeException("Not a child."); + } + + @Override + void replaceChild(@SuppressWarnings("unused") Node oldChild, @SuppressWarnings("unused") Node newChild) + { + // Replace child + if(this._ampersand_ == oldChild) + { + setAmpersand((TAmpersand) newChild); + return; + } + + if(this._range_ == oldChild) + { + setRange((PRange) newChild); + return; + } + + throw new RuntimeException("Not a child."); + } +}