front_processing/extern/TUIO_JAVA/src/com/illposed/osc/utility/OSCByteArrayToJavaConverter.java
author bastiena
Fri, 23 Mar 2012 16:24:36 +0100
changeset 10 925b7ee746e3
parent 9 0f44b7360c8d
child 28 9ccef81f02ab
permissions -rw-r--r--
Front Processing : Changed utf-8 to utf-8 without BOM
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     1
/* $Id: OSCByteArrayToJavaConverter.java,v 1.1.1.1 2006/11/13 14:47:22 modin Exp $
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     2
 * Created on 28.10.2003
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     3
 */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     4
package com.illposed.osc.utility;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     5
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     6
import java.math.BigInteger;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     7
import java.util.Date;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     8
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
     9
import com.illposed.osc.*;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    10
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    11
/**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    12
 * @author cramakrishnan
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    13
 *
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    14
 * Copyright (C) 2003, C. Ramakrishnan / Auracle
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    15
 * All rights reserved.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    16
 * 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    17
 * See license.txt (or license.rtf) for license information.
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    18
 */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    19
public class OSCByteArrayToJavaConverter {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    20
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    21
    byte[] bytes;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    22
    int bytesLength;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    23
    int streamPosition;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    24
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    25
    private byte[] intBytes   = new byte[4];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    26
    private byte[] floatBytes = new byte[4];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    27
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    28
    private    byte[] secondBytes = new byte[8];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    29
    private    byte[] picosecBytes = new byte[8];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    30
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    31
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    32
     * Helper object for converting from a byte array to Java objects
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    33
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    34
    /*public OSCByteArrayToJavaConverter() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    35
        super();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    36
    }*/
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    37
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    38
    public OSCPacket convert(byte[] byteArray, int bytesLength) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    39
        bytes = byteArray;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    40
        this.bytesLength = bytesLength;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    41
        streamPosition = 0;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    42
        if (isBundle())
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    43
            return convertBundle();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    44
        else
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    45
            return convertMessage();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    46
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    47
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    48
    private boolean isBundle() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    49
        // only need the first 7 to check if it is a bundle
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    50
        String bytesAsString = new String(bytes, 0, 7);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    51
        return bytesAsString.startsWith("#bundle");
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    52
    }                               
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    53
                               
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    54
    private OSCBundle convertBundle() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    55
        // skip the "#bundle " stuff
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    56
        streamPosition = 8;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    57
        Date timestamp = readTimeTag();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    58
        OSCBundle bundle = new OSCBundle(timestamp);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    59
        OSCByteArrayToJavaConverter myConverter = new OSCByteArrayToJavaConverter();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    60
        while (streamPosition < bytesLength) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    61
            // recursively read through the stream and convert packets you find
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    62
            int packetLength = ((Integer) readInteger()).intValue();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    63
            byte[] packetBytes = new byte[packetLength];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    64
            //streamPosition++;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    65
            System.arraycopy(bytes,streamPosition,packetBytes,0,packetLength);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    66
            streamPosition+=packetLength;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    67
            //for (int i = 0; i < packetLength; i++)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    68
            //    packetBytes[i] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    69
            OSCPacket packet = myConverter.convert(packetBytes, packetLength);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    70
            bundle.addPacket(packet);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    71
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    72
        return bundle;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    73
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    74
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    75
    private OSCMessage convertMessage() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    76
        OSCMessage message = new OSCMessage();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    77
        message.setAddress(readString());
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    78
        char[] types = readTypes();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    79
        if (null == types) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    80
            // we are done
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    81
            return message;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    82
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    83
        moveToFourByteBoundry();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    84
        for (int i = 0; i < types.length; i++) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    85
            if ('[' == types[i]) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    86
                // we're looking at an array -- read it in
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    87
                message.addArgument(readArray(types, i));
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    88
                // then increment i to the end of the array
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    89
                while (']' != types[i])
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    90
                    i++;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    91
            } else
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    92
                message.addArgument(readArgument(types[i]));
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    93
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    94
        return message;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    95
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    96
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    97
    private String readString() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    98
        int strLen = lengthOfCurrentString();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
    99
        char[] stringChars = new char[strLen];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   100
        //System.arraycopy(bytes,streamPosition,stringChars,0,strLen);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   101
        //streamPosition+=strLen;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   102
        for (int i = 0; i < strLen; i++)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   103
            stringChars[i] = (char) bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   104
        moveToFourByteBoundry();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   105
        return new String(stringChars);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   106
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   107
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   108
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   109
     * @return a char array with the types of the arguments
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   110
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   111
    private char[] readTypes() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   112
        // the next byte should be a ","
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   113
        if (bytes[streamPosition] != 0x2C)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   114
            return null;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   115
        streamPosition++;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   116
        // find out how long the list of types is
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   117
        int typesLen = lengthOfCurrentString();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   118
        if (0 == typesLen) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   119
            return null;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   120
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   121
        // read in the types
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   122
        char[] typesChars = new char[typesLen];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   123
        for (int i = 0; i < typesLen; i++) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   124
            typesChars[i] = (char) bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   125
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   126
        return typesChars;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   127
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   128
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   129
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   130
     * @param c type of argument
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   131
     * @return a Java representation of the argument
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   132
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   133
    private Object readArgument(char c) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   134
        switch (c) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   135
            case 'i' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   136
                return readInteger();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   137
            case 'h' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   138
                return readBigInteger();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   139
            case 'f' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   140
                return readFloat();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   141
            case 'd' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   142
                return readDouble();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   143
            case 's' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   144
                return readString();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   145
            case 'c' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   146
                return readChar();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   147
            case 'T' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   148
                return Boolean.TRUE;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   149
            case 'F' :
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   150
                return Boolean.FALSE;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   151
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   152
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   153
        return null;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   154
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   155
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   156
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   157
     * @return a Character
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   158
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   159
    private Object readChar() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   160
        return new Character((char) bytes[streamPosition++]);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   161
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   162
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   163
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   164
     * @return a Double
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   165
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   166
    private Object readDouble() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   167
        return readFloat();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   168
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   169
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   170
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   171
     * @return a Float
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   172
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   173
    private Object readFloat() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   174
        //byte[] floatBytes = new byte[4];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   175
        floatBytes[0] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   176
        floatBytes[1] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   177
        floatBytes[2] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   178
        floatBytes[3] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   179
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   180
        int floatBits = 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   181
            ((floatBytes[3] & 0xFF) ) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   182
            ((floatBytes[2] & 0xFF) << 8) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   183
            ((floatBytes[1] & 0xFF) << 16) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   184
            ((floatBytes[0] & 0xFF) << 24);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   185
        
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   186
        return new Float(Float.intBitsToFloat(floatBits));
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   187
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   188
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   189
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   190
     * @return a BigInteger
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   191
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   192
    private Object readBigInteger() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   193
        //byte[] intBytes = new byte[4];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   194
        intBytes[0] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   195
        intBytes[1] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   196
        intBytes[2] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   197
        intBytes[3] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   198
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   199
        int intBits = 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   200
            ((intBytes[3] & 0xFF) ) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   201
            ((intBytes[2] & 0xFF) << 8) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   202
            ((intBytes[1] & 0xFF) << 16) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   203
            ((intBytes[0] & 0xFF) << 24);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   204
        
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   205
        return new Integer(intBits);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   206
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   207
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   208
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   209
     * @return an Integer
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   210
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   211
    private Object readInteger() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   212
        //byte[] intBytes = new byte[4];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   213
        intBytes[0] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   214
        intBytes[1] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   215
        intBytes[2] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   216
        intBytes[3] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   217
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   218
        int intBits = 
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   219
            ((intBytes[3] & 0xFF) ) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   220
            ((intBytes[2] & 0xFF) << 8) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   221
            ((intBytes[1] & 0xFF) << 16) +
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   222
            ((intBytes[0] & 0xFF) << 24);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   223
        
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   224
        return new Integer(intBits);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   225
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   226
    
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   227
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   228
     * @return a Date
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   229
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   230
    private Date readTimeTag() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   231
        //byte[] secondBytes = new byte[8];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   232
        //byte[] picosecBytes = new byte[8];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   233
        /*for (int i = 4; i < 8; i++)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   234
            secondBytes[i] = bytes[streamPosition++];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   235
        for (int i = 4; i < 8; i++)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   236
            picosecBytes[i] = bytes[streamPosition++];*/
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   237
        System.arraycopy(bytes,streamPosition,secondBytes,4,4);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   238
        streamPosition+=4;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   239
        System.arraycopy(bytes,streamPosition,picosecBytes,4,4);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   240
        streamPosition+=4;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   241
        
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   242
        BigInteger secsSince1900 = new BigInteger(secondBytes);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   243
        long secsSince1970 =  secsSince1900.longValue() - OSCBundle.SECONDS_FROM_1900_to_1970.longValue();
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   244
        if (secsSince1970 < 0) secsSince1970 = 0; // no point maintaining times in the distant past
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   245
        BigInteger picosecs = new BigInteger(picosecBytes);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   246
        long millisecs = (secsSince1970 * 1000) + (picosecs.longValue() / 1000);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   247
        return new Date(millisecs);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   248
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   249
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   250
    /**
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   251
     * @param types
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   252
     * @param i
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   253
     * @return an Array
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   254
     */
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   255
    private Object[] readArray(char[] types, int i) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   256
        int arrayLen = 0;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   257
        while (types[i + arrayLen] != ']')
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   258
            arrayLen++;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   259
        Object[] array = new Object[arrayLen];
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   260
        for (int j = 0; i < arrayLen; j++) {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   261
            array[j] = readArgument(types[i + j]);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   262
        }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   263
        return array;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   264
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   265
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   266
    private int lengthOfCurrentString() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   267
        int i = 0;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   268
        while (bytes[streamPosition + i] != 0)
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   269
            i++;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   270
        return i;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   271
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   272
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   273
    private void moveToFourByteBoundry() {
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   274
        // If i'm already at a 4 byte boundry, I need to move to the next one
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   275
        int mod = streamPosition % 4;
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   276
        streamPosition += (4 - mod);
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   277
    }
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   278
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   279
}
925b7ee746e3 Front Processing :
bastiena
parents: 9
diff changeset
   280