All Downloads are FREE. Search and download functionalities are using the official Maven repository.

zmq.Msg Maven / Gradle / Ivy

/*
    Copyright (c) 2007-2012 iMatix Corporation
    Copyright (c) 2009-2011 250bpm s.r.o.
    Copyright (c) 2007-2011 Other contributors as noted in the AUTHORS file

    This file is part of 0MQ.

    0MQ is free software; you can redistribute it and/or modify it under
    the terms of the GNU Lesser General Public License as published by
    the Free Software Foundation; either version 3 of the License, or
    (at your option) any later version.

    0MQ 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 Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public License
    along with this program.  If not, see .
 */

package zmq;

import java.nio.ByteBuffer;
import java.nio.ByteOrder;

public class Msg {
    private static final int MAX_VSM_SIZE = 29;

    private static final byte TYPE_MIN = 101;
    private static final byte TYPE_VSM = 101;
    private static final byte TYPE_LMSG = 102;
    private static final byte TYPE_DELIMITER = 103;
    private static final byte TYPE_CMSG = 104;
    private static final byte TYPE_MAX = 104;

    public static final int MORE = 1;
    public static final int COMMAND = 2;
    public static final int IDENTITY = 64;
    public static final int SHARED = 128;

    private int flags;
    private byte type;

    private int size;
    private byte[] data;
    private ByteBuffer buf;

    public Msg() {
        this.type = TYPE_VSM;
        this.flags = 0;
        this.size = 0;
        this.buf = ByteBuffer.wrap(new byte[0]).order(ByteOrder.BIG_ENDIAN);
        this.data = buf.array();
    }

    public Msg(int capacity) {
        if (capacity <= MAX_VSM_SIZE)
            this.type = TYPE_VSM;
        else
            this.type = TYPE_LMSG;
        this.flags = 0;
        this.size = capacity;
        this.buf = ByteBuffer.wrap(new byte[capacity]).order(ByteOrder.BIG_ENDIAN);
        this.data = buf.array();
    }

    public Msg(byte[] src) {
        if (src == null) {
            src = new byte[0];
        }
        if (src.length <= MAX_VSM_SIZE) {
            this.type = TYPE_VSM;
        } else {
            this.type = TYPE_LMSG;
        }
        this.flags = 0;
        this.size = src.length;
        this.data = src;
        this.buf = ByteBuffer.wrap(src).order(ByteOrder.BIG_ENDIAN);
    }

    public Msg(final ByteBuffer src) {
        if (src == null) {
            throw new IllegalArgumentException("ByteBuffer cannot be null");
        }
        if (src.position() > 0) {
            throw new IllegalArgumentException("ByteBuffer position is not zero, did you forget to flip it?");
        }
        this.type = TYPE_LMSG;
        this.flags = 0;
        this.buf = src.duplicate();
        if (buf.hasArray())
            this.data = buf.array();
        else
            this.data = null;
        this.size = buf.remaining();
    }

    public Msg(final Msg m) {
        if (m == null)
            throw new IllegalArgumentException("Msg cannot be null");
        this.type = m.type;
        this.flags = m.flags;
        this.size = m.size;
        this.buf = m.buf != null ? m.buf.duplicate() : null;
        this.data = new byte[this.size];
        System.arraycopy(m.data, 0, this.data, 0, m.size);
    }

    public boolean isIdentity() {
        return (flags & IDENTITY) == IDENTITY;
    }

    public boolean isDelimiter() {
        return type == TYPE_DELIMITER;
    }

    public boolean isVSM() {
        return type == TYPE_VSM;
    }

    public boolean isCMSG() {
        return type == TYPE_CMSG;
    }

    public boolean check() {
        return type >= TYPE_MIN && type <= TYPE_MAX;
    }

    public int flags() {
        return flags;
    }

    public boolean hasMore() {
        return (flags & MORE) > 0;
    }

    public byte type() {
        return type;
    }

    public void setFlags(int flags_) {
        flags |= flags_;
    }

    public void initDelimiter() {
        type = TYPE_DELIMITER;
        flags = 0;
    }

    public byte[] data() {
        if (buf.isDirect()) {
            int length = buf.remaining();
            byte[] bytes = new byte[length];
            buf.duplicate().get(bytes);
            return bytes;
        }
        return data;
    }

    public ByteBuffer buf() {
        return buf.duplicate();
    }

    public int size() {
        return size;
    }

    public void resetFlags(int f) {
        flags = flags & ~f;
    }

    public byte get() {
        return buf.get();
    }

    public byte get(int index) {
        return buf.get(index);
    }

    public Msg put(byte b) {
        buf.put(b);
        return this;
    }

    public Msg put(int index, byte b) {
        buf.put(index, b);
        return this;
    }

    public Msg put(byte[] src) {
        return put(src, 0, src.length);
    }

    public Msg put(byte[] src, int off, int len) {
        if (src == null)
            return this;
        buf.put(src, off, len);
        return this;
    }

    public Msg put(ByteBuffer src) {
        buf.put(src);
        return this;
    }

    public int getBytes(int index, byte[] dst, int off, int len) {
        int count = Math.min(len, size);
        if (buf.isDirect()) {
            ByteBuffer dup = buf.duplicate();
            dup.position(index);
            dup.put(dst, off, count);
            return count;
        }
        System.arraycopy(data, index, dst, off, count);
        return count;
    }

    public int getBytes(int index, ByteBuffer bb, int len) {
        int count = Math.min(bb.remaining(), size - index);
        count = Math.min(count, len);
        bb.put(buf);
        return count;
    }

    @Override
    public String toString() {
        return String.format("#zmq.Msg{type=%s, size=%s, flags=%s}", type, size, flags);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy