blob: 8b2518f0c1db9e2c8a811cbf8c1af48da69d1b91 [file] [log] [blame]
Meki Cherkaouif441d3a2012-04-22 15:17:52 -07001/*
2 * This class contains utilities to help parse the data
3 * author: ucla-cs
Jeff Thompson745026e2012-10-13 12:49:20 -07004 * See COPYING for copyright and distribution information.
Meki Cherkaouif441d3a2012-04-22 15:17:52 -07005 */
6
7var DataUtils = function DataUtils(){
8
9
10};
11
12
13/*
14 * NOTE THIS IS CURRENTLY NOT BEHING USED
15 *
16 */
17
Meki Cherkaoui8f173612012-06-06 01:05:40 -070018DataUtils.keyStr = "ABCDEFGHIJKLMNOP" +
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070019 "QRSTUVWXYZabcdef" +
20 "ghijklmnopqrstuv" +
21 "wxyz0123456789+/" +
22 "=";
23
Meki Cherkaoui8f173612012-06-06 01:05:40 -070024
25/**
26 * Raw String to Base 64
27 */
Meki Cherkaouib21911b2012-05-18 16:54:37 -070028DataUtils.stringtoBase64=function stringtoBase64(input) {
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070029 input = escape(input);
30 var output = "";
31 var chr1, chr2, chr3 = "";
32 var enc1, enc2, enc3, enc4 = "";
33 var i = 0;
34
35 do {
36 chr1 = input.charCodeAt(i++);
37 chr2 = input.charCodeAt(i++);
38 chr3 = input.charCodeAt(i++);
39
40 enc1 = chr1 >> 2;
41 enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
42 enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
43 enc4 = chr3 & 63;
44
45 if (isNaN(chr2)) {
46 enc3 = enc4 = 64;
47 } else if (isNaN(chr3)) {
48 enc4 = 64;
49 }
50
51 output = output +
Meki Cherkaoui8f173612012-06-06 01:05:40 -070052 DataUtils.keyStr.charAt(enc1) +
53 DataUtils.keyStr.charAt(enc2) +
54 DataUtils.keyStr.charAt(enc3) +
55 DataUtils.keyStr.charAt(enc4);
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070056 chr1 = chr2 = chr3 = "";
57 enc1 = enc2 = enc3 = enc4 = "";
58 } while (i < input.length);
59
60 return output;
61 }
62
Meki Cherkaoui8f173612012-06-06 01:05:40 -070063/**
64 * Base 64 to Raw String
65 */
Meki Cherkaouib21911b2012-05-18 16:54:37 -070066DataUtils.base64toString = function base64toString(input) {
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070067 var output = "";
68 var chr1, chr2, chr3 = "";
69 var enc1, enc2, enc3, enc4 = "";
70 var i = 0;
71
72 // remove all characters that are not A-Z, a-z, 0-9, +, /, or =
73 var base64test = /[^A-Za-z0-9\+\/\=]/g;
Jeff Thompson74957972012-10-07 21:14:32 -070074 /* Test for invalid characters. */
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070075 if (base64test.exec(input)) {
76 alert("There were invalid base64 characters in the input text.\n" +
77 "Valid base64 characters are A-Z, a-z, 0-9, '+', '/',and '='\n" +
78 "Expect errors in decoding.");
79 }
Meki Cherkaoui8f173612012-06-06 01:05:40 -070080
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070081 input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
82
83 do {
Meki Cherkaoui8f173612012-06-06 01:05:40 -070084 enc1 = DataUtils.keyStr.indexOf(input.charAt(i++));
85 enc2 = DataUtils.keyStr.indexOf(input.charAt(i++));
86 enc3 = DataUtils.keyStr.indexOf(input.charAt(i++));
87 enc4 = DataUtils.keyStr.indexOf(input.charAt(i++));
Meki Cherkaouif441d3a2012-04-22 15:17:52 -070088
89 chr1 = (enc1 << 2) | (enc2 >> 4);
90 chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
91 chr3 = ((enc3 & 3) << 6) | enc4;
92
93 output = output + String.fromCharCode(chr1);
94
95 if (enc3 != 64) {
96 output = output + String.fromCharCode(chr2);
97 }
98 if (enc4 != 64) {
99 output = output + String.fromCharCode(chr3);
100 }
101
102 chr1 = chr2 = chr3 = "";
103 enc1 = enc2 = enc3 = enc4 = "";
104
105 } while (i < input.length);
106
107 return unescape(output);
108 };
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700109
110//byte []
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700111
112/**
113 * NOT WORKING!!!!!
114 *
115 * Unsiged Long Number to Byte Array
116 */
117
118 /*
119DataUtils.unsignedLongToByteArray= function( value) {
120
121 if(LOG>4)console.log('INPUT IS '+value);
122
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700123 if( 0 == value )
124 return [0];
125
126 if( 0 <= value && value <= 0x00FF ) {
127 //byte []
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700128 var bb = new Array(1);
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700129 bb[0] = (value & 0x00FF);
130 return bb;
131 }
132
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700133 if(LOG>4) console.log('type of value is '+typeof value);
134 if(LOG>4) console.log('value is '+value);
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700135 //byte []
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700136 var out = null;
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700137 //int
138 var offset = -1;
139 for(var i = 7; i >=0; --i) {
140 //byte
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700141 console.log(i);
142 console.log('value is '+value);
143 console.log('(value >> (i * 8)) '+ (value >> (i * 8)) );
144 console.log(' ((value >> (i * 8)) & 0xFF) '+ ((value >> (i * 8)) & 0xFF) );
145
146 var b = ((value >> (i * 8)) & 0xFF) ;
147
148 if(LOG>4) console.log('b is '+b);
149
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700150 if( out == null && b != 0 ) {
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700151 //out = new byte[i+1];
152 out = new Array(i+1);
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700153 offset = i;
154 }
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700155
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700156 if( out != null )
157 out[ offset - i ] = b;
158 }
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700159 if(LOG>4)console.log('OUTPUT IS ');
160 if(LOG>4)console.log(out);
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700161 return out;
162}
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700163*/
164
165/**
166 * NOT WORKING!!!!!
167 *
168 * Unsiged Long Number to Byte Array
169 *//*
170DataUtils.byteArrayToUnsignedLong = function(//final byte []
171 src) {
172 if(LOG>4) console.log('INPUT IS ');
173 if(LOG>4) console.log(src);
174
175 var value = 0;
176 for(var i = 0; i < src.length; i++) {
177 value = value << 8;
178 // Java will assume the byte is signed, so extend it and trim it.
179
180
181 var b = ((src[i]) & 0xFF );
182 value |= b;
183 }
184
185 if(LOG>4) console.log('OUTPUT IS ');
186
187 if(LOG>4) console.log(value);
188
189 return value;
190 }*/
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700191
192
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700193/**
194 * Hex String to Byte Array
195 */
196 //THIS IS NOT WORKING
197/*
198DataUtils.HexStringtoByteArray = function(str) {
Meki Cherkaouiabb973b2012-05-09 14:25:57 -0700199 var byteArray = [];
200 for (var i = 0; i < str.length; i++)
201 if (str.charCodeAt(i) <= 0x7F)
202 byteArray.push(str.charCodeAt(i));
203 else {
204 var h = encodeURIComponent(str.charAt(i)).substr(1).split('%');
205 for (var j = 0; j < h.length; j++)
206 byteArray.push(parseInt(h[j], 16));
207 }
208 return byteArray;
209};
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700210*/
211
212/**
213 * Byte Array to Hex String
214 */
215DataUtils.byteArrayToHexString = function(byteArray) {
Meki Cherkaouiabb973b2012-05-09 14:25:57 -0700216 var str = '';
217 for (var i = 0; i < byteArray.length; i++)
218 str += byteArray[i] <= 0x7F?
219 byteArray[i] === 0x25 ? "%25" : // %
220 String.fromCharCode(byteArray[i]) :
221 "%" + byteArray[i].toString(16).toUpperCase();
222 return decodeURIComponent(str);
223};
Meki Cherkaouif441d3a2012-04-22 15:17:52 -0700224
225
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700226/**
227 * Byte array to Hex String
228 */
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700229//http://ejohn.org/blog/numbers-hex-and-colors/
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700230DataUtils.toHex = function(arguments){
231 if(LOG>4) console.log('ABOUT TO CONVERT '+ arguments);
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700232 //console.log(arguments);
233 var ret = "";
234 for ( var i = 0; i < arguments.length; i++ )
235 ret += (arguments[i] < 16 ? "0" : "") + arguments[i].toString(16);
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700236 return ret; //.toUpperCase();
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700237}
238
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700239/**
Jeff Thompsona566e792012-10-06 21:46:34 -0700240 * Raw string to hex string.
241 */
242DataUtils.stringToHex = function(arguments){
243 var ret = "";
244 for (var i = 0; i < arguments.length; ++i) {
245 var value = arguments.charCodeAt(i);
246 ret += (value < 16 ? "0" : "") + value.toString(16);
247 }
248 return ret;
249}
250
251/**
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700252 * Byte array to raw string
253 */
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700254//DOES NOT SEEM TO WORK
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700255DataUtils.toString = function(arguments){
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700256 //console.log(arguments);
257 var ret = "";
258 for ( var i = 0; i < arguments.length; i++ )
259 ret += String.fromCharCode(arguments[i]);
260 return ret;
261}
262
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700263/**
264 * Hex String to byte array
265 */
266DataUtils.toNumbers=function( str ){
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700267 if(typeof str =='string'){
268 var ret = [];
269 str.replace(/(..)/g, function(str){
270 ret.push( parseInt( str, 16 ) );
271 });
272 return ret;
273 }
274}
275
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700276/**
Jeff Thompson74957972012-10-07 21:14:32 -0700277 * Hex String to raw string.
278 */
279DataUtils.hexToRawString = function(str) {
280 if(typeof str =='string') {
281 var ret = "";
282 str.replace(/(..)/g, function(s) {
283 ret += String.fromCharCode(parseInt(s, 16));
284 });
285 return ret;
286 }
287}
288
289/**
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700290 * Raw String to Byte Array
291 */
292DataUtils.toNumbersFromString = function( str ){
Meki Cherkaouib21911b2012-05-18 16:54:37 -0700293 var bytes = new Array(str.length);
294 for(var i=0;i<str.length;i++)
295 bytes[i] = str.charCodeAt(i);
296 return bytes;
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700297}
298
299DataUtils.encodeUtf8 = function (string) {
300 string = string.replace(/\r\n/g,"\n");
301 var utftext = "";
302
303 for (var n = 0; n < string.length; n++) {
304
305 var c = string.charCodeAt(n);
306
307 if (c < 128) {
308 utftext += String.fromCharCode(c);
309 }
310 else if((c > 127) && (c < 2048)) {
311 utftext += String.fromCharCode((c >> 6) | 192);
312 utftext += String.fromCharCode((c & 63) | 128);
313 }
314 else {
315 utftext += String.fromCharCode((c >> 12) | 224);
316 utftext += String.fromCharCode(((c >> 6) & 63) | 128);
317 utftext += String.fromCharCode((c & 63) | 128);
318 }
319
320 }
321
322 return utftext;
323 };
324
325 // public method for url decoding
326DataUtils.decodeUtf8 = function (utftext) {
327 var string = "";
328 var i = 0;
Jeff Thompsondeda95e2012-10-21 19:17:56 -0700329 var c = 0;
330 var c1 = 0;
331 var c2 = 0;
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700332
333 while ( i < utftext.length ) {
334
335 c = utftext.charCodeAt(i);
336
337 if (c < 128) {
338 string += String.fromCharCode(c);
339 i++;
340 }
341 else if((c > 191) && (c < 224)) {
342 c2 = utftext.charCodeAt(i+1);
343 string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
344 i += 2;
345 }
346 else {
347 c2 = utftext.charCodeAt(i+1);
Jeff Thompsondeda95e2012-10-21 19:17:56 -0700348 var c3 = utftext.charCodeAt(i+2);
Meki Cherkaoui8f173612012-06-06 01:05:40 -0700349 string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
350 i += 3;
351 }
352
353 }
354
355 return string;
356 };
357
358 test = function(){
359 console.log(DataUtils.decodeUtf8("HELLO.~"));
360 return DataUtils.decodeUtf8("HELLO.~");
361 }
362
363//NOT WORKING
364/*
365DataUtils.getUTF8StringFromBytes = function(bytes) {
366
367 bytes = toString(bytes);
368
369 var ix = 0;
370
371 if( bytes.slice(0,3) == "\xEF\xBB\xBF") {
372 ix = 3;
373 }
374
375 var string = "";
376 for( ; ix < bytes.length; ix++ ) {
377 var byte1 = bytes[ix].charCodeAt(0);
378 if( byte1 < 0x80 ) {
379 string += String.fromCharCode(byte1);
380 } else if( byte1 >= 0xC2 && byte1 < 0xE0 ) {
381 var byte2 = bytes[++ix].charCodeAt(0);
382 string += String.fromCharCode(((byte1&0x1F)<<6) + (byte2&0x3F));
383 } else if( byte1 >= 0xE0 && byte1 < 0xF0 ) {
384 var byte2 = bytes[++ix].charCodeAt(0);
385 var byte3 = bytes[++ix].charCodeAt(0);
386 string += String.fromCharCode(((byte1&0xFF)<<12) + ((byte2&0x3F)<<6) + (byte3&0x3F));
387 } else if( byte1 >= 0xF0 && byte1 < 0xF5) {
388 var byte2 = bytes[++ix].charCodeAt(0);
389 var byte3 = bytes[++ix].charCodeAt(0);
390 var byte4 = bytes[++ix].charCodeAt(0);
391 var codepoint = ((byte1&0x07)<<18) + ((byte2&0x3F)<<12)+ ((byte3&0x3F)<<6) + (byte4&0x3F);
392 codepoint -= 0x10000;
393 string += String.fromCharCode(
394 (codepoint>>10) + 0xD800,
395 (codepoint&0x3FF) + 0xDC00
396 );
397 }
398 }
399
400 return string;
401}*/
402
Jeff Thompsonbb976092012-09-29 17:01:38 -0700403/**
404 * Return true if a1 and a2 are the same length with equal elements.
405 */
406DataUtils.arraysEqual = function(a1, a2){
407 if (a1.length != a2.length)
408 return false;
409
410 for (var i = 0; i < a1.length; ++i) {
411 if (a1[i] != a2[i])
412 return false;
413 }
414
415 return true;
Jeff Thompsondeda95e2012-10-21 19:17:56 -0700416};
417
418/*
419 * Convert the big endian byte array to an unsigned int.
420 * Don't check for overflow.
421 */
422DataUtils.bigEndianToUnsignedInt = function(bytes) {
423 var result = 0;
424 for (var i = 0; i < bytes.length; ++i) {
425 result <<= 8;
426 result += bytes[i];
427 }
428 return result;
429};
430
431/*
432 * Convert the int value to a new big endian byte array and return.
433 * If value is 0 or negative, return [].
434 */
435DataUtils.nonNegativeIntToBigEndian = function(value) {
436 var result = [];
437 if (value <= 0)
438 return result;
439
440 while (value != 0) {
441 result.unshift(value & 0xff);
442 value >>= 8;
443 }
444 return result;
445};