IppContour.java 5.95 KB
/*
 * Decompiled with CFR 0_118.
 */
package com.scene7.is.ipp.messages;

import com.scene7.is.ipp.messages.Ipp;
import com.scene7.is.ipp.messages.IppBool;
import com.scene7.is.ipp.messages.IppInt;
import com.scene7.is.ipp.messages.IppPointDouble;
import com.scene7.is.ipp.messages.IppSegmentType;
import com.scene7.is.ipp.messages.Offset;
import java.io.IOException;
import java.io.Writer;

public class IppContour {
    private IppPointDouble[] points_;
    private int[] types_;
    private boolean isClosed_;

    public IppContour(IppPointDouble[] points, int[] types, boolean isClosed) {
        this.points_ = points;
        this.types_ = types;
        this.isClosed_ = isClosed;
    }

    public String toString() {
        StringBuffer buffer = new StringBuffer();
        buffer.append("[");
        buffer.append("points: ").append(String.valueOf(this.points_)).append(" ");
        buffer.append("types: ").append(String.valueOf(this.types_)).append(" ");
        buffer.append("isClosed: ").append(String.valueOf(this.isClosed_)).append(" ");
        buffer.append("]");
        return buffer.toString();
    }

    public boolean equals(Object o) {
        int i;
        if (!(o instanceof IppContour)) {
            return false;
        }
        IppContour e = (IppContour)o;
        if (this.points_.length != e.points_.length) {
            return false;
        }
        for (i = 0; i < this.points_.length; ++i) {
            if (this.points_[i].equals(e.points_[i])) continue;
            return false;
        }
        if (this.types_.length != e.types_.length) {
            return false;
        }
        for (i = 0; i < this.types_.length; ++i) {
            if (this.types_[i] == e.types_[i]) continue;
            return false;
        }
        if (this.isClosed_ != e.isClosed_) {
            return false;
        }
        return true;
    }

    public static IppContour Unstuff(byte[] arr, Offset arrayPos) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppContour align");
        IppPointDouble[] points = IppPointDouble.UnstuffArray(arr, arrayPos);
        int[] types = IppInt.UnstuffArray(arr, arrayPos);
        boolean isClosed = IppBool.Unstuff(arr, arrayPos);
        return new IppContour(points, types, isClosed);
    }

    public static IppContour[] UnstuffArray(byte[] arr, Offset arrayPos) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppContour alignemt");
        int count = IppInt.Unstuff(arr, arrayPos);
        int size = IppInt.Unstuff(arr, arrayPos);
        Ipp.Assert(count == 0 || size >= 28, "IppContour count");
        Offset roff = new Offset(IppInt.Unstuff(arr, arrayPos));
        Offset loff = new Offset(roff.val);
        IppContour[] result = new IppContour[count];
        for (int i = 0; i < count; ++i) {
            loff.val = roff.val;
            result[i] = IppContour.Unstuff(arr, loff);
            roff.val += size;
        }
        return result;
    }

    public static IppContour[] UnstuffFixedArray(byte[] arr, Offset arrayPos, int count) {
        IppContour[] result = new IppContour[count];
        for (int i = 0; i < count; ++i) {
            result[i] = IppContour.Unstuff(arr, arrayPos);
        }
        return result;
    }

    public static void Stuff(byte[] arr, Offset arrayPos, Offset varPos, IppContour val) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppContour align");
        if (val != null) {
            IppPointDouble.StuffArray(arr, arrayPos, varPos, val.points());
            IppInt.StuffArray(arr, arrayPos, varPos, val.types());
            IppBool.Stuff(arr, arrayPos, varPos, val.isClosed());
        } else {
            Ipp.StuffNullBytes(arr, arrayPos, 28);
        }
    }

    public static void StuffArray(byte[] arr, Offset arrayPos, Offset varPos, IppContour[] val) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppContour stuffarray align");
        int len = val != null ? val.length : 0;
        IppInt.Stuff(arr, arrayPos, varPos, len);
        IppInt.Stuff(arr, arrayPos, varPos, 28);
        Ipp.StuffOffset(arr, arrayPos, varPos, len > 0 ? 4 : 1);
        Offset varvarPos = new Offset(varPos.val + 28 * len);
        for (int i = 0; i < len; ++i) {
            IppContour.Stuff(arr, varPos, varvarPos, val[i]);
        }
        varPos.val = varvarPos.val;
    }

    public static void StuffFixedArray(byte[] arr, Offset arrayPos, Offset varPos, int count, IppContour[] val) {
        Ipp.Assert(val.length == count, "IppContour count");
        for (int i = 0; i < count; ++i) {
            IppContour.Stuff(arr, arrayPos, varPos, val[i]);
        }
    }

    public static void Print(Writer tf, String label, IppContour it) throws IOException {
        String ll = label + "IppContour: ";
        if (it == null) {
            tf.write(ll + "NULL!!\n");
            return;
        }
        tf.write(ll + "\n");
        IppPointDouble.PrintArray(tf, ll + "points: ", it.points());
        IppSegmentType.PrintArray(tf, ll + "types: ", it.types());
        IppBool.Print(tf, ll + "isClosed: ", it.isClosed());
    }

    public static void PrintArray(Writer tf, String label, IppContour[] it) throws IOException {
        String ll = label + "IppContour Array, length: ";
        tf.write(ll);
        if (it == null) {
            tf.write("NULL!!!\n");
            return;
        }
        tf.write("" + it.length + "\n");
        for (int i = 0; i < it.length; ++i) {
            ll = label + "IppContour[" + String.valueOf(i) + "]: ";
            IppContour.Print(tf, ll, it[i]);
        }
    }

    public void adjustVarPos(Offset varPos) {
        varPos.val = varPos.val + 7 & -8;
        if (this.points_ != null) {
            varPos.val += this.points_.length * 16;
        }
        varPos.val = varPos.val + 3 & -4;
        if (this.types_ != null) {
            varPos.val += this.types_.length * 4;
        }
    }

    public IppPointDouble[] points() {
        return this.points_;
    }

    public int[] types() {
        return this.types_;
    }

    public boolean isClosed() {
        return this.isClosed_;
    }
}