blob: ec70e30117d977c12ca89b4d44b16271e1287912 [file] [log] [blame]
/*
* Copyright (C) 2007 The Android Open Source Project
*
* 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 com.android.dx.dex.code;
import com.android.dx.rop.code.RegisterSpec;
import com.android.dx.rop.code.RegisterSpecList;
import com.android.dx.rop.code.SourcePosition;
/**
* Pseudo-instruction which is used to introduce a new local variable. That
* is, an instance of this class in an instruction stream indicates that
* starting with the subsequent instruction, the indicated variable
* is bound.
*/
public final class LocalStart extends ZeroSizeInsn {
/**
* {@code non-null;} register spec representing the local variable introduced
* by this instance
*/
private final RegisterSpec local;
/**
* Returns the local variable listing string for a single register spec.
*
* @param spec {@code non-null;} the spec to convert
* @return {@code non-null;} the string form
*/
public static String localString(RegisterSpec spec) {
return spec.regString() + ' ' + spec.getLocalItem().toString() + ": " +
spec.getTypeBearer().toHuman();
}
/**
* Constructs an instance. The output address of this instance is initially
* unknown ({@code -1}).
*
* @param position {@code non-null;} source position
* @param local {@code non-null;} register spec representing the local
* variable introduced by this instance
*/
public LocalStart(SourcePosition position, RegisterSpec local) {
super(position);
if (local == null) {
throw new NullPointerException("local == null");
}
this.local = local;
}
/** {@inheritDoc} */
@Override
public DalvInsn withRegisterOffset(int delta) {
return new LocalStart(getPosition(), local.withOffset(delta));
}
/** {@inheritDoc} */
@Override
public DalvInsn withRegisters(RegisterSpecList registers) {
return new LocalStart(getPosition(), local);
}
/**
* Gets the register spec representing the local variable introduced
* by this instance.
*
* @return {@code non-null;} the register spec
*/
public RegisterSpec getLocal() {
return local;
}
/** {@inheritDoc} */
@Override
protected String argString() {
return local.toString();
}
/** {@inheritDoc} */
@Override
protected String listingString0(boolean noteIndices) {
return "local-start " + localString(local);
}
}