AFC - Abacus Formula Compiler for Java

Decompiled Code For INDEX( E$68:E$70, C68, D68 )

The expression

=INDEX( E$68:E$70, C68, D68 )

is compiled to the following class(es):

package org.formulacompiler.gen;
import org.formulacompiler.runtime.Computation;
import org.formulacompiler.runtime.FormulaException;
import org.formulacompiler.runtime.internal.Environment;
import org.formulacompiler.runtime.internal.Runtime_v2;
import org.formulacompiler.tests.reference.base.Inputs;
import org.formulacompiler.tests.reference.base.Outputs;

final class $Root extends Outputs implements Computation
{
    private final Inputs $inputs;
    final Environment $environment;

    $Root(Inputs inputs, Environment environment) {
        $environment = environment;
        $inputs = inputs;
    }

    final double get$0() {
        return $idx$0($lin$3$1((int) Runtime_v2.checkDouble(get$1()),
                               (int) Runtime_v2.checkDouble(get$2())));
    }

    public final double dbl() {
        return get$0();
    }

    final int $lin$3$1(int i, int i_0_) {
        if (i >= 1 &#38;&#38; i <= 3 &#38;&#38; i_0_ >= 1 &#38;&#38; i_0_ <= 1)
            return (i - 1) * 1 + (i_0_ - 1);
        throw new FormulaException
                  ("#VALUE/REF! because index is out of range in INDEX");
    }

    final double $idx$0(int i) {
        switch (i) {
        case 0:
            return 10.0;
        case 1:
            return 11.0;
        case 2:
            return 12.0;
        default:
            throw new FormulaException
                      ("#VALUE/REF! because index is out of range in INDEX");
        }
    }

    final double get$1() {
        return $inputs.dbl(0);
    }

    final double get$2() {
        return $inputs.dbl(1);
    }
}