blob: ac16b0512553882103c212fa2f6f1009630a0be2 [file] [log] [blame]
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Mozilla Communicator client code, released March 31, 1998.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corporation.
* Portions created by Netscape are Copyright (C) 1998-1999
* Netscape Communications Corporation. All Rights Reserved.
*
* Contributor(s):
*
* IBM
* - Binding to permit interfacing between Mozilla and SWT
* - Copyright (C) 2003, 2012 IBM Corp. All Rights Reserved.
*
* ***** END LICENSE BLOCK ***** */
package org.eclipse.swt.internal.mozilla;
/** @jniclass flags=cpp */
public class nsID {
public int m0;
public short m1;
public short m2;
public byte[] m3 = new byte[8];
public static final int sizeof = 16;
static final String zeros = "00000000"; //$NON-NLS-1$
public nsID() {
}
public nsID(String id) {
Parse(id);
}
public boolean Equals(nsID other) {
long /*int*/ ptr = XPCOM.nsID_new ();
XPCOM.memmove (ptr, this, nsID.sizeof);
long /*int*/ otherPtr = XPCOM.nsID_new ();
XPCOM.memmove (otherPtr, other, nsID.sizeof);
boolean result = XPCOM.nsID_Equals (ptr, otherPtr) != 0;
XPCOM.nsID_delete (ptr);
XPCOM.nsID_delete (otherPtr);
return result;
}
public void Parse(String aIDStr) {
if(aIDStr == null) throw new Error ();
int i = 0;
for (; i < 8; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m0 = (m0 << 4) + digit;
}
if (aIDStr.charAt (i++) != '-') throw new Error ();
for (; i < 13; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m1 = (short)((m1 << 4) + digit);
}
if (aIDStr.charAt (i++) != '-') throw new Error ();
for (; i < 18; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m2 = (short)((m2 << 4) + digit);
}
if (aIDStr.charAt (i++) != '-') throw new Error ();
for (; i < 21; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[0] = (byte)((m3[0] << 4) + digit);
}
for (; i < 23; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[1] = (byte)((m3[1] << 4) + digit);
}
if (aIDStr.charAt (i++) != '-') throw new Error ();
for (; i < 26; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[2] = (byte)((m3[2] << 4) + digit);
}
for (; i < 28; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[3] = (byte)((m3[3] << 4) + digit);
}
for (; i < 30; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[4] = (byte)((m3[4] << 4) + digit);
}
for (; i < 32; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[5] = (byte)((m3[5] << 4) + digit);
}
for (; i < 34; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[6] = (byte)((m3[6] << 4) + digit);
}
for (; i < 36; i++) {
int digit = Character.digit (aIDStr.charAt (i), 16);
if (digit == -1) throw new Error ();
m3[7] = (byte)((m3[7] << 4) + digit);
}
}
static String toHex (int v, int length) {
String t = Integer.toHexString (v).toUpperCase ();
int tlen = t.length ();
if (tlen > length) {
t = t.substring (tlen - length);
}
return zeros.substring (0, Math.max (0, length - tlen)) + t;
}
public String toString () {
return '{' + toHex (m0, 8) + '-' +
toHex (m1, 4) + '-' +
toHex (m2, 4) + '-' +
toHex (m3[0], 2) + toHex (m3[1], 2) + '-' +
toHex (m3[2], 2) + toHex (m3[3], 2) + toHex (m3[4], 2) + toHex (m3[5], 2) + toHex (m3[6], 2) + toHex (m3[7], 2) + '}';
}
}