diff options
Diffstat (limited to 'js/dojo/dojox/encoding/compression')
| -rw-r--r-- | js/dojo/dojox/encoding/compression/lzw.js | 96 | ||||
| -rw-r--r-- | js/dojo/dojox/encoding/compression/splay.js | 71 |
2 files changed, 167 insertions, 0 deletions
diff --git a/js/dojo/dojox/encoding/compression/lzw.js b/js/dojo/dojox/encoding/compression/lzw.js new file mode 100644 index 0000000..ee771d4 --- /dev/null +++ b/js/dojo/dojox/encoding/compression/lzw.js @@ -0,0 +1,96 @@ +//>>built +define("dojox/encoding/compression/lzw", [ + "dojo/_base/lang", // dojo.extend + "../bits" +], function(lang, bits) { + + var lzw = lang.getObject("dojox.encoding.compression.lzw", true); + /*===== + lzw = dojox.encoding.compression.lzw; + =====*/ + + var _bits = function(x){ + var w = 1; + for(var v = 2; x >= v; v <<= 1, ++w); + return w; + }; + + lzw.Encoder = function(n){ + this.size = n; + this.init(); + }; + + lang.extend(lzw.Encoder, { + init: function(){ + this.dict = {}; + for(var i = 0; i < this.size; ++i){ + this.dict[String.fromCharCode(i)] = i; + } + this.width = _bits(this.code = this.size); + this.p = ""; + }, + encode: function(value, stream){ + var c = String.fromCharCode(value), p = this.p + c, r = 0; + // if already in the dictionary + if(p in this.dict){ + this.p = p; + return r; + } + stream.putBits(this.dict[this.p], this.width); + // if we need to increase the code length + if((this.code & (this.code + 1)) == 0){ + stream.putBits(this.code++, r = this.width++); + } + // add new string + this.dict[p] = this.code++; + this.p = c; + return r + this.width; + }, + flush: function(stream){ + if(this.p.length == 0){ + return 0; + } + stream.putBits(this.dict[this.p], this.width); + this.p = ""; + return this.width; + } + }); + + lzw.Decoder = function(n){ + this.size = n; + this.init(); + }; + + lang.extend(lzw.Decoder, { + init: function(){ + this.codes = new Array(this.size); + for(var i = 0; i < this.size; ++i){ + this.codes[i] = String.fromCharCode(i); + } + this.width = _bits(this.size); + this.p = -1; + }, + decode: function(stream){ + var c = stream.getBits(this.width), v; + if(c < this.codes.length){ + v = this.codes[c]; + if(this.p >= 0){ + this.codes.push(this.codes[this.p] + v.substr(0, 1)); + } + }else{ + if((c & (c + 1)) == 0){ + this.codes.push(""); + ++this.width; + return ""; + } + var x = this.codes[this.p]; + v = x + x.substr(0, 1); + this.codes.push(v); + } + this.p = c; + return v; + } + }); + + return lzw; +}); diff --git a/js/dojo/dojox/encoding/compression/splay.js b/js/dojo/dojox/encoding/compression/splay.js new file mode 100644 index 0000000..45ebe6d --- /dev/null +++ b/js/dojo/dojox/encoding/compression/splay.js @@ -0,0 +1,71 @@ +//>>built +define("dojox/encoding/compression/splay", [ + "dojo/_base/lang", // dojo.extend + "../bits" +], function(lang, bits) { + var compression = lang.getObject("dojox.encoding.compression", true); + /*===== + compression = dojox.encoding.compression; + =====*/ + + compression.Splay = function(n){ + this.up = new Array(2 * n + 1); + this.left = new Array(n); + this.right = new Array(n); + this.reset(); + }; + + lang.extend(compression.Splay, { + reset: function(){ + for(var i = 1; i < this.up.length; this.up[i] = Math.floor((i - 1) / 2), ++i); + for(var i = 0; i < this.left.length; this.left[i] = 2 * i + 1, this.right[i] = 2 * i + 2, ++i); + }, + splay: function(i){ + var a = i + this.left.length; + do{ + var c = this.up[a]; + if(c){ // root + // rotated pair + var d = this.up[c]; + // swap descendants + var b = this.left[d]; + if(c == b){ + b = this.right[d]; + this.right[d] = a; + } else { + this.left[d] = a; + } + this[a == this.left[c] ? "left" : "right"][c] = b; + this.up[a] = d; + this.up[b] = c; + a = d; + }else{ + a = c; + } + }while(a); // root + }, + encode: function(value, stream){ + var s = [], a = value + this.left.length; + do{ + s.push(this.right[this.up[a]] == a); + a = this.up[a]; + }while(a); // root + this.splay(value); + var l = s.length; + while(s.length){ stream.putBits(s.pop() ? 1 : 0, 1); } + return l; + }, + decode: function(stream){ + var a = 0; // root; + do{ + a = this[stream.getBits(1) ? "right" : "left"][a]; + }while(a < this.left.length); + a -= this.left.length; + this.splay(a); + return a; + } + }); + + + return compression.Splay; +}); |
