/*
 * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code 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
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package jdk.nashorn.internal.ir;

import jdk.nashorn.internal.ir.annotations.Immutable;
import jdk.nashorn.internal.ir.visitor.NodeVisitor;

IR representation of an object literal property.
/** * IR representation of an object literal property. */
@Immutable public final class PropertyNode extends Node { private static final long serialVersionUID = 1L;
Property key.
/** Property key. */
private final Expression key;
Property value.
/** Property value. */
private final Expression value;
Property getter.
/** Property getter. */
private final FunctionNode getter;
Property getter.
/** Property getter. */
private final FunctionNode setter;
static property flag
/** static property flag */
private final boolean isStatic;
Computed property flag
/** Computed property flag */
private final boolean computed;
Constructor
Params:
  • token – token
  • finish – finish
  • key – the key of this property
  • value – the value of this property
  • getter – getter function body
  • setter – setter function body
  • isStatic – is this a static property?
  • computed – is this a computed property?
/** * Constructor * * @param token token * @param finish finish * @param key the key of this property * @param value the value of this property * @param getter getter function body * @param setter setter function body * @param isStatic is this a static property? * @param computed is this a computed property? */
public PropertyNode(final long token, final int finish, final Expression key, final Expression value, final FunctionNode getter, final FunctionNode setter, final boolean isStatic, final boolean computed) { super(token, finish); this.key = key; this.value = value; this.getter = getter; this.setter = setter; this.isStatic = isStatic; this.computed = computed; } private PropertyNode(final PropertyNode propertyNode, final Expression key, final Expression value, final FunctionNode getter, final FunctionNode setter, final boolean isStatic, final boolean computed) { super(propertyNode); this.key = key; this.value = value; this.getter = getter; this.setter = setter; this.isStatic = isStatic; this.computed = computed; }
Get the name of the property key, or null if key is a computed name.
Returns:key name or null
/** * Get the name of the property key, or {@code null} if key is a computed name. * @return key name or null */
public String getKeyName() { return !computed && key instanceof PropertyKey ? ((PropertyKey) key).getPropertyName() : null; } @Override public Node accept(final NodeVisitor<? extends LexicalContext> visitor) { if (visitor.enterPropertyNode(this)) { return visitor.leavePropertyNode( setKey((Expression) key.accept(visitor)). setValue(value == null ? null : (Expression)value.accept(visitor)). setGetter(getter == null ? null : (FunctionNode)getter.accept(visitor)). setSetter(setter == null ? null : (FunctionNode)setter.accept(visitor))); } return this; } @Override public void toString(final StringBuilder sb, final boolean printType) { if (value instanceof FunctionNode && ((FunctionNode)value).getIdent() != null) { value.toString(sb); } if (value != null) { ((Node)key).toString(sb, printType); sb.append(": "); value.toString(sb, printType); } if (getter != null) { sb.append(' '); getter.toString(sb, printType); } if (setter != null) { sb.append(' '); setter.toString(sb, printType); } }
Get the getter for this property
Returns:getter or null if none exists
/** * Get the getter for this property * @return getter or null if none exists */
public FunctionNode getGetter() { return getter; }
Set the getter of this property, null if none
Params:
  • getter – getter
Returns:same node or new node if state changed
/** * Set the getter of this property, null if none * @param getter getter * @return same node or new node if state changed */
public PropertyNode setGetter(final FunctionNode getter) { if (this.getter == getter) { return this; } return new PropertyNode(this, key, value, getter, setter, isStatic, computed); }
Return the key for this property node
Returns:the key
/** * Return the key for this property node * @return the key */
public Expression getKey() { return key; } private PropertyNode setKey(final Expression key) { if (this.key == key) { return this; } return new PropertyNode(this, key, value, getter, setter, isStatic, computed); }
Get the setter for this property
Returns:setter or null if none exists
/** * Get the setter for this property * @return setter or null if none exists */
public FunctionNode getSetter() { return setter; }
Set the setter for this property, null if none
Params:
  • setter – setter
Returns:same node or new node if state changed
/** * Set the setter for this property, null if none * @param setter setter * @return same node or new node if state changed */
public PropertyNode setSetter(final FunctionNode setter) { if (this.setter == setter) { return this; } return new PropertyNode(this, key, value, getter, setter, isStatic, computed); }
Get the value of this property
Returns:property value
/** * Get the value of this property * @return property value */
public Expression getValue() { return value; }
Set the value of this property
Params:
  • value – new value
Returns:same node or new node if state changed
/** * Set the value of this property * @param value new value * @return same node or new node if state changed */
public PropertyNode setValue(final Expression value) { if (this.value == value) { return this; } return new PropertyNode(this, key, value, getter, setter, isStatic, computed); }
Returns true if this is a static property.
Returns:true if static flag is set
/** * Returns true if this is a static property. * * @return true if static flag is set */
public boolean isStatic() { return isStatic; }
Returns true if this is a computed property.
Returns:true if the computed flag is set
/** * Returns true if this is a computed property. * * @return true if the computed flag is set */
public boolean isComputed() { return computed; } }