IppAnnotGroup.java 5.35 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.IppInt;
import com.scene7.is.ipp.messages.IppString;
import com.scene7.is.ipp.messages.Offset;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.io.Writer;

public class IppAnnotGroup {
    private int id_;
    private String name_;
    private int color_;

    public IppAnnotGroup(int id, String name, int color) {
        this.id_ = id;
        this.name_ = name;
        this.color_ = color;
    }

    public String toString() {
        StringBuffer buffer = new StringBuffer();
        buffer.append("[");
        buffer.append("id: ").append(String.valueOf(this.id_)).append(" ");
        buffer.append("name: ").append(String.valueOf(this.name_)).append(" ");
        buffer.append("color: ").append(String.valueOf(this.color_)).append(" ");
        buffer.append("]");
        return buffer.toString();
    }

    public boolean equals(Object o) {
        if (!(o instanceof IppAnnotGroup)) {
            return false;
        }
        IppAnnotGroup e = (IppAnnotGroup)o;
        if (this.id_ != e.id_) {
            return false;
        }
        if (!this.name_.equals(e.name_)) {
            return false;
        }
        if (this.color_ != e.color_) {
            return false;
        }
        return true;
    }

    public static IppAnnotGroup Unstuff(byte[] arr, Offset arrayPos) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppAnnotGroup align");
        int id = IppInt.Unstuff(arr, arrayPos);
        String name = IppString.Unstuff(arr, arrayPos);
        int color = IppInt.Unstuff(arr, arrayPos);
        return new IppAnnotGroup(id, name, color);
    }

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

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

    public static void Stuff(byte[] arr, Offset arrayPos, Offset varPos, IppAnnotGroup val) {
        Ipp.Assert((arrayPos.val & 3) == 0, "IppAnnotGroup align");
        if (val != null) {
            IppInt.Stuff(arr, arrayPos, varPos, val.id());
            IppString.Stuff(arr, arrayPos, varPos, val.name());
            IppInt.Stuff(arr, arrayPos, varPos, val.color());
        } else {
            Ipp.StuffNullBytes(arr, arrayPos, 12);
        }
    }

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

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

    public static void Print(Writer tf, String label, IppAnnotGroup it) throws IOException {
        String ll = label + "IppAnnotGroup: ";
        if (it == null) {
            tf.write(ll + "NULL!!\n");
            return;
        }
        tf.write(ll + "\n");
        IppInt.Print(tf, ll + "id: ", it.id());
        IppString.Print(tf, ll + "name: ", it.name());
        IppInt.Print(tf, ll + "color: ", it.color());
    }

    public static void PrintArray(Writer tf, String label, IppAnnotGroup[] it) throws IOException {
        String ll = label + "IppAnnotGroup 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 + "IppAnnotGroup[" + String.valueOf(i) + "]: ";
            IppAnnotGroup.Print(tf, ll, it[i]);
        }
    }

    public void adjustVarPos(Offset varPos) {
        try {
            varPos.val += this.name_.getBytes("UTF-8").length + 1;
        }
        catch (UnsupportedEncodingException e) {
            throw new AssertionError(e);
        }
    }

    public int id() {
        return this.id_;
    }

    public String name() {
        return this.name_;
    }

    public int color() {
        return this.color_;
    }
}