mirror of
https://github.com/danbulant/node-x11
synced 2026-06-14 20:21:40 +00:00
Compare commits
64 commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
eeb9d58310 | ||
|
|
97e3600467 | ||
|
|
bf56aef5a4 | ||
|
|
7728cde55e | ||
|
|
89fd615f8f | ||
|
|
1db2cb54c3 | ||
|
|
4ece7f2b0b | ||
|
|
b50b222a74 | ||
|
|
9414ed788d | ||
|
|
c54dddd746 | ||
|
|
c41ad68e34 | ||
|
|
e17e8b04a1 | ||
|
|
3d6295f0df | ||
|
|
a16c1cb8eb | ||
|
|
8ed75f54e1 | ||
|
|
340432893d | ||
|
|
8500b1fc54 | ||
|
|
43a7e7375a | ||
|
|
f6547d3876 | ||
|
|
15c7149c6a | ||
|
|
4bddee6d5e | ||
|
|
8f322e5f8f | ||
|
|
5c46c4f1d3 | ||
|
|
29b454ee3d | ||
|
|
66bc53624d | ||
|
|
d1868d5ee8 | ||
|
|
2d7ffc2bcd | ||
|
|
4c6617c994 | ||
|
|
174cff9a9c | ||
|
|
2bb273993e | ||
|
|
d5c4103b1f | ||
|
|
d004af97fa | ||
|
|
ce51cefdad | ||
|
|
373b60b975 | ||
|
|
85905efeae | ||
|
|
ef001bd4fb | ||
|
|
6f535cb65d | ||
|
|
ed27aa84ff | ||
|
|
e87b183a8f | ||
|
|
fd09ef9848 | ||
|
|
4e84ae8e40 | ||
|
|
a97f7a179d | ||
|
|
bc9dceebd4 | ||
|
|
18cbbdf6ee | ||
|
|
da262fcb8d | ||
|
|
8049e70deb | ||
|
|
eb674cc41c | ||
|
|
f13247ec6d | ||
|
|
6598e75baf | ||
|
|
3ca322cecc | ||
|
|
97a582be5c | ||
|
|
7341a317bd | ||
|
|
37d0130b38 | ||
|
|
08a6ae573e | ||
|
|
0ad31e0ffe | ||
|
|
777becd99e | ||
|
|
77a94b1324 | ||
|
|
9b6492b34a | ||
|
|
562ed74562 | ||
|
|
9e967b9734 | ||
|
|
6293ab358b | ||
|
|
e3f6438e1a | ||
|
|
9ff1b645d1 | ||
|
|
7e8e972b24 |
40 changed files with 1593 additions and 847 deletions
4
.gitignore
vendored
Normal file
4
.gitignore
vendored
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
*.log
|
||||||
|
yarn.lock
|
||||||
|
package-lock.json
|
||||||
|
node_modules
|
||||||
10
.travis.yml
10
.travis.yml
|
|
@ -7,12 +7,10 @@ before_script:
|
||||||
|
|
||||||
env:
|
env:
|
||||||
- NOLISTEN=tcp DISPLAY=:99.0
|
- NOLISTEN=tcp DISPLAY=:99.0
|
||||||
- NOLISTEN=unix DISPLAY=:99.0
|
# - NOLISTEN=unix DISPLAY=:99.0
|
||||||
- NOLISTEN=unix DISPLAY=127.0.0.2:99.0
|
# - NOLISTEN=unix DISPLAY=127.0.0.2:99.0
|
||||||
|
|
||||||
language: node_js
|
language: node_js
|
||||||
node_js:
|
node_js:
|
||||||
- '0.10'
|
- '12'
|
||||||
- '0.12'
|
- '14'
|
||||||
- '4.2'
|
|
||||||
- '5.0'
|
|
||||||
|
|
|
||||||
64
README.md
64
README.md
|
|
@ -1,21 +1,20 @@
|
||||||
# About
|
# node-x11
|
||||||
[](https://gitter.im/sidorares/node-x11?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
|
||||||
X11 protocol client for node.js
|
|
||||||
|
|
||||||
Implements core X11 protocol, as well as Xrender, Damage, Composite, Big-Requests, Dpms, Screensaver, XFixes, Shape, XTest, XC-Misc, GLX and Apple-WM extensions.
|
X11 protocol client for Node.js: implements the core X11 protocol, as well as Xrender, Damage, Composite, Big-Requests, Dpms, Screensaver, XFixes, Shape, XTest, XC-Misc, GLX, and Apple-WM extensions.
|
||||||
# install
|
|
||||||
|
|
||||||
`npm install x11`
|
|
||||||
|
|
||||||
Windows users:
|
|
||||||
1) install [XMing](http://www.straightrunning.com/XmingNotes/) or [Cygwin/X](http://x.cygwin.com/)
|
|
||||||
2) get node-x11 copy (using [git](http://code.google.com/p/msysgit/downloads/list?can=3) or from [Github](https://github.com/sidorares/node-x11/archives/master ))
|
|
||||||
|
|
||||||
#CI build status:
|
|
||||||
|
|
||||||
|
[](https://gitter.im/sidorares/node-x11?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
[](http://travis-ci.org/sidorares/node-x11)
|
[](http://travis-ci.org/sidorares/node-x11)
|
||||||
|
|
||||||
# example
|
## Install
|
||||||
|
|
||||||
|
npm install x11
|
||||||
|
|
||||||
|
Windows users:
|
||||||
|
|
||||||
|
1. install [XMing](http://www.straightrunning.com/XmingNotes/) or [Cygwin/X](http://x.cygwin.com/)
|
||||||
|
2. get node-x11 copy (using [git](http://code.google.com/p/msysgit/downloads/list?can=3) or from [Github](https://github.com/sidorares/node-x11/archives/master))
|
||||||
|
|
||||||
|
## Example
|
||||||
|
|
||||||
Core requests usage:
|
Core requests usage:
|
||||||
|
|
||||||
|
|
@ -31,18 +30,31 @@ Core requests usage:
|
||||||
var root = display.screen[0].root;
|
var root = display.screen[0].root;
|
||||||
var wid = X.AllocID();
|
var wid = X.AllocID();
|
||||||
X.CreateWindow(
|
X.CreateWindow(
|
||||||
wid, root, // new window id, parent
|
wid,
|
||||||
0, 0, 100, 100, // x, y, w, h
|
root, // new window id, parent
|
||||||
0, 0, 0, 0, // border, depth, class, visual
|
0,
|
||||||
|
0,
|
||||||
|
500,
|
||||||
|
500, // x, y, w, h
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0, // border, depth, class, visual
|
||||||
{ eventMask: Exposure | PointerMotion } // other parameters
|
{ eventMask: Exposure | PointerMotion } // other parameters
|
||||||
);
|
);
|
||||||
X.MapWindow(wid);
|
X.MapWindow(wid);
|
||||||
var gc = X.AllocID();
|
var gc = X.AllocID();
|
||||||
X.CreateGC(gc, wid);
|
X.CreateGC(gc, wid);
|
||||||
|
var white = display.screen[0].white_pixel;
|
||||||
|
var black = display.screen[0].black_pixel;
|
||||||
|
cidBlack = X.AllocID();
|
||||||
|
cidWhite = X.AllocID();
|
||||||
|
X.CreateGC(cidBlack, wid, { foreground: black, background: white });
|
||||||
|
X.CreateGC(cidWhite, wid, { foreground: white, background: black });
|
||||||
X.on('event', function(ev) {
|
X.on('event', function(ev) {
|
||||||
if (ev.type == 12)
|
if (ev.type == 12) {
|
||||||
{
|
X.PolyFillRectangle(wid, cidWhite, [0, 0, 500, 500]);
|
||||||
X.PolyText8(wid, gc, 50, 50, ['Hello, Node.JS!']);
|
X.PolyText8(wid, cidBlack, 50, 50, ['Hello, Node.JS!']);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
X.on('error', function(e) {
|
X.on('error', function(e) {
|
||||||
|
|
@ -54,14 +66,15 @@ Core requests usage:
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
# Screenshots
|
## Screenshots
|
||||||
|
|
||||||

|

|
||||||

|

|
||||||

|

|
||||||

|

|
||||||
|
|
||||||
# In use
|
## In use
|
||||||
|
|
||||||
- [ntk](https://github.com/sidorares/ntk) - higher level toolkit on top of X11
|
- [ntk](https://github.com/sidorares/ntk) - higher level toolkit on top of X11
|
||||||
- [node-remote](https://github.com/AndrewSwerlick/node-remote) - media center controller
|
- [node-remote](https://github.com/AndrewSwerlick/node-remote) - media center controller
|
||||||
- [tiles](https://github.com/dominictarr/tiles) - tiling window manager
|
- [tiles](https://github.com/dominictarr/tiles) - tiling window manager
|
||||||
|
|
@ -74,7 +87,7 @@ Core requests usage:
|
||||||
- [tinywm](https://github.com/Airblader/node-tinywm) The famous [TinyWM](https://github.com/mackstann/tinywm) written in node.js
|
- [tinywm](https://github.com/Airblader/node-tinywm) The famous [TinyWM](https://github.com/mackstann/tinywm) written in node.js
|
||||||
- [basedwm](https://github.com/anko/basedwm) Infinite-desktop panning X window manager in LiveScript
|
- [basedwm](https://github.com/anko/basedwm) Infinite-desktop panning X window manager in LiveScript
|
||||||
|
|
||||||
# X11 resources/documentation:
|
## X11 resources/documentation:
|
||||||
|
|
||||||
- [Xplain](https://github.com/magcius/xplain) - A series of articles to help explain the X Window System http://magcius.github.io/xplain/article/
|
- [Xplain](https://github.com/magcius/xplain) - A series of articles to help explain the X Window System http://magcius.github.io/xplain/article/
|
||||||
- [Official X11 docs](http://www.x.org/releases/X11R7.6/doc/)
|
- [Official X11 docs](http://www.x.org/releases/X11R7.6/doc/)
|
||||||
|
|
@ -83,7 +96,7 @@ Core requests usage:
|
||||||
- [How to write composite manager](http://www.talisman.org/~erlkonig/misc/x11-composite-tutorial/)
|
- [How to write composite manager](http://www.talisman.org/~erlkonig/misc/x11-composite-tutorial/)
|
||||||
- [Extended Window Manager Hints specification](http://standards.freedesktop.org/wm-spec/wm-spec-1.3.html)
|
- [Extended Window Manager Hints specification](http://standards.freedesktop.org/wm-spec/wm-spec-1.3.html)
|
||||||
|
|
||||||
# Other implementations
|
## Other implementations
|
||||||
|
|
||||||
- C: XLib - http://www.sbin.org/doc/Xlib/ http://www.tronche.com/gui/x/xlib/ http://www.x.org/docs/X11/xlib.pdf
|
- C: XLib - http://www.sbin.org/doc/Xlib/ http://www.tronche.com/gui/x/xlib/ http://www.x.org/docs/X11/xlib.pdf
|
||||||
- C: XCB - http://xcb.freedesktop.org/
|
- C: XCB - http://xcb.freedesktop.org/
|
||||||
|
|
@ -96,8 +109,9 @@ Core requests usage:
|
||||||
- Ruby: https://github.com/dj2/x-ruby-bindings
|
- Ruby: https://github.com/dj2/x-ruby-bindings
|
||||||
- Clojure: https://github.com/noodlewiz/xcljb
|
- Clojure: https://github.com/noodlewiz/xcljb
|
||||||
- Guile: https://github.com/mwitmer/guile-xcb
|
- Guile: https://github.com/mwitmer/guile-xcb
|
||||||
|
- Emacs lisp: https://github.com/ch11ng/xelb ( autogenerated from XCB XML )
|
||||||
|
|
||||||
# Server side (protocol + functionality) implementations for js + DOM
|
## Server side (protocol + functionality) implementations for js + DOM
|
||||||
|
|
||||||
would be really great to make completely web based playground page, connecting node-x11 api to DOM based implementation
|
would be really great to make completely web based playground page, connecting node-x11 api to DOM based implementation
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -252,7 +252,7 @@ function genReq(req, last)
|
||||||
if (req.body.length == 0)
|
if (req.body.length == 0)
|
||||||
{
|
{
|
||||||
result.push(' function() {');
|
result.push(' function() {');
|
||||||
result.push(' return new Buffer([' + req.opcode + ', 0, 1, 0]);');
|
result.push(' return Buffer.from([' + req.opcode + ', 0, 1, 0]);');
|
||||||
} else {
|
} else {
|
||||||
result.push(' function (args) {');
|
result.push(' function (args) {');
|
||||||
result.push(' var extraLength = 0;');
|
result.push(' var extraLength = 0;');
|
||||||
|
|
@ -287,10 +287,10 @@ function genReq(req, last)
|
||||||
var reqLen4 = ((reqLen + 3) >> 2);
|
var reqLen4 = ((reqLen + 3) >> 2);
|
||||||
|
|
||||||
if (extraLength)
|
if (extraLength)
|
||||||
result.push(' var data = new Buffer(' + reqLen + ' + extraLength);');
|
result.push(' var data = Buffer.alloc(' + reqLen + ' + extraLength);');
|
||||||
else {
|
else {
|
||||||
result.pop();
|
result.pop();
|
||||||
result.push(' var data = new Buffer(' + reqLen + ');');
|
result.push(' var data = Buffer.alloc(' + reqLen + ');');
|
||||||
}
|
}
|
||||||
result.push(' data[0] = ' + req.opcode + ';');
|
result.push(' data[0] = ' + req.opcode + ';');
|
||||||
if (req.body.length != 0) {
|
if (req.body.length != 0) {
|
||||||
|
|
|
||||||
|
|
@ -571,7 +571,7 @@ module.exports.readJpeg = function(path)
|
||||||
var imageData = {};
|
var imageData = {};
|
||||||
imageData.width = j.width;
|
imageData.width = j.width;
|
||||||
imageData.height = j.height;
|
imageData.height = j.height;
|
||||||
imageData.data = new Buffer(j.width*j.height*4);
|
imageData.data = Buffer.from(j.width*j.height*4);
|
||||||
j.copyToImageData(imageData);
|
j.copyToImageData(imageData);
|
||||||
return imageData;
|
return imageData;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -874,7 +874,7 @@ module.exports.readPng = function(path)
|
||||||
var imageData = {};
|
var imageData = {};
|
||||||
imageData.width = j.width;
|
imageData.width = j.width;
|
||||||
imageData.height = j.height;
|
imageData.height = j.height;
|
||||||
imageData.data = new Buffer(j.width*j.height*4);
|
imageData.data = Buffer.alloc(j.width*j.height*4);
|
||||||
j.render(imageData);
|
j.render(imageData);
|
||||||
return imageData;
|
return imageData;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
344
examples/png/png-decoder.js
Normal file
344
examples/png/png-decoder.js
Normal file
|
|
@ -0,0 +1,344 @@
|
||||||
|
/*
|
||||||
|
* Simple png decoder
|
||||||
|
* https://github.com/b37t1td/png-decoder
|
||||||
|
*/
|
||||||
|
|
||||||
|
var CRCTable = new Int32Array([
|
||||||
|
0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,
|
||||||
|
0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
|
||||||
|
0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,
|
||||||
|
0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
|
||||||
|
0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,
|
||||||
|
0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,
|
||||||
|
0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c,
|
||||||
|
0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
|
||||||
|
0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423,
|
||||||
|
0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
|
||||||
|
0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106,
|
||||||
|
0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
|
||||||
|
0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d,
|
||||||
|
0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,
|
||||||
|
0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,
|
||||||
|
0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
|
||||||
|
0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7,
|
||||||
|
0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,
|
||||||
|
0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa,
|
||||||
|
0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
|
||||||
|
0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81,
|
||||||
|
0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,
|
||||||
|
0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84,
|
||||||
|
0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
|
||||||
|
0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,
|
||||||
|
0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,
|
||||||
|
0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e,
|
||||||
|
0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
|
||||||
|
0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55,
|
||||||
|
0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
|
||||||
|
0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28,
|
||||||
|
0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
|
||||||
|
0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f,
|
||||||
|
0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,
|
||||||
|
0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,
|
||||||
|
0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
|
||||||
|
0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69,
|
||||||
|
0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,
|
||||||
|
0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc,
|
||||||
|
0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
|
||||||
|
0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693,
|
||||||
|
0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,
|
||||||
|
0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
|
||||||
|
]);
|
||||||
|
|
||||||
|
var crc32 = function(buf) {
|
||||||
|
var crc = -1;
|
||||||
|
for (var i = 0; i < buf.length; i++) {
|
||||||
|
crc = CRCTable[(crc ^ buf[i]) & 0xff] ^ (crc >>> 8);
|
||||||
|
}
|
||||||
|
return crc ^ -1;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* BE byteArray implementation
|
||||||
|
* by Svetlana Linuxenko <linuxenko@yahoo.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* eslint no-undef: 0 */
|
||||||
|
var byteArray = Uint8Array;
|
||||||
|
|
||||||
|
var cmp = function(a, b) {
|
||||||
|
if (!b) b = a; a = this;
|
||||||
|
return a.filter(function(c,i) { return c === b[i]; }).length === a.length;
|
||||||
|
};
|
||||||
|
|
||||||
|
var toInt = function(a) {
|
||||||
|
if (!a) a = this.slice(this.off, 4);
|
||||||
|
return (a[0] << 24) | (a[1] << 16) | (a[2] << 8) | a[3];
|
||||||
|
//return a[0] | (a[1] << 8) | (a[2] << 16) | (a[3] << 24);
|
||||||
|
};
|
||||||
|
|
||||||
|
var toBytes = function(int) {
|
||||||
|
return new byteArray([
|
||||||
|
(int >> 24) & 0xff,
|
||||||
|
(int >> 16) & 0xff,
|
||||||
|
(int >> 8) & 0xff,
|
||||||
|
int & 0xff
|
||||||
|
]);
|
||||||
|
};
|
||||||
|
|
||||||
|
var nextInt = function() {
|
||||||
|
return this.toInt(this.slice(this.off, (this.off += 4)));
|
||||||
|
};
|
||||||
|
|
||||||
|
var nextIntBytes = function() {
|
||||||
|
return this.nextBytes(4);
|
||||||
|
};
|
||||||
|
|
||||||
|
var nextBytes = function(size) {
|
||||||
|
return this.slice(this.off, (this.off += size));
|
||||||
|
};
|
||||||
|
|
||||||
|
var nextByte = function() {
|
||||||
|
return this.nextBytes(1)[0];
|
||||||
|
};
|
||||||
|
|
||||||
|
var insertInt = function(int) {
|
||||||
|
this.insertBytes(this.toBytes(int));
|
||||||
|
};
|
||||||
|
|
||||||
|
var insertBytes = function(bytes, length) {
|
||||||
|
length = length || 4;
|
||||||
|
this.set(bytes, this.off, length);
|
||||||
|
this.off += length;
|
||||||
|
};
|
||||||
|
|
||||||
|
var insertByte = function(byte) {
|
||||||
|
this.set([byte], this.off, (this.off += 1));
|
||||||
|
};
|
||||||
|
|
||||||
|
byteArray.prototype.cmp = cmp;
|
||||||
|
byteArray.prototype.toInt = toInt;
|
||||||
|
byteArray.prototype.nextInt = nextInt;
|
||||||
|
byteArray.prototype.nextIntBytes = nextIntBytes;
|
||||||
|
byteArray.prototype.toBytes = toBytes;
|
||||||
|
byteArray.prototype.insertInt = insertInt;
|
||||||
|
byteArray.prototype.insertBytes = insertBytes;
|
||||||
|
byteArray.prototype.nextBytes = nextBytes;
|
||||||
|
byteArray.prototype.nextByte = nextByte;
|
||||||
|
byteArray.prototype.insertByte = insertByte;
|
||||||
|
|
||||||
|
Object.defineProperty(byteArray.prototype , 'off', {
|
||||||
|
enumerable: false,
|
||||||
|
configurable: false,
|
||||||
|
writable: true,
|
||||||
|
value : 0
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
var SIGNATURE = new byteArray([0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a]);
|
||||||
|
var IHDR = new byteArray([0x49, 0x48, 0x44, 0x52]);
|
||||||
|
var IDAT = new byteArray([0x49, 0x44, 0x41, 0x54]);
|
||||||
|
var IEND = new byteArray([0x49, 0x45, 0x4e, 0x44]);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Decoder
|
||||||
|
*/
|
||||||
|
var zlib = require('zlib');
|
||||||
|
|
||||||
|
var inflateFunction = function(data) {
|
||||||
|
return zlib.inflateSync(Buffer.from(data));
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
var Decoder = function() { };
|
||||||
|
|
||||||
|
Decoder.prototype.parse = function(data) {
|
||||||
|
if (!(data instanceof byteArray)) {
|
||||||
|
data = new byteArray(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!SIGNATURE.cmp(data.nextBytes(SIGNATURE.length))) {
|
||||||
|
throw new Error('Not png');
|
||||||
|
}
|
||||||
|
|
||||||
|
while (data.off < data.length) {
|
||||||
|
var len = data.nextInt();
|
||||||
|
var hdr = data.nextBytes(len + 4);
|
||||||
|
|
||||||
|
if (crc32(hdr) !== data.nextInt()) {
|
||||||
|
throw new Error('Crc error');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IHDR.cmp(hdr)) {
|
||||||
|
this._IHDR = this._chunkIHDR(hdr.slice(4, len + 4));
|
||||||
|
|
||||||
|
if (this._IHDR.palette !== 8) {
|
||||||
|
throw new Error('Depth error');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._IHDR.compression !== 0) {
|
||||||
|
throw new Error('Compression error');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._IHDR.filter !== 0) {
|
||||||
|
throw new Error('Filter error');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._IHDR.interlace !== 0) {
|
||||||
|
throw new Error('Interlace error');
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (this._IHDR.colorType){
|
||||||
|
case 0: this.bpp = 1; break;
|
||||||
|
case 2: this.bpp = 3; break;
|
||||||
|
case 3: this.bpp = 1; break;
|
||||||
|
case 4: this.bpp = 2; break;
|
||||||
|
case 6: this.bpp = 4; break;
|
||||||
|
default: throw new Error('ColorType error');
|
||||||
|
}
|
||||||
|
this.chunks = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IDAT.cmp(hdr)) {
|
||||||
|
if (!this._IHDR) {
|
||||||
|
throw new Error('IHDR error');
|
||||||
|
}
|
||||||
|
|
||||||
|
this._chunkIDAT(hdr.slice(4, len + 4));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IEND.cmp(hdr)) {
|
||||||
|
return this._chunkIEND();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Error('Data error');
|
||||||
|
};
|
||||||
|
|
||||||
|
Decoder.prototype._chunkIEND = function() {
|
||||||
|
var tmp = [];
|
||||||
|
for (var i = 0; i < this.chunks.length; i++) {
|
||||||
|
for (var j = 0; j < this.chunks[i].length; j++) {
|
||||||
|
tmp.push(this.chunks[i][j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this.filter(inflateFunction(tmp));
|
||||||
|
};
|
||||||
|
|
||||||
|
Decoder.prototype._chunkIDAT = function(chunk) {
|
||||||
|
this.chunks.push(chunk);
|
||||||
|
};
|
||||||
|
|
||||||
|
Decoder.prototype._chunkIHDR = function(chunk) {
|
||||||
|
return {
|
||||||
|
width : chunk.nextInt(),
|
||||||
|
height : chunk.nextInt(),
|
||||||
|
palette : chunk.nextByte(),
|
||||||
|
colorType : chunk.nextByte(),
|
||||||
|
compression : chunk.nextByte(),
|
||||||
|
filter : chunk.nextByte(),
|
||||||
|
interlace : chunk.nextByte()
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
Decoder.prototype.filter = function(data) {
|
||||||
|
var bpp = this.bpp;
|
||||||
|
var width = this._IHDR.width, height = this._IHDR.height;
|
||||||
|
var pixels = new byteArray((width * height) * bpp);
|
||||||
|
var filter, line, left, leftup, up, pixel;
|
||||||
|
var lineWidth = width * bpp, byte, off;
|
||||||
|
|
||||||
|
for (var y = 0; y < height; y++) {
|
||||||
|
|
||||||
|
filter = data.nextByte();
|
||||||
|
line = data.nextBytes(lineWidth);
|
||||||
|
|
||||||
|
for (var x = 0; x < lineWidth; x++) {
|
||||||
|
|
||||||
|
if (filter !== 0) {
|
||||||
|
off = (y * lineWidth) + x;
|
||||||
|
}
|
||||||
|
|
||||||
|
byte = line.nextByte();
|
||||||
|
|
||||||
|
switch(filter) {
|
||||||
|
case 0: //None
|
||||||
|
pixel = byte;
|
||||||
|
break;
|
||||||
|
case 1: // Sub Raw(x) + Raw(x - bpp)
|
||||||
|
if (x < bpp) {
|
||||||
|
pixel = byte;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pixel = pixels[off - bpp] + byte & 0xff;
|
||||||
|
break;
|
||||||
|
case 2: // Up(x) = Raw(x) + Prior(x)
|
||||||
|
if (y === 0) {
|
||||||
|
pixel = byte;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pixel = pixels[off - lineWidth] + byte & 0xff;
|
||||||
|
break;
|
||||||
|
case 3: // Average(x) = Raw(x) + floor((Raw(x-bpp)+Prior(x))/2)
|
||||||
|
if (y === 0) {
|
||||||
|
if (x < bpp) {
|
||||||
|
pixel = byte;
|
||||||
|
} else {
|
||||||
|
pixel = (byte + (pixels[off - bpp] >> 1)) & 0xff;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (x < bpp) {
|
||||||
|
pixel = (byte + (pixels[off - lineWidth] >> 1)) & 0xff;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pixel = (byte + (pixels[off - bpp] + pixels[off - lineWidth] >> 1)) & 0xff;
|
||||||
|
break;
|
||||||
|
case 4: // Paeth
|
||||||
|
if (y === 0) {
|
||||||
|
if (x < bpp) {
|
||||||
|
pixel = byte;
|
||||||
|
} else {
|
||||||
|
pixel = (byte + (pixels[off - bpp])) & 0xff;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (x < bpp) {
|
||||||
|
pixel = (byte + (pixels[off - lineWidth])) & 0xff;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
up = pixels[off - lineWidth];
|
||||||
|
left = pixels[off - bpp];
|
||||||
|
leftup = pixels[(off - lineWidth) - bpp];
|
||||||
|
|
||||||
|
var p = left + up - leftup,
|
||||||
|
pleft = Math.abs(p - left),
|
||||||
|
pup = Math.abs(p - up),
|
||||||
|
pleftup = Math.abs(p - leftup);
|
||||||
|
|
||||||
|
if (pleft <= pup && pleft <= pleftup){
|
||||||
|
pixel = byte + left & 0xff;
|
||||||
|
break;
|
||||||
|
} else if (pup <= pleftup) {
|
||||||
|
pixel = byte + up & 0xff;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pixel = byte + leftup & 0xff;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new Error('Filter error: ' + filter);
|
||||||
|
}
|
||||||
|
|
||||||
|
pixels.insertByte(pixel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return pixels;
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = Decoder;
|
||||||
BIN
examples/png/screen.png
Normal file
BIN
examples/png/screen.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 5.3 KiB |
80
examples/png/test1.js
Normal file
80
examples/png/test1.js
Normal file
|
|
@ -0,0 +1,80 @@
|
||||||
|
//var logo = require('./node-png').readPng('./node-logo.png');
|
||||||
|
var fs = require('fs');
|
||||||
|
var Decoder = require('./png-decoder');
|
||||||
|
var decoder = new Decoder();
|
||||||
|
|
||||||
|
var logo = {
|
||||||
|
data : Buffer.from(decoder.parse(fs.readFileSync('./screen.png'))),
|
||||||
|
width : decoder._IHDR.width,
|
||||||
|
height : decoder._IHDR.height
|
||||||
|
};
|
||||||
|
|
||||||
|
var x11 = require('../../lib');
|
||||||
|
|
||||||
|
var Exposure = x11.eventMask.Exposure;
|
||||||
|
|
||||||
|
x11.createClient(function(err, display)
|
||||||
|
{
|
||||||
|
var X = display.client;
|
||||||
|
X.require('render', function(err, Render) {
|
||||||
|
var root = display.screen[0].root;
|
||||||
|
main(root, X, Render, display);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
function main(root, X, Render, display) {
|
||||||
|
|
||||||
|
var win, picWin, pic, gc;
|
||||||
|
|
||||||
|
win = X.AllocID();
|
||||||
|
X.CreateWindow(
|
||||||
|
win, root,
|
||||||
|
0, 0, logo.width, logo.height,
|
||||||
|
0, 0, 0, 0,
|
||||||
|
{ eventMask: Exposure }
|
||||||
|
);
|
||||||
|
X.MapWindow(win);
|
||||||
|
|
||||||
|
gc = X.AllocID();
|
||||||
|
X.CreateGC(gc, win);
|
||||||
|
|
||||||
|
var logoPixmap = X.AllocID();
|
||||||
|
X.CreatePixmap(logoPixmap, win, 24, logo.width, logo.height);
|
||||||
|
|
||||||
|
var rscreen = display.screen[0];
|
||||||
|
var screen =
|
||||||
|
rscreen.depths[rscreen.root_depth][
|
||||||
|
Object.keys(rscreen.depths[rscreen.root_depth])[0]];
|
||||||
|
|
||||||
|
var rmask = parseInt(screen.red_mask, 10);
|
||||||
|
var gmask = parseInt(screen.green_mask, 10);
|
||||||
|
var bmask = parseInt(screen.blue_mask, 10);
|
||||||
|
|
||||||
|
for (var y = 0; y < logo.height; y++) {
|
||||||
|
for (var x = 0; x < logo.width; x++) {
|
||||||
|
var pixel = Buffer.from([
|
||||||
|
logo.data[(x + logo.width * y) * 4],
|
||||||
|
logo.data[(x + logo.width * y) * 4 + 1],
|
||||||
|
logo.data[(x + logo.width * y) * 4 + 2], 0]).readInt32LE();
|
||||||
|
|
||||||
|
logo.data[(x + logo.width * y) * 4 ] = (pixel & rmask) >> 16;
|
||||||
|
logo.data[(x + logo.width * y) * 4 + 1] = (pixel & gmask) >> 8;
|
||||||
|
logo.data[(x + logo.width * y) * 4 + 2] = (pixel & bmask) >> 0;
|
||||||
|
logo.data[(x + logo.width * y) * 4 + 3] = 0x00;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
X.PutImage(2, logoPixmap, gc, logo.width, logo.height, 0, 0, 0, 24, logo.data);
|
||||||
|
|
||||||
|
var logoPicture = X.AllocID();
|
||||||
|
Render.CreatePicture(logoPicture, logoPixmap, Render.rgb24);
|
||||||
|
var winPicture = X.AllocID();
|
||||||
|
Render.CreatePicture(winPicture, win, Render.rgb24);
|
||||||
|
|
||||||
|
X.on('event', function(ev) {
|
||||||
|
if (ev.name == 'Expose') {
|
||||||
|
Render.Composite(3, logoPicture, 0, winPicture, 0, 0, 0, 0, 0, 0, logo.width, logo.height);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
8
examples/screenshot.js
Executable file → Normal file
8
examples/screenshot.js
Executable file → Normal file
|
|
@ -17,7 +17,7 @@ x11.createClient(function(err, display) {
|
||||||
|
|
||||||
|
|
||||||
var dispwin = X.AllocID();
|
var dispwin = X.AllocID();
|
||||||
X.CreateWindow(dispwin, root, 0, 0, width, height, 1, 1, 0, { eventMask: x11.eventMask.Exposure });
|
X.CreateWindow(dispwin, root, 0, 0, width, height, 0, 0, 0, 0, { eventMask: x11.eventMask.Exposure });
|
||||||
X.MapWindow(dispwin);
|
X.MapWindow(dispwin);
|
||||||
//X.CopyArea(idScreenshot, dispwin, gc, 0, 0, 0, 0, width, height);
|
//X.CopyArea(idScreenshot, dispwin, gc, 0, 0, 0, 0, width, height);
|
||||||
|
|
||||||
|
|
@ -71,7 +71,11 @@ x11.createClient(function(err, display) {
|
||||||
|
|
||||||
});
|
});
|
||||||
*/
|
*/
|
||||||
X.GetImage(2, root, 0, 0, width, height, 0xffffffff, function(image) {
|
X.GetImage(2, id, 0, 0, width, height, 0xffffffff, function(err, image) {
|
||||||
|
if (err) {
|
||||||
|
console.log(err);
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
console.log(image);
|
console.log(image);
|
||||||
// format, drawable, gc, width, height, dstX, dstY, leftPad, depth, data
|
// format, drawable, gc, width, height, dstX, dstY, leftPad, depth, data
|
||||||
X.PutImage(2, dispwin, gc, width, height, 0, 0, 0, 24, image.data);
|
X.PutImage(2, dispwin, gc, width, height, 0, 0, 0, 24, image.data);
|
||||||
|
|
|
||||||
36
examples/simple/gcinvert.js
Normal file
36
examples/simple/gcinvert.js
Normal file
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
* GCFunction usage example
|
||||||
|
*/
|
||||||
|
var x11 = require('../../lib');
|
||||||
|
|
||||||
|
x11.createClient(function(err, display) {
|
||||||
|
var X = display.client;
|
||||||
|
var root = display.screen[0].root;
|
||||||
|
var white = display.screen[0].white_pixel;
|
||||||
|
var black = display.screen[0].black_pixel;
|
||||||
|
|
||||||
|
var wid = X.AllocID();
|
||||||
|
X.CreateWindow(wid, root, 0, 0, 400, 300, 0, 0, 0, 0, {
|
||||||
|
backgroundPixel: black,
|
||||||
|
eventMask: x11.eventMask.ButtonPress|x11.eventMask.Exposure });
|
||||||
|
var gc = X.AllocID();
|
||||||
|
X.CreateGC(gc, wid, {foreground : white, 'function' : x11.gcFunction.GXinvert});
|
||||||
|
X.MapWindow(wid);
|
||||||
|
|
||||||
|
|
||||||
|
X.on('event', function(ev) {
|
||||||
|
|
||||||
|
if (ev.type === 12) {
|
||||||
|
X.PolyFillRectangle(wid, gc, [0, 0, 400, 300]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ev.type === 4) {
|
||||||
|
var x = ev.x;
|
||||||
|
var y = ev.y;
|
||||||
|
|
||||||
|
X.PolyFillRectangle(wid, gc, [x - 25, y - 25, 50, 50]);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
@ -26,7 +26,7 @@ function padWidth(buf, width) {
|
||||||
return buf;
|
return buf;
|
||||||
else {
|
else {
|
||||||
var stride = (width+3)&~3;
|
var stride = (width+3)&~3;
|
||||||
var res = new Buffer(height*stride);
|
var res = Buffer.alloc(height*stride);
|
||||||
res.fill(0);
|
res.fill(0);
|
||||||
for (var y=0; y < height; ++y) {
|
for (var y=0; y < height; ++y) {
|
||||||
// memcpy(tmpbitmap+y*stride, bitmap->buffer+y*ginfo.width, ginfo.width);
|
// memcpy(tmpbitmap+y*stride, bitmap->buffer+y*ginfo.width, ginfo.width);
|
||||||
|
|
@ -88,7 +88,7 @@ var xclient = x11.createClient({ debug: true }, function(err, display) {
|
||||||
var glyphFromCode = [];
|
var glyphFromCode = [];
|
||||||
glyphs.forEach(function(g) {
|
glyphs.forEach(function(g) {
|
||||||
if (!g.image || (g.image.length == 0)) {
|
if (!g.image || (g.image.length == 0)) {
|
||||||
g.image = new Buffer(64);
|
g.image = Buffer.alloc(64);
|
||||||
g.image.fill(0);
|
g.image.fill(0);
|
||||||
g.width = 8;
|
g.width = 8;
|
||||||
g.height = 8;
|
g.height = 8;
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@ var Pixmap = require('./pixmap').Pixmap;
|
||||||
var Buffer = require('buffer').Buffer;
|
var Buffer = require('buffer').Buffer;
|
||||||
require('../../lib/unpackbuffer').addUnpack(Buffer);
|
require('../../lib/unpackbuffer').addUnpack(Buffer);
|
||||||
|
|
||||||
var reversed = new Buffer(256);
|
var reversed = Buffer.alloc(256);
|
||||||
for (var i=0; i < 256; ++i)
|
for (var i=0; i < 256; ++i)
|
||||||
{
|
{
|
||||||
var res = 0;
|
var res = 0;
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@ var xclient = x11.createClient();
|
||||||
var Exposure = x11.eventMask.Exposure;
|
var Exposure = x11.eventMask.Exposure;
|
||||||
var PointerMotion = x11.eventMask.PointerMotion;
|
var PointerMotion = x11.eventMask.PointerMotion;
|
||||||
|
|
||||||
var bitmap = new Buffer(128*128/8); // 16384 bits, 2048 bytes bitmap
|
var bitmap = Buffer.alloc(128*128/8); // 16384 bits, 2048 bytes bitmap
|
||||||
for (var i=0; i < bitmap.length; ++i)
|
for (var i=0; i < bitmap.length; ++i)
|
||||||
{
|
{
|
||||||
bitmap[i] = i % 256;
|
bitmap[i] = i % 256;
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ var x11 = require('../../lib');
|
||||||
var Exposure = x11.eventMask.Exposure;
|
var Exposure = x11.eventMask.Exposure;
|
||||||
var PointerMotion = x11.eventMask.PointerMotion;
|
var PointerMotion = x11.eventMask.PointerMotion;
|
||||||
|
|
||||||
var bitmap = new Buffer(128*128*4); // 16384 bits, 2048 bytes bitmap
|
var bitmap = Buffer.alloc(128*128*4); // 16384 bits, 2048 bytes bitmap
|
||||||
for (var i=0; i < bitmap.length; ++i)
|
for (var i=0; i < bitmap.length; ++i)
|
||||||
{
|
{
|
||||||
var byteNum = i%4;
|
var byteNum = i%4;
|
||||||
|
|
|
||||||
|
|
@ -25,7 +25,7 @@ var Buffer = require('buffer').Buffer;
|
||||||
|
|
||||||
var startpos = [4, 15];
|
var startpos = [4, 15];
|
||||||
var cupsize = [10, 20];
|
var cupsize = [10, 20];
|
||||||
var cup = new Buffer(cupsize[0]*cupsize[1]);
|
var cup = Buffer.alloc(cupsize[0]*cupsize[1]);
|
||||||
var moveInterval;
|
var moveInterval;
|
||||||
|
|
||||||
function clearCup()
|
function clearCup()
|
||||||
|
|
|
||||||
12
examples/vncviewer/d3des.js
vendored
12
examples/vncviewer/d3des.js
vendored
|
|
@ -56,8 +56,8 @@ var pc2 = [
|
||||||
function deskey(key, edf)
|
function deskey(key, edf)
|
||||||
{
|
{
|
||||||
var i, j, l, m, n;
|
var i, j, l, m, n;
|
||||||
var pc1m = new Buffer(56);
|
var pc1m = Buffer.alloc(56);
|
||||||
var pcr = new Buffer(56);
|
var pcr = Buffer.alloc(56);
|
||||||
var kn = new Array(32);
|
var kn = new Array(32);
|
||||||
|
|
||||||
for ( j = 0; j < 56; j++ ) {
|
for ( j = 0; j < 56; j++ ) {
|
||||||
|
|
@ -388,17 +388,17 @@ function desfunc(block, keys)
|
||||||
|
|
||||||
module.exports.response = function(challenge, password)
|
module.exports.response = function(challenge, password)
|
||||||
{
|
{
|
||||||
var key = new Buffer(8);
|
var key = Buffer.alloc(8);
|
||||||
key.fill(0);
|
key.fill(0);
|
||||||
key.write(password.substring(0,8));
|
key.write(password.substring(0,8));
|
||||||
var in1 = challenge.slice(0,8);
|
var in1 = challenge.slice(0,8);
|
||||||
var in2 = challenge.slice(8,16);
|
var in2 = challenge.slice(8,16);
|
||||||
var res1 = new Buffer(8);
|
var res1 = Buffer.alloc(8);
|
||||||
var res2 = new Buffer(8);
|
var res2 = Buffer.alloc(8);
|
||||||
deskey(key, EN0);
|
deskey(key, EN0);
|
||||||
des(in1, res1);
|
des(in1, res1);
|
||||||
des(in2, res2);
|
des(in2, res2);
|
||||||
var resp = new Buffer(16);
|
var resp = Buffer.alloc(16);
|
||||||
res1.copy(resp);
|
res1.copy(resp);
|
||||||
res2.copy(resp, 8);
|
res2.copy(resp, 8);
|
||||||
return resp;
|
return resp;
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,7 @@
|
||||||
// It should create a pleasant looking hex dumb by default:
|
// It should create a pleasant looking hex dumb by default:
|
||||||
//
|
//
|
||||||
// var hexy = require('hexy.js'),
|
// var hexy = require('hexy.js'),
|
||||||
// b = new Buffer("\000\001\003\005\037\012\011bcdefghijklmnopqrstuvwxyz0123456789")
|
// b = Buffer.from("\000\001\003\005\037\012\011bcdefghijklmnopqrstuvwxyz0123456789")
|
||||||
//
|
//
|
||||||
// console.log(hexy.hexy(b))
|
// console.log(hexy.hexy(b))
|
||||||
//
|
//
|
||||||
|
|
|
||||||
|
|
@ -400,7 +400,7 @@ RfbClient.prototype.readHextileTile = function(rect, cb)
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tile.buffer = new Buffer(tilebuflen);
|
tile.buffer = Buffer.alloc(tilebuflen);
|
||||||
|
|
||||||
function solidBackground() {
|
function solidBackground() {
|
||||||
clog('solidBackground');
|
clog('solidBackground');
|
||||||
|
|
@ -667,8 +667,8 @@ function createConnection(params)
|
||||||
var wstream = fs.createWriteStream(params.rfbFileOut);
|
var wstream = fs.createWriteStream(params.rfbFileOut);
|
||||||
wstream.write('FBS 001.001\n');
|
wstream.write('FBS 001.001\n');
|
||||||
stream.on('data', function(data) {
|
stream.on('data', function(data) {
|
||||||
var sizeBuf = new Buffer(4);
|
var sizeBuf = Buffer.alloc(4);
|
||||||
var timeBuf = new Buffer(4);
|
var timeBuf = Buffer.alloc(4);
|
||||||
var size = data.length;
|
var size = data.length;
|
||||||
sizeBuf.writeInt32BE(size, 0);
|
sizeBuf.writeInt32BE(size, 0);
|
||||||
wstream.write(sizeBuf);
|
wstream.write(sizeBuf);
|
||||||
|
|
@ -676,7 +676,7 @@ function createConnection(params)
|
||||||
timeBuf.writeInt32BE(+new Date() - start, 0);
|
timeBuf.writeInt32BE(+new Date() - start, 0);
|
||||||
wstream.write(timeBuf);
|
wstream.write(timeBuf);
|
||||||
var padding = 3 - ((size - 1) & 0x03);
|
var padding = 3 - ((size - 1) & 0x03);
|
||||||
var pbuf = new Buffer(padding);
|
var pbuf = Buffer.alloc(padding);
|
||||||
wstream.write(pbuf);
|
wstream.write(pbuf);
|
||||||
}).on('end', function() {
|
}).on('end', function() {
|
||||||
wstream.end();
|
wstream.end();
|
||||||
|
|
|
||||||
|
|
@ -62,7 +62,7 @@ RfbServer.prototype.processSecurity = function()
|
||||||
break;
|
break;
|
||||||
case rfb.security.VNC:
|
case rfb.security.VNC:
|
||||||
// generate random 16 byte challenge
|
// generate random 16 byte challenge
|
||||||
serv.challenge = new Buffer(16);
|
serv.challenge = Buffer.alloc(16);
|
||||||
serv.challenge.write('1234567890abcdef');
|
serv.challenge.write('1234567890abcdef');
|
||||||
console.log(['sending challenge', serv.challenge]);
|
console.log(['sending challenge', serv.challenge]);
|
||||||
serv.pack_stream.pack('a', [serv.challenge]).flush();
|
serv.pack_stream.pack('a', [serv.challenge]).flush();
|
||||||
|
|
|
||||||
|
|
@ -34,7 +34,7 @@ function ReadFixedRequest(length, callback)
|
||||||
this.length = length;
|
this.length = length;
|
||||||
this.callback = callback;
|
this.callback = callback;
|
||||||
//clog(length);
|
//clog(length);
|
||||||
this.data = new Buffer(length);
|
this.data = Buffer.alloc(length);
|
||||||
this.received_bytes = 0;
|
this.received_bytes = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -328,7 +328,7 @@ UnpackStream.prototype.pack = function(format, args)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var buf = new Buffer(packetlength);
|
var buf = Buffer.alloc(packetlength);
|
||||||
var offset = 0;
|
var offset = 0;
|
||||||
var arg = 0;
|
var arg = 0;
|
||||||
for (var i = 0; i < format.length; ++i)
|
for (var i = 0; i < format.length; ++i)
|
||||||
|
|
|
||||||
|
|
@ -95,7 +95,7 @@ PixmapFromFile.prototype.mapColors = function(content,size){
|
||||||
}
|
}
|
||||||
|
|
||||||
PixmapFromFile.prototype.toBuffer = function (colors,content,size) {
|
PixmapFromFile.prototype.toBuffer = function (colors,content,size) {
|
||||||
var buf = new Buffer(size.width*size.height*4);
|
var buf = Buffer.alloc(size.width*size.height*4);
|
||||||
var offset = 0, byte,color;
|
var offset = 0, byte,color;
|
||||||
var copy;
|
var copy;
|
||||||
if( !this.options.format || this.options.format.toUpperCase() === "BGRA"){
|
if( !this.options.format || this.options.format.toUpperCase() === "BGRA"){
|
||||||
|
|
|
||||||
|
|
@ -50,7 +50,7 @@ function parseXauth( buf )
|
||||||
return auth;
|
return auth;
|
||||||
}
|
}
|
||||||
|
|
||||||
var homedir = require('os-homedir');
|
var homedir = require('os').homedir;
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
|
|
||||||
function readXauthority(cb) {
|
function readXauthority(cb) {
|
||||||
|
|
|
||||||
|
|
@ -231,9 +231,10 @@ function packValueMask(reqname, values)
|
||||||
});
|
});
|
||||||
|
|
||||||
var args = [];
|
var args = [];
|
||||||
for (m in masksList)
|
for (var i=0,length=masksList.length;i<length;i++)
|
||||||
{
|
{
|
||||||
var valueName = reqValueMaskName[masksList[m]];
|
var value = masksList[i];
|
||||||
|
var valueName = reqValueMaskName[value];
|
||||||
format += reqValueMask[valueName].format
|
format += reqValueMask[valueName].format
|
||||||
args.push( values[valueName] );
|
args.push( values[valueName] );
|
||||||
}
|
}
|
||||||
|
|
@ -464,7 +465,7 @@ var templates = {
|
||||||
function(mode, wid, name, type, units, data)
|
function(mode, wid, name, type, units, data)
|
||||||
{
|
{
|
||||||
var padded4 = (data.length + 3) >> 2;
|
var padded4 = (data.length + 3) >> 2;
|
||||||
var pad = new Buffer( (padded4<<2) - data.length);
|
var pad = Buffer.alloc( (padded4<<2) - data.length);
|
||||||
var format = 'CCSLLLCxxxLaa';
|
var format = 'CCSLLLCxxxLaa';
|
||||||
var requestLength = 6 + padded4;
|
var requestLength = 6 + padded4;
|
||||||
var dataLenInFormatUnits = data.length / (units >> 3);
|
var dataLenInFormatUnits = data.length / (units >> 3);
|
||||||
|
|
@ -732,12 +733,6 @@ var templates = {
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
FreePixmap: [
|
|
||||||
function (pixmap) {
|
|
||||||
return [ 'CxSL', [54, 2, pixmap] ];
|
|
||||||
}
|
|
||||||
],
|
|
||||||
|
|
||||||
CreateCursor: [
|
CreateCursor: [
|
||||||
function(cid, source, mask, foreRGB, backRGB, x, y) {
|
function(cid, source, mask, foreRGB, backRGB, x, y) {
|
||||||
foreR = foreRGB.R
|
foreR = foreRGB.R
|
||||||
|
|
@ -771,13 +766,9 @@ var templates = {
|
||||||
var vals = packValueMask('CreateGC', values);
|
var vals = packValueMask('CreateGC', values);
|
||||||
var packetLength = 3 + (values ? vals[2].length : 0);
|
var packetLength = 3 + (values ? vals[2].length : 0);
|
||||||
var args = [56, packetLength, cid];
|
var args = [56, packetLength, cid];
|
||||||
args.push(vals[0]); // values bitmask
|
format += vals[0]
|
||||||
var valArr = vals[1];
|
args.push(vals[1]); // values bitmask
|
||||||
for (var v in valArr)
|
args = args.concat(vals[2])
|
||||||
{
|
|
||||||
format += 'L'; // TODO: we know format string length in advance and += inefficient for string
|
|
||||||
args.push(valArr[v]);
|
|
||||||
}
|
|
||||||
return [format, args];
|
return [format, args];
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
@ -860,7 +851,7 @@ var templates = {
|
||||||
var padded = xutil.padded_length(data.length);
|
var padded = xutil.padded_length(data.length);
|
||||||
var reqLen = 6 + padded/4; // (length + 3) >> 2 ???
|
var reqLen = 6 + padded/4; // (length + 3) >> 2 ???
|
||||||
var padLength = padded - data.length;
|
var padLength = padded - data.length;
|
||||||
var pad = new Buffer(padLength); // TODO: new pack format 'X' - skip amount of bytes supplied in numerical argument
|
var pad = Buffer.alloc(padLength); // TODO: new pack format 'X' - skip amount of bytes supplied in numerical argument
|
||||||
|
|
||||||
// TODO: move code to calculate reqLength and use BigReq if needed outside of corereq.js
|
// TODO: move code to calculate reqLength and use BigReq if needed outside of corereq.js
|
||||||
// NOTE: big req is used here (first 'L' in format, 0 and +1 in params), won't work if not enabled
|
// NOTE: big req is used here (first 'L' in format, 0 and +1 in params), won't work if not enabled
|
||||||
|
|
@ -1030,6 +1021,12 @@ var templates = {
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
||||||
|
Bell: [
|
||||||
|
function(percent) {
|
||||||
|
return ["CxCs",[108,1]];
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
ForceScreenSaver: [
|
ForceScreenSaver: [
|
||||||
function(activate) {
|
function(activate) {
|
||||||
return [ 'CCS', [115, activate?1:0, 1] ];
|
return [ 'CCS', [115, activate?1:0, 1] ];
|
||||||
|
|
|
||||||
|
|
@ -258,7 +258,7 @@ exports.requireExt = function(display, callback)
|
||||||
ext.BindTexImage = function(ctx, drawable, buffer, attribs) {
|
ext.BindTexImage = function(ctx, drawable, buffer, attribs) {
|
||||||
if (!attribs)
|
if (!attribs)
|
||||||
attribs = [];
|
attribs = [];
|
||||||
var data = new Buffer(12 + attribs.length*4);
|
var data = Buffer.alloc(12 + attribs.length*4);
|
||||||
data.writeUInt32LE(drawable, 0);
|
data.writeUInt32LE(drawable, 0);
|
||||||
data.writeUInt32LE(buffer, 4);
|
data.writeUInt32LE(buffer, 4);
|
||||||
data.writeUInt32LE(attribs.length, 8);
|
data.writeUInt32LE(attribs.length, 8);
|
||||||
|
|
@ -268,7 +268,7 @@ exports.requireExt = function(display, callback)
|
||||||
}
|
}
|
||||||
|
|
||||||
ext.ReleaseTexImage = function(ctx, drawable, buffer) {
|
ext.ReleaseTexImage = function(ctx, drawable, buffer) {
|
||||||
var data = new Buffer(8);
|
var data = Buffer.alloc(8);
|
||||||
data.writeUint32LE(drawable, 0);
|
data.writeUint32LE(drawable, 0);
|
||||||
data.writeUint32LE(buffer, 4);
|
data.writeUint32LE(buffer, 4);
|
||||||
ext.VendorPrivate(ctx, 1331, data);
|
ext.VendorPrivate(ctx, 1331, data);
|
||||||
|
|
@ -287,7 +287,7 @@ exports.requireExt = function(display, callback)
|
||||||
X.pack_stream.pack('CCSLSSL', [ext.majorOpcode, 2, length, ctx, requestNum, requestTotal, data.length]);
|
X.pack_stream.pack('CCSLSSL', [ext.majorOpcode, 2, length, ctx, requestNum, requestTotal, data.length]);
|
||||||
|
|
||||||
X.pack_stream.write_queue.push(data);
|
X.pack_stream.write_queue.push(data);
|
||||||
var pad = new Buffer(padLength);
|
var pad = Buffer.alloc(padLength);
|
||||||
pad.fill(0);
|
pad.fill(0);
|
||||||
X.pack_stream.write_queue.push(pad);
|
X.pack_stream.write_queue.push(pad);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
|
|
|
||||||
|
|
@ -16,7 +16,7 @@ module.exports = function(GLX, ctx) {
|
||||||
throw Error('Buffer too big. Make sure you are using RenderLarge for large commands');
|
throw Error('Buffer too big. Make sure you are using RenderLarge for large commands');
|
||||||
|
|
||||||
currentLength += len;
|
currentLength += len;
|
||||||
var res = Buffer(len);
|
var res = Buffer.alloc(len);
|
||||||
res.writeUInt16LE(len, 0);
|
res.writeUInt16LE(len, 0);
|
||||||
res.writeUInt16LE(opcode, 2);
|
res.writeUInt16LE(opcode, 2);
|
||||||
return res;
|
return res;
|
||||||
|
|
@ -266,7 +266,7 @@ module.exports = function(GLX, ctx) {
|
||||||
typeSize[constants.BYTE] = 1;
|
typeSize[constants.BYTE] = 1;
|
||||||
typeSize[constants.UNSIGNED_BYTE] = 1;
|
typeSize[constants.UNSIGNED_BYTE] = 1;
|
||||||
|
|
||||||
var res = new Buffer(60 + data.length*typeSize[type]);
|
var res = Buffer.alloc(60 + data.length*typeSize[type]);
|
||||||
res.writeUInt32LE(res.length, 0);
|
res.writeUInt32LE(res.length, 0);
|
||||||
res.writeUInt32LE(110, 4);
|
res.writeUInt32LE(110, 4);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,19 +5,14 @@ var xutil = require('../xutil');
|
||||||
// http://cgit.freedesktop.org/xcb/proto/tree/src/render.xml?id=HEAD
|
// http://cgit.freedesktop.org/xcb/proto/tree/src/render.xml?id=HEAD
|
||||||
// and http://www.x.org/releases/X11R7.6/doc/renderproto/renderproto.txt
|
// and http://www.x.org/releases/X11R7.6/doc/renderproto/renderproto.txt
|
||||||
// TODO: move to templates
|
// TODO: move to templates
|
||||||
exports.requireExt = function(display, callback)
|
exports.requireExt = function(display, callback) {
|
||||||
{
|
|
||||||
|
|
||||||
var X = display.client;
|
var X = display.client;
|
||||||
X.QueryExtension('RENDER', function(err, ext) {
|
X.QueryExtension('RENDER', function(err, ext) {
|
||||||
|
if (!ext.present) {
|
||||||
if (!ext.present)
|
|
||||||
{
|
|
||||||
return callback(new Error('extension not available'));
|
return callback(new Error('extension not available'));
|
||||||
}
|
}
|
||||||
|
|
||||||
ext.QueryVersion = function(clientMaj, clientMin, callback)
|
ext.QueryVersion = function(clientMaj, clientMin, callback) {
|
||||||
{
|
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 0, 3, clientMaj, clientMin]);
|
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 0, 3, clientMaj, clientMin]);
|
||||||
X.replies[X.seq_num] = [
|
X.replies[X.seq_num] = [
|
||||||
|
|
@ -28,10 +23,9 @@ exports.requireExt = function(display, callback)
|
||||||
callback
|
callback
|
||||||
];
|
];
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.QueryPictFormat = function(callback)
|
ext.QueryPictFormat = function(callback) {
|
||||||
{
|
|
||||||
X.pack_stream.pack('CCS', [ext.majorOpcode, 1, 1]);
|
X.pack_stream.pack('CCS', [ext.majorOpcode, 1, 1]);
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
X.replies[X.seq_num] = [
|
X.replies[X.seq_num] = [
|
||||||
|
|
@ -46,8 +40,7 @@ exports.requireExt = function(display, callback)
|
||||||
// formats list:
|
// formats list:
|
||||||
var offset = 24;
|
var offset = 24;
|
||||||
res.formats = [];
|
res.formats = [];
|
||||||
for (var i=0; i < num_formats; ++i)
|
for (var i = 0; i < num_formats; ++i) {
|
||||||
{
|
|
||||||
var format = {};
|
var format = {};
|
||||||
var f = buf.unpack('LCCxxSSSSSSSSL', offset);
|
var f = buf.unpack('LCCxxSSSSSSSSL', offset);
|
||||||
res.formats.push(f);
|
res.formats.push(f);
|
||||||
|
|
@ -58,10 +51,9 @@ exports.requireExt = function(display, callback)
|
||||||
callback
|
callback
|
||||||
];
|
];
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.QueryFilters = function(callback)
|
ext.QueryFilters = function(callback) {
|
||||||
{
|
|
||||||
X.pack_stream.pack('CCSL', [ext.majorOpcode, 29, 2, display.screen[0].root]);
|
X.pack_stream.pack('CCSL', [ext.majorOpcode, 29, 2, display.screen[0].root]);
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
X.replies[X.seq_num] = [
|
X.replies[X.seq_num] = [
|
||||||
|
|
@ -71,14 +63,12 @@ exports.requireExt = function(display, callback)
|
||||||
var num_filters = h[1];
|
var num_filters = h[1];
|
||||||
var aliases = [];
|
var aliases = [];
|
||||||
var offset = 24; // LL + 16 bytes pad
|
var offset = 24; // LL + 16 bytes pad
|
||||||
for (var i=0; i < num_aliases; ++i)
|
for (var i = 0; i < num_aliases; ++i) {
|
||||||
{
|
|
||||||
aliases.push(buf.unpack('S', offset)[0]);
|
aliases.push(buf.unpack('S', offset)[0]);
|
||||||
offset += 2;
|
offset += 2;
|
||||||
}
|
}
|
||||||
var filters = [];
|
var filters = [];
|
||||||
for (var i=0; i < num_filters; ++i)
|
for (var i = 0; i < num_filters; ++i) {
|
||||||
{
|
|
||||||
var len = buf.unpack('C', offset)[0];
|
var len = buf.unpack('C', offset)[0];
|
||||||
//if (!len) break;
|
//if (!len) break;
|
||||||
offset++;
|
offset++;
|
||||||
|
|
@ -90,7 +80,7 @@ exports.requireExt = function(display, callback)
|
||||||
callback
|
callback
|
||||||
];
|
];
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
}
|
};
|
||||||
|
|
||||||
var valueList = [
|
var valueList = [
|
||||||
['repeat', 'Cxxx'],
|
['repeat', 'Cxxx'],
|
||||||
|
|
@ -116,22 +106,19 @@ exports.requireExt = function(display, callback)
|
||||||
x: 1
|
x: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.CreatePicture = function(pid, drawable, pictformat, values)
|
ext.CreatePicture = function(pid, drawable, pictformat, values) {
|
||||||
{
|
|
||||||
var mask = 0;
|
var mask = 0;
|
||||||
var reqLen = 5; // + (values + pad)/4
|
var reqLen = 5; // + (values + pad)/4
|
||||||
var format = 'CCSLLLL';
|
var format = 'CCSLLLL';
|
||||||
var params = [ext.majorOpcode, 4, reqLen, pid, drawable, pictformat, mask];
|
var params = [ext.majorOpcode, 4, reqLen, pid, drawable, pictformat, mask];
|
||||||
|
|
||||||
if (values)
|
if (values) {
|
||||||
{
|
|
||||||
var valuesLength = 0;
|
var valuesLength = 0;
|
||||||
for (var i=0; i < valueList.length; ++i)
|
for (var i = 0; i < valueList.length; ++i) {
|
||||||
{
|
|
||||||
var name = valueList[i][0];
|
var name = valueList[i][0];
|
||||||
var val = values[name];
|
var val = values[name];
|
||||||
if (val) {
|
if (val) {
|
||||||
mask |= (1 << i);
|
mask |= 1 << i;
|
||||||
params.push(val);
|
params.push(val);
|
||||||
var valueFormat = valueList[i][1];
|
var valueFormat = valueList[i][1];
|
||||||
format += valueFormat;
|
format += valueFormat;
|
||||||
|
|
@ -140,8 +127,7 @@ exports.requireExt = function(display, callback)
|
||||||
}
|
}
|
||||||
var pad4 = (valuesLength + 3) >> 2;
|
var pad4 = (valuesLength + 3) >> 2;
|
||||||
var toPad = (pad4 << 2) - valuesLength;
|
var toPad = (pad4 << 2) - valuesLength;
|
||||||
for (var i=0; i < toPad; ++i)
|
for (var i = 0; i < toPad; ++i) format += 'x';
|
||||||
format += 'x';
|
|
||||||
reqLen += pad4;
|
reqLen += pad4;
|
||||||
params[2] = reqLen;
|
params[2] = reqLen;
|
||||||
params[6] = mask;
|
params[6] = mask;
|
||||||
|
|
@ -149,7 +135,7 @@ exports.requireExt = function(display, callback)
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.FreePicture = function(pid) {
|
ext.FreePicture = function(pid) {
|
||||||
X.pack_stream.pack('CCSL', [ext.majorOpcode, 7, 2, pid]);
|
X.pack_stream.pack('CCSL', [ext.majorOpcode, 7, 2, pid]);
|
||||||
|
|
@ -157,13 +143,11 @@ exports.requireExt = function(display, callback)
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
function floatToFix(f)
|
function floatToFix(f) {
|
||||||
{
|
|
||||||
return parseInt(f * 65536);
|
return parseInt(f * 65536);
|
||||||
}
|
}
|
||||||
|
|
||||||
function colorToFix(f)
|
function colorToFix(f) {
|
||||||
{
|
|
||||||
if (f < 0) f = 0;
|
if (f < 0) f = 0;
|
||||||
if (f > 1) f = 1;
|
if (f > 1) f = 1;
|
||||||
return parseInt(f * 65535);
|
return parseInt(f * 65535);
|
||||||
|
|
@ -185,26 +169,31 @@ exports.requireExt = function(display, callback)
|
||||||
};
|
};
|
||||||
|
|
||||||
// see example of blur filter here: https://github.com/richoH/rxvt-unicode/blob/master/src/background.C
|
// see example of blur filter here: https://github.com/richoH/rxvt-unicode/blob/master/src/background.C
|
||||||
ext.SetPictureFilter = function(pid, name, filterParams)
|
ext.SetPictureFilter = function(pid, name, filterParams) {
|
||||||
{
|
if (filterParams === 0) filterParams = [0];
|
||||||
if (filterParams === 0)
|
if (!filterParams) filterParams = [];
|
||||||
filterParams = [0];
|
if (!Array.isArray(filterParams)) filterParams = [filterParams];
|
||||||
if (!filterParams)
|
|
||||||
filterParams = [];
|
|
||||||
if (!Array.isArray(filterParams))
|
|
||||||
filterParams = [filterParams];
|
|
||||||
|
|
||||||
var reqLen = 2;
|
var reqLen = 2;
|
||||||
var format = 'CCSLSxxp';
|
var format = 'CCSLSxxp';
|
||||||
var params = [ext.majorOpcode, 30, reqLen, pid, name.length, name];
|
var params = [ext.majorOpcode, 30, reqLen, pid, name.length, name];
|
||||||
reqLen += xutil.padded_length(name.length + 3) / 4 + filterParams.length;
|
reqLen += xutil.padded_length(name.length + 3) / 4 + filterParams.length;
|
||||||
|
|
||||||
if (name == 'nearest' || name == 'bilinear' || name == 'fast' || name == 'good' || name == 'best') {
|
if (
|
||||||
|
name == 'nearest' ||
|
||||||
|
name == 'bilinear' ||
|
||||||
|
name == 'fast' ||
|
||||||
|
name == 'good' ||
|
||||||
|
name == 'best'
|
||||||
|
) {
|
||||||
if (filterParams.length !== 0) {
|
if (filterParams.length !== 0) {
|
||||||
throw 'Render.SetPictureFilter: "' + name + '" - unexpected parameters for filters';
|
throw 'Render.SetPictureFilter: "' + name + '" - unexpected parameters for filters';
|
||||||
}
|
}
|
||||||
} else if (name == 'convolution') {
|
} else if (name == 'convolution') {
|
||||||
if (filterParams.length < 2 || ((filterParams[0]*filterParams[1] + 2) !== filterParams.length) ) {
|
if (
|
||||||
|
filterParams.length < 2 ||
|
||||||
|
filterParams[0] * filterParams[1] + 2 !== filterParams.length
|
||||||
|
) {
|
||||||
throw 'Render.SetPictureFilter: "convolution" - incorrect matrix dimensions. Must be flat array [ w, h, elem1, elem2, ... ]';
|
throw 'Render.SetPictureFilter: "convolution" - incorrect matrix dimensions. Must be flat array [ w, h, elem1, elem2, ... ]';
|
||||||
}
|
}
|
||||||
for (var i = 0; i < filterParams.length; ++i) {
|
for (var i = 0; i < filterParams.length; ++i) {
|
||||||
|
|
@ -213,7 +202,10 @@ exports.requireExt = function(display, callback)
|
||||||
}
|
}
|
||||||
} else if (name == 'binomial' || name == 'gaussian') {
|
} else if (name == 'binomial' || name == 'gaussian') {
|
||||||
if (filterParams.length !== 1) {
|
if (filterParams.length !== 1) {
|
||||||
throw 'Render.SetPictureFilter: "' + name + '" - incorrect number of parameters, must be exactly 1 number, instead got: ' + filterParams;
|
throw 'Render.SetPictureFilter: "' +
|
||||||
|
name +
|
||||||
|
'" - incorrect number of parameters, must be exactly 1 number, instead got: ' +
|
||||||
|
filterParams;
|
||||||
}
|
}
|
||||||
format += 'L';
|
format += 'L';
|
||||||
params.push(floatToFix(filterParams[0]));
|
params.push(floatToFix(filterParams[0]));
|
||||||
|
|
@ -226,15 +218,22 @@ exports.requireExt = function(display, callback)
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.CreateSolidFill = function(pid, r, g, b, a)
|
ext.CreateSolidFill = function(pid, r, g, b, a) {
|
||||||
{
|
X.pack_stream.pack('CCSLSSSS', [
|
||||||
X.pack_stream.pack('CCSLSSSS', [ext.majorOpcode, 33, 4, pid, colorToFix(r), colorToFix(g), colorToFix(b), colorToFix(a)]);
|
ext.majorOpcode,
|
||||||
|
33,
|
||||||
|
4,
|
||||||
|
pid,
|
||||||
|
colorToFix(r),
|
||||||
|
colorToFix(g),
|
||||||
|
colorToFix(b),
|
||||||
|
colorToFix(a)
|
||||||
|
]);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.RadialGradient = function(pid, p1, p2, r1, r2, stops)
|
ext.RadialGradient = function(pid, p1, p2, r1, r2, stops) {
|
||||||
{
|
|
||||||
var reqLen = 9 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
var reqLen = 9 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
||||||
var format = 'CCSLLLLLLLL';
|
var format = 'CCSLLLLLLLL';
|
||||||
var params = [ext.majorOpcode, 35, reqLen, pid];
|
var params = [ext.majorOpcode, 35, reqLen, pid];
|
||||||
|
|
@ -248,26 +247,22 @@ exports.requireExt = function(display, callback)
|
||||||
|
|
||||||
// [ [float stopDist, [float r, g, b, a] ], ...]
|
// [ [float stopDist, [float r, g, b, a] ], ...]
|
||||||
// stop distances
|
// stop distances
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'L';
|
format += 'L';
|
||||||
// TODO: we know total params length in advance. ? params[index] =
|
// TODO: we know total params length in advance. ? params[index] =
|
||||||
params.push(floatToFix(stops[i][0]))
|
params.push(floatToFix(stops[i][0]));
|
||||||
}
|
}
|
||||||
// colors
|
// colors
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'SSSS';
|
format += 'SSSS';
|
||||||
for (var j=0; j < 4; ++j)
|
for (var j = 0; j < 4; ++j) params.push(colorToFix(stops[i][1][j]));
|
||||||
params.push(colorToFix(stops[i][1][j]));
|
|
||||||
}
|
}
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.LinearGradient = function(pid, p1, p2, stops)
|
ext.LinearGradient = function(pid, p1, p2, stops) {
|
||||||
{
|
|
||||||
var reqLen = 7 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
var reqLen = 7 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
||||||
var format = 'CCSLLLLLL';
|
var format = 'CCSLLLLLL';
|
||||||
var params = [ext.majorOpcode, 34, reqLen, pid];
|
var params = [ext.majorOpcode, 34, reqLen, pid];
|
||||||
|
|
@ -280,26 +275,22 @@ exports.requireExt = function(display, callback)
|
||||||
|
|
||||||
// [ [float stopDist, [float r, g, b, a] ], ...]
|
// [ [float stopDist, [float r, g, b, a] ], ...]
|
||||||
// stop distances
|
// stop distances
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'L';
|
format += 'L';
|
||||||
// TODO: we know total params length in advance. ? params[index] =
|
// TODO: we know total params length in advance. ? params[index] =
|
||||||
params.push(floatToFix(stops[i][0]))
|
params.push(floatToFix(stops[i][0]));
|
||||||
}
|
}
|
||||||
// colors
|
// colors
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'SSSS';
|
format += 'SSSS';
|
||||||
for (var j=0; j < 4; ++j)
|
for (var j = 0; j < 4; ++j) params.push(colorToFix(stops[i][1][j]));
|
||||||
params.push(colorToFix(stops[i][1][j]));
|
|
||||||
}
|
}
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.ConicalGradient = function(pid, center, angle, stops)
|
ext.ConicalGradient = function(pid, center, angle, stops) {
|
||||||
{
|
|
||||||
var reqLen = 6 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
var reqLen = 6 + stops.length * 3; //header + params + 1xStopfix+2xColors
|
||||||
var format = 'CCSLLLLL';
|
var format = 'CCSLLLLL';
|
||||||
var params = [ext.majorOpcode, 36, reqLen, pid];
|
var params = [ext.majorOpcode, 36, reqLen, pid];
|
||||||
|
|
@ -311,33 +302,27 @@ exports.requireExt = function(display, callback)
|
||||||
|
|
||||||
// [ [float stopDist, [float r, g, b, a] ], ...]
|
// [ [float stopDist, [float r, g, b, a] ], ...]
|
||||||
// stop distances
|
// stop distances
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'L';
|
format += 'L';
|
||||||
// TODO: we know total params length in advance. ? params[index] =
|
// TODO: we know total params length in advance. ? params[index] =
|
||||||
params.push(floatToFix(stops[i][0]))
|
params.push(floatToFix(stops[i][0]));
|
||||||
}
|
}
|
||||||
// colors
|
// colors
|
||||||
for (var i=0; i < stops.length; ++i)
|
for (var i = 0; i < stops.length; ++i) {
|
||||||
{
|
|
||||||
format += 'SSSS';
|
format += 'SSSS';
|
||||||
for (var j=0; j < 4; ++j)
|
for (var j = 0; j < 4; ++j) params.push(colorToFix(stops[i][1][j]));
|
||||||
params.push(colorToFix(stops[i][1][j]));
|
|
||||||
}
|
}
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.FillRectangles = function(op, pid, color, rects)
|
ext.FillRectangles = function(op, pid, color, rects) {
|
||||||
{
|
|
||||||
var reqLen = 5 + rects.length / 2;
|
var reqLen = 5 + rects.length / 2;
|
||||||
var format = 'CCSCxxxLSSSS';
|
var format = 'CCSCxxxLSSSS';
|
||||||
var params = [ext.majorOpcode, 26, reqLen, op, pid];
|
var params = [ext.majorOpcode, 26, reqLen, op, pid];
|
||||||
for (var j=0; j < 4; ++j)
|
for (var j = 0; j < 4; ++j) params.push(colorToFix(color[j]));
|
||||||
params.push(colorToFix(color[j]));
|
for (var i = 0; i < rects.length; i += 4) {
|
||||||
for (var i=0; i < rects.length; i+=4)
|
|
||||||
{
|
|
||||||
format += 'ssSS';
|
format += 'ssSS';
|
||||||
params.push(rects[i * 4]);
|
params.push(rects[i * 4]);
|
||||||
params.push(rects[i * 4 + 1]);
|
params.push(rects[i * 4 + 1]);
|
||||||
|
|
@ -347,28 +332,51 @@ exports.requireExt = function(display, callback)
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.Composite = function(op, src, mask, dst, srcX, srcY, maskX, maskY, dstX, dstY, width, height)
|
ext.Composite = function(
|
||||||
{
|
op,
|
||||||
X.pack_stream.pack(
|
src,
|
||||||
'CCSCxxxLLLssssssSS',
|
mask,
|
||||||
[ext.majorOpcode, 8, 9, op, src, mask, dst, srcX, srcY, maskX, maskY, dstX, dstY, width, height]
|
dst,
|
||||||
)
|
srcX,
|
||||||
|
srcY,
|
||||||
|
maskX,
|
||||||
|
maskY,
|
||||||
|
dstX,
|
||||||
|
dstY,
|
||||||
|
width,
|
||||||
|
height
|
||||||
|
) {
|
||||||
|
X.pack_stream
|
||||||
|
.pack('CCSCxxxLLLssssssSS', [
|
||||||
|
ext.majorOpcode,
|
||||||
|
8,
|
||||||
|
9,
|
||||||
|
op,
|
||||||
|
src,
|
||||||
|
mask,
|
||||||
|
dst,
|
||||||
|
srcX,
|
||||||
|
srcY,
|
||||||
|
maskX,
|
||||||
|
maskY,
|
||||||
|
dstX,
|
||||||
|
dstY,
|
||||||
|
width,
|
||||||
|
height
|
||||||
|
])
|
||||||
.flush();
|
.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
// note that Trapezoids is considered deprecated by Render extension
|
// note that Trapezoids is considered deprecated by Render extension
|
||||||
ext.Trapezoids = function(op, src, srcX, srcY, dst, maskFormat, trapz)
|
ext.Trapezoids = function(op, src, srcX, srcY, dst, maskFormat, trapz) {
|
||||||
{
|
|
||||||
var format = 'CCSCxxxLLLss';
|
var format = 'CCSCxxxLLLss';
|
||||||
var params = [ext.majorOpcode, 10, 6 + trapz.length, op, src, dst, maskFormat, srcX, srcY];
|
var params = [ext.majorOpcode, 10, 6 + trapz.length, op, src, dst, maskFormat, srcX, srcY];
|
||||||
for (var i=0; i < trapz.length; i++)
|
for (var i = 0; i < trapz.length; i++) {
|
||||||
{
|
|
||||||
format += 'llllllllll';
|
format += 'llllllllll';
|
||||||
for (var j=0; j < 10; ++j)
|
for (var j = 0; j < 10; ++j) params.push(floatToFix(trapz[i * 10 + j]));
|
||||||
params.push(floatToFix(trapz[i*10 + j]));
|
|
||||||
}
|
}
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
|
|
@ -378,8 +386,7 @@ exports.requireExt = function(display, callback)
|
||||||
ext.AddTraps = function(pic, offX, offY, trapList) {
|
ext.AddTraps = function(pic, offX, offY, trapList) {
|
||||||
var format = 'CCSLss';
|
var format = 'CCSLss';
|
||||||
var params = [ext.majorOpcode, 32, 3 + trapList.length, pic, offX, offY];
|
var params = [ext.majorOpcode, 32, 3 + trapList.length, pic, offX, offY];
|
||||||
for (var i=0; i < trapList.length; i++)
|
for (var i = 0; i < trapList.length; i++) {
|
||||||
{
|
|
||||||
format += 'l';
|
format += 'l';
|
||||||
params.push(floatToFix(trapList[i]));
|
params.push(floatToFix(trapList[i]));
|
||||||
}
|
}
|
||||||
|
|
@ -388,12 +395,10 @@ exports.requireExt = function(display, callback)
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.Triangles = function(op, src, srcX, srcY, dst, maskFormat, tris)
|
ext.Triangles = function(op, src, srcX, srcY, dst, maskFormat, tris) {
|
||||||
{
|
|
||||||
var format = 'CCSCxxxLLLss';
|
var format = 'CCSCxxxLLLss';
|
||||||
var params = [ext.majorOpcode, 11, 6 + tris.length, op, src, dst, maskFormat, srcX, srcY];
|
var params = [ext.majorOpcode, 11, 6 + tris.length, op, src, dst, maskFormat, srcX, srcY];
|
||||||
for (var i=0; i < tris.length; i+=6)
|
for (var i = 0; i < tris.length; i += 6) {
|
||||||
{
|
|
||||||
format += 'llllll';
|
format += 'llllll';
|
||||||
//TODO: Array.copy
|
//TODO: Array.copy
|
||||||
params.push(floatToFix(tris[i + 0])); // x1
|
params.push(floatToFix(tris[i + 0])); // x1
|
||||||
|
|
@ -406,25 +411,25 @@ exports.requireExt = function(display, callback)
|
||||||
X.pack_stream.pack(format, params);
|
X.pack_stream.pack(format, params);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.CreateGlyphSet = function(gsid, format) {
|
ext.CreateGlyphSet = function(gsid, format) {
|
||||||
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 17, 3, gsid, format]);
|
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 17, 3, gsid, format]);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.ReferenceGlyphSet = function(gsid, existing) {
|
ext.ReferenceGlyphSet = function(gsid, existing) {
|
||||||
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 18, 3, gsid, existing]);
|
X.pack_stream.pack('CCSLL', [ext.majorOpcode, 18, 3, gsid, existing]);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.FreeGlyphSet = function(gsid) {
|
ext.FreeGlyphSet = function(gsid) {
|
||||||
X.pack_stream.pack('CCSL', [ext.majorOpcode, 19, 2, gsid]);
|
X.pack_stream.pack('CCSL', [ext.majorOpcode, 19, 2, gsid]);
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
ext.AddGlyphs = function(gsid, glyphs) {
|
ext.AddGlyphs = function(gsid, glyphs) {
|
||||||
var numGlyphs = glyphs.length;
|
var numGlyphs = glyphs.length;
|
||||||
|
|
@ -437,7 +442,7 @@ exports.requireExt = function(display, callback)
|
||||||
glyph = glyphs[i];
|
glyph = glyphs[i];
|
||||||
if (glyph.width % 4 !== 0) {
|
if (glyph.width % 4 !== 0) {
|
||||||
var stride = (glyph.width + 3) & ~3;
|
var stride = (glyph.width + 3) & ~3;
|
||||||
var res = new Buffer(glyph.height*stride);
|
var res = Buffer.alloc(glyph.height * stride);
|
||||||
res.fill(0);
|
res.fill(0);
|
||||||
for (var y = 0; y < glyph.height; ++y) {
|
for (var y = 0; y < glyph.height; ++y) {
|
||||||
glyph.image.copy(res, y * stride, y * glyph.width, y * glyph.width + glyph.width);
|
glyph.image.copy(res, y * stride, y * glyph.width, y * glyph.width + glyph.width);
|
||||||
|
|
@ -463,7 +468,14 @@ exports.requireExt = function(display, callback)
|
||||||
}
|
}
|
||||||
// width + heiht + origin xy + advance xy
|
// width + heiht + origin xy + advance xy
|
||||||
for (i = 0; i < numGlyphs; i++) {
|
for (i = 0; i < numGlyphs; i++) {
|
||||||
X.pack_stream.pack('SSssss', [glyphs[i].width, glyphs[i].height, -glyphs[i].x, glyphs[i].y, glyphs[i].offX, glyphs[i].offY]);
|
X.pack_stream.pack('SSssss', [
|
||||||
|
glyphs[i].width,
|
||||||
|
glyphs[i].height,
|
||||||
|
-glyphs[i].x,
|
||||||
|
glyphs[i].y,
|
||||||
|
glyphs[i].offX,
|
||||||
|
glyphs[i].offY
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
// image
|
// image
|
||||||
for (i = 0; i < numGlyphs; i++) {
|
for (i = 0; i < numGlyphs; i++) {
|
||||||
|
|
@ -471,12 +483,29 @@ exports.requireExt = function(display, callback)
|
||||||
}
|
}
|
||||||
X.pack_stream.flush();
|
X.pack_stream.flush();
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
}
|
};
|
||||||
|
|
||||||
//AddGlyphsFromPicture, opcode=21 (not in spec)
|
// As far as I know this is not implemented in any X server and always retuen "Bad implementation"
|
||||||
// FreeGlyps - opcode 22
|
// Also documentation looks misleading as it's not mention glyph ids.
|
||||||
// gsid(L) , glyphs.length (L) + each glyph id (L)
|
ext.AddGlyphsFromPicture = function(gsid, src, glyphs) {
|
||||||
//
|
var len = 3 + glyphs.length * 5;
|
||||||
|
X.pack_stream.pack('CCSLLL', [ext.majorOpcode, 21, 0, len + 1, gsid, src]);
|
||||||
|
for (i = 0; i < glyphs.length; i++) {
|
||||||
|
X.pack_stream.pack('L', [glyphs[i].id]);
|
||||||
|
}
|
||||||
|
for (i = 0; i < glyphs.length; i++) {
|
||||||
|
X.pack_stream.pack('SSssssss', [
|
||||||
|
glyphs[i].width,
|
||||||
|
glyphs[i].height,
|
||||||
|
-glyphs[i].x,
|
||||||
|
glyphs[i].y,
|
||||||
|
glyphs[i].offX,
|
||||||
|
glyphs[i].offY,
|
||||||
|
glyphs[i].srcX,
|
||||||
|
glyphs[i].srcY
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// each GlyphEle:
|
// each GlyphEle:
|
||||||
// 1 byte - number of glyphs
|
// 1 byte - number of glyphs
|
||||||
|
|
@ -492,29 +521,128 @@ exports.requireExt = function(display, callback)
|
||||||
// glyphs as input:
|
// glyphs as input:
|
||||||
// [ "just string (0,0) offset is used", [ 10, 10, "string offseted 10,10 from previous pen position" ], 1234567 ] 1234567 is glypfset id or FONT
|
// [ "just string (0,0) offset is used", [ 10, 10, "string offseted 10,10 from previous pen position" ], 1234567 ] 1234567 is glypfset id or FONT
|
||||||
|
|
||||||
|
|
||||||
// TODO: pre-process input so strings larger than 254 chars are supported
|
// TODO: pre-process input so strings larger than 254 chars are supported
|
||||||
// (split them into multiple entries with 0,0 offset)
|
// (split them into multiple entries with 0,0 offset)
|
||||||
|
|
||||||
var formatFromBits = [,,,,,,,,'C',,,,,,,,'S',,,,,,,,,,,,,,,,'L'];
|
var formatFromBits = [
|
||||||
var bufferWriteBits = [,,,,,,,,'writeUInt8',,,,,,,,'writeUInt16LE',,,,,,,,,,,,,,,,'writeUInt32LE'];
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'C',
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'S',
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'L'
|
||||||
|
];
|
||||||
|
var bufferWriteBits = [
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'writeUInt8',
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'writeUInt16LE',
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
'writeUInt32LE'
|
||||||
|
];
|
||||||
|
|
||||||
// 8/16/32 bit string + 4-byte pad
|
// 8/16/32 bit string + 4-byte pad
|
||||||
function wstring(bits, s) {
|
function wstring(bits, s) {
|
||||||
var charLength = bits / 8;
|
var charLength = bits / 8;
|
||||||
var dataLength = s.length * charLength;
|
var dataLength = s.length * charLength;
|
||||||
var res = new Buffer(xutil.padded_length(dataLength));
|
var res = Buffer.alloc(xutil.padded_length(dataLength));
|
||||||
debugger;
|
debugger;
|
||||||
var write = res[bufferWriteBits[bits]]
|
var write = res[bufferWriteBits[bits]];
|
||||||
res.fill(0);
|
res.fill(0);
|
||||||
for(var i=0; i < s.length; i++)
|
for (var i = 0; i < s.length; i++) write.call(res, s.charCodeAt(i), i * charLength);
|
||||||
write.call(res, s.charCodeAt(i), i*charLength);
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
var compositeGlyphsOpcodeFromBits = [,,,,,,,,23,,,,,,,,24,,,,,,,,,,,,,,,,25];
|
var compositeGlyphsOpcodeFromBits = [
|
||||||
ext.CompositeGlyphs = function(glyphBits, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs)
|
,
|
||||||
{
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
23,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
24,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
,
|
||||||
|
25
|
||||||
|
];
|
||||||
|
ext.CompositeGlyphs = function(glyphBits, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs) {
|
||||||
var opcode = compositeGlyphsOpcodeFromBits[glyphBits];
|
var opcode = compositeGlyphsOpcodeFromBits[glyphBits];
|
||||||
var charFormat = formatFromBits[glyphBits];
|
var charFormat = formatFromBits[glyphBits];
|
||||||
var charLength = glyphBits / 8;
|
var charLength = glyphBits / 8;
|
||||||
|
|
@ -534,10 +662,18 @@ exports.requireExt = function(display, callback)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
X.pack_stream.pack(
|
X.pack_stream.pack('CCSCxxxLLLLss', [
|
||||||
'CCSCxxxLLLLss',
|
ext.majorOpcode,
|
||||||
[ext.majorOpcode, opcode, length, op, src, dst, maskFormat, gsid, srcX, srcY]
|
opcode,
|
||||||
);
|
length,
|
||||||
|
op,
|
||||||
|
src,
|
||||||
|
dst,
|
||||||
|
maskFormat,
|
||||||
|
gsid,
|
||||||
|
srcX,
|
||||||
|
srcY
|
||||||
|
]);
|
||||||
for (var i = 0; i < glyphs.length; ++i) {
|
for (var i = 0; i < glyphs.length; ++i) {
|
||||||
var g = glyphs[i];
|
var g = glyphs[i];
|
||||||
switch (typeof g) {
|
switch (typeof g) {
|
||||||
|
|
@ -556,18 +692,15 @@ exports.requireExt = function(display, callback)
|
||||||
X.seq_num++;
|
X.seq_num++;
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.CompositeGlyphs8 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs)
|
ext.CompositeGlyphs8 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs) {
|
||||||
{
|
|
||||||
return ext.CompositeGlyphs(8, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
return ext.CompositeGlyphs(8, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.CompositeGlyphs16 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs)
|
ext.CompositeGlyphs16 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs) {
|
||||||
{
|
|
||||||
return ext.CompositeGlyphs(16, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
return ext.CompositeGlyphs(16, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
||||||
};
|
};
|
||||||
|
|
||||||
ext.CompositeGlyphs32 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs)
|
ext.CompositeGlyphs32 = function(op, src, dst, maskFormat, gsid, srcX, srcY, glyphs) {
|
||||||
{
|
|
||||||
return ext.CompositeGlyphs(32, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
return ext.CompositeGlyphs(32, op, src, dst, maskFormat, gsid, srcX, srcY, glyphs);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -590,32 +723,36 @@ exports.requireExt = function(display, callback)
|
||||||
// 11 - colormap or none
|
// 11 - colormap or none
|
||||||
|
|
||||||
ext.QueryPictFormat(function(err, formats) {
|
ext.QueryPictFormat(function(err, formats) {
|
||||||
if (err)
|
if (err) return callback(err);
|
||||||
return callback(err);
|
|
||||||
for (var i = 0; i < formats.formats.length; ++i) {
|
for (var i = 0; i < formats.formats.length; ++i) {
|
||||||
var f = formats.formats[i];
|
var f = formats.formats[i];
|
||||||
if (f[2] == 1 && f[10] == 1)
|
if (f[2] == 1 && f[10] == 1) ext.mono1 = f[0];
|
||||||
ext.mono1 = f[0] ;
|
if (f[2] == 24 && f[3] == 16 && f[5] == 8 && f[7] == 0) ext.rgb24 = f[0];
|
||||||
if (f[2] == 24 && f[3] == 16 && f[5] == 8 && f[7] == 0)
|
|
||||||
ext.rgb24 = f[0];
|
|
||||||
// 1, 32, 16, 255, 8, 255, 0, 255, 24, 255, 0
|
// 1, 32, 16, 255, 8, 255, 0, 255, 24, 255, 0
|
||||||
if (f[2] == 32 && f[3] == 16 && f[4] == 255 && f[5] == 8 && f[6] == 255 && f[7] == 0 && f[9] == 24)
|
if (
|
||||||
|
f[2] == 32 &&
|
||||||
|
f[3] == 16 &&
|
||||||
|
f[4] == 255 &&
|
||||||
|
f[5] == 8 &&
|
||||||
|
f[6] == 255 &&
|
||||||
|
f[7] == 0 &&
|
||||||
|
f[9] == 24
|
||||||
|
)
|
||||||
ext.rgba32 = f[0];
|
ext.rgba32 = f[0];
|
||||||
if (f[2] == 8 && f[10] == 255)
|
if (f[2] == 8 && f[10] == 255) ext.a8 = f[0];
|
||||||
ext.a8 = f[0];
|
|
||||||
}
|
}
|
||||||
callback(null, ext);
|
callback(null, ext);
|
||||||
});
|
});
|
||||||
|
|
||||||
[
|
[
|
||||||
"PICTFORMAT argument does not name a defined PICTFORMAT",
|
'PICTFORMAT argument does not name a defined PICTFORMAT',
|
||||||
"PICTURE argument does not name a defined PICTURE",
|
'PICTURE argument does not name a defined PICTURE',
|
||||||
"PICTOP argument does not name a defined PICTOP",
|
'PICTOP argument does not name a defined PICTOP',
|
||||||
"GLYPHSET argument does not name a defined GLYPHSET",
|
'GLYPHSET argument does not name a defined GLYPHSET',
|
||||||
"GLYPH argument does not name a defined GLYPH in the glyphset"
|
'GLYPH argument does not name a defined GLYPH in the glyphset'
|
||||||
].forEach(function(desc, code) {
|
].forEach(function(desc, code) {
|
||||||
X.errorParsers[ext.firstError + code] = function(err) {
|
X.errorParsers[ext.firstError + code] = function(err) {
|
||||||
err.message = "XRender: a value for a " + desc;
|
err.message = 'XRender: a value for a ' + desc;
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
@ -727,4 +864,4 @@ exports.requireExt = function(display, callback)
|
||||||
Best: 'best'
|
Best: 'best'
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
}
|
};
|
||||||
|
|
|
||||||
|
|
@ -112,5 +112,31 @@ exports.requireExt = function(display, callback)
|
||||||
callback(null, ext);
|
callback(null, ext);
|
||||||
});
|
});
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
ext.events = {
|
||||||
|
ShapeNotify: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
X.eventParsers[ext.firstEvent + ext.events.ShapeNotify] = function(type, seq, extra, code, raw)
|
||||||
|
{
|
||||||
|
var event = {};
|
||||||
|
event.type = type;
|
||||||
|
event.kind = code;
|
||||||
|
event.seq = seq;
|
||||||
|
|
||||||
|
event.window = extra;
|
||||||
|
|
||||||
|
var values = raw.unpack('ssSSLC');
|
||||||
|
|
||||||
|
event.x = values[0];
|
||||||
|
event.y = values[1];
|
||||||
|
event.width = values[2];
|
||||||
|
event.height = values[3];
|
||||||
|
event.time = values[4];
|
||||||
|
event.shaped = values[5];
|
||||||
|
event.name = 'ShapeNotify';
|
||||||
|
|
||||||
|
return event;
|
||||||
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
||||||
22
lib/gcfunction.js
Normal file
22
lib/gcfunction.js
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
/*
|
||||||
|
* GCFunction named shortcuts
|
||||||
|
*/
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
GXclear : 0x0,
|
||||||
|
GXand : 0x1,
|
||||||
|
GXandReverse : 0x2,
|
||||||
|
GXcopy : 0x3,
|
||||||
|
GXandInverted : 0x4,
|
||||||
|
GXnoop : 0x5,
|
||||||
|
GXxor : 0x6,
|
||||||
|
GXor : 0x7,
|
||||||
|
GXnor : 0x8,
|
||||||
|
GXequiv : 0x9,
|
||||||
|
GXinvert : 0xa,
|
||||||
|
GXorReverse : 0xb,
|
||||||
|
GXcopyInverted : 0xc,
|
||||||
|
GXorInverted : 0xd,
|
||||||
|
GXnand : 0xe,
|
||||||
|
GXset : 0xf
|
||||||
|
};
|
||||||
|
|
@ -7,7 +7,7 @@
|
||||||
// It should create a pleasant looking hex dumb by default:
|
// It should create a pleasant looking hex dumb by default:
|
||||||
//
|
//
|
||||||
// var hexy = require('hexy.js'),
|
// var hexy = require('hexy.js'),
|
||||||
// b = new Buffer("\000\001\003\005\037\012\011bcdefghijklmnopqrstuvwxyz0123456789")
|
// b = Buffer.alloc("\000\001\003\005\037\012\011bcdefghijklmnopqrstuvwxyz0123456789")
|
||||||
//
|
//
|
||||||
// console.log(hexy.hexy(b))
|
// console.log(hexy.hexy(b))
|
||||||
//
|
//
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,11 @@ Object.defineProperty(module.exports, 'keySyms', {
|
||||||
get: function() { return require('./keysyms'); }
|
get: function() { return require('./keysyms'); }
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Object.defineProperty(module.exports, 'gcFunction', {
|
||||||
|
enumerable: true,
|
||||||
|
get: function() { return require('./gcfunction'); }
|
||||||
|
});
|
||||||
|
|
||||||
//TODO:
|
//TODO:
|
||||||
// keepe everything in namespace for consistensy (eventMask, keySyms, class, destination ...
|
// keepe everything in namespace for consistensy (eventMask, keySyms, class, destination ...
|
||||||
// or put most used constants to top namespace? (currently class and destination in top)
|
// or put most used constants to top namespace? (currently class and destination in top)
|
||||||
|
|
|
||||||
|
|
@ -23,7 +23,7 @@ function ReadFixedRequest(length, callback)
|
||||||
{
|
{
|
||||||
this.length = length;
|
this.length = length;
|
||||||
this.callback = callback;
|
this.callback = callback;
|
||||||
this.data = new Buffer(length);
|
this.data = Buffer.alloc(length);
|
||||||
this.received_bytes = 0;
|
this.received_bytes = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -201,7 +201,7 @@ UnpackStream.prototype.pstr = function(str)
|
||||||
var len = xutil.padded_length(str.length);
|
var len = xutil.padded_length(str.length);
|
||||||
if (len == 0)
|
if (len == 0)
|
||||||
return; // nothing to write
|
return; // nothing to write
|
||||||
var buf = new Buffer(len);
|
var buf = Buffer.alloc(len);
|
||||||
buf.write(str, 'binary');
|
buf.write(str, 'binary');
|
||||||
this.write_queue.push(buf);
|
this.write_queue.push(buf);
|
||||||
}
|
}
|
||||||
|
|
@ -231,7 +231,7 @@ UnpackStream.prototype.pack = function(format, args)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var buf = new Buffer(packetlength);
|
var buf = Buffer.alloc(packetlength);
|
||||||
var offset = 0;
|
var offset = 0;
|
||||||
var arg = 0;
|
var arg = 0;
|
||||||
for (var i = 0; i < format.length; ++i)
|
for (var i = 0; i < format.length; ++i)
|
||||||
|
|
@ -269,12 +269,14 @@ UnpackStream.prototype.pack = function(format, args)
|
||||||
buf[offset++] = (n >> 16) & 0xff;
|
buf[offset++] = (n >> 16) & 0xff;
|
||||||
buf[offset++] = (n >> 24) & 0xff;
|
buf[offset++] = (n >> 24) & 0xff;
|
||||||
break;
|
break;
|
||||||
case 'a': // string or buffer
|
case 'a': // string, buffer, or array
|
||||||
var str = args[arg++];
|
var str = args[arg++];
|
||||||
if (Buffer.isBuffer(str))
|
if (Buffer.isBuffer(str))
|
||||||
{
|
{
|
||||||
str.copy(buf, offset);
|
str.copy(buf, offset);
|
||||||
offset += str.length;
|
offset += str.length;
|
||||||
|
} else if(Array.isArray(str)) {
|
||||||
|
for(var item of str) buf[offset++] = item;
|
||||||
} else {
|
} else {
|
||||||
// TODO: buffer.write could be faster
|
// TODO: buffer.write could be faster
|
||||||
for (var c = 0; c < str.length; ++c)
|
for (var c = 0; c < str.length; ++c)
|
||||||
|
|
|
||||||
31
lib/xcore.js
31
lib/xcore.js
|
|
@ -6,7 +6,6 @@ var handshake = require('./handshake');
|
||||||
|
|
||||||
var EventEmitter = require('events').EventEmitter;
|
var EventEmitter = require('events').EventEmitter;
|
||||||
var PackStream = require('./unpackstream');
|
var PackStream = require('./unpackstream');
|
||||||
var coreRequestsTemplate = require('./corereqs');
|
|
||||||
var hexy = require('./hexy').hexy;
|
var hexy = require('./hexy').hexy;
|
||||||
|
|
||||||
var Buffer = require('buffer').Buffer;
|
var Buffer = require('buffer').Buffer;
|
||||||
|
|
@ -20,6 +19,25 @@ var coreRequests = require('./corereqs');
|
||||||
var stdatoms = require('./stdatoms');
|
var stdatoms = require('./stdatoms');
|
||||||
var em = require('./eventmask').eventMask;
|
var em = require('./eventmask').eventMask;
|
||||||
|
|
||||||
|
function stash ()
|
||||||
|
{
|
||||||
|
require('./ext/apple-wm');
|
||||||
|
require('./ext/big-requests');
|
||||||
|
require('./ext/composite');
|
||||||
|
require('./ext/damage');
|
||||||
|
require('./ext/dpms');
|
||||||
|
require('./ext/fixes');
|
||||||
|
require('./ext/glxconstants');
|
||||||
|
require('./ext/glx');
|
||||||
|
require('./ext/glxrender');
|
||||||
|
require('./ext/randr');
|
||||||
|
require('./ext/render');
|
||||||
|
require('./ext/screen-saver');
|
||||||
|
require('./ext/shape');
|
||||||
|
require('./ext/xc-misc');
|
||||||
|
require('./ext/xtest');
|
||||||
|
}
|
||||||
|
|
||||||
function XClient(displayNum, screenNum, options)
|
function XClient(displayNum, screenNum, options)
|
||||||
{
|
{
|
||||||
EventEmitter.call(this);
|
EventEmitter.call(this);
|
||||||
|
|
@ -304,7 +322,14 @@ XClient.prototype.unpackEvent = function(type, seq, extra, code, raw, headerBuf)
|
||||||
event.x = values[5];
|
event.x = values[5];
|
||||||
event.y = values[6];
|
event.y = values[6];
|
||||||
event.values = values
|
event.values = values
|
||||||
|
} else if (type == 9) { // FocusIn
|
||||||
|
event.name = "FocusIn";
|
||||||
|
event.mode = raw.unpack('C')[0];
|
||||||
|
event.wid = extra;
|
||||||
|
} else if (type == 10) { // FocusOut
|
||||||
|
event.name = "FocusOut";
|
||||||
|
event.mode = raw.unpack('C')[0];
|
||||||
|
event.wid = extra;
|
||||||
} else if (type == 12) { // Expose
|
} else if (type == 12) { // Expose
|
||||||
var values = raw.unpack('SSSSS');
|
var values = raw.unpack('SSSSS');
|
||||||
event.name = 'Expose'
|
event.name = 'Expose'
|
||||||
|
|
@ -490,7 +515,7 @@ XClient.prototype.expectReplyHeader = function()
|
||||||
|
|
||||||
// raw event 32-bytes packet (primarily for use in SendEvent);
|
// raw event 32-bytes packet (primarily for use in SendEvent);
|
||||||
// TODO: Event::pack based on event parameters, inverse to unpackEvent
|
// TODO: Event::pack based on event parameters, inverse to unpackEvent
|
||||||
ev.rawData = new Buffer(32);
|
ev.rawData = Buffer.alloc(32);
|
||||||
headerBuf.copy(ev.rawData);
|
headerBuf.copy(ev.rawData);
|
||||||
buf.copy(ev.rawData, 8);
|
buf.copy(ev.rawData, 8);
|
||||||
|
|
||||||
|
|
|
||||||
16
package.json
16
package.json
|
|
@ -12,7 +12,7 @@
|
||||||
"X"
|
"X"
|
||||||
],
|
],
|
||||||
"homepage": "https://github.com/sidorares/node-x11",
|
"homepage": "https://github.com/sidorares/node-x11",
|
||||||
"version": "2.2.0",
|
"version": "2.3.0",
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
{
|
{
|
||||||
"name": "Andrey Sidorov",
|
"name": "Andrey Sidorov",
|
||||||
|
|
@ -40,17 +40,15 @@
|
||||||
"node": "*"
|
"node": "*"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"mocha": "*",
|
"async": "^3.0.1",
|
||||||
"should": "*",
|
"mocha": "^7.1.2",
|
||||||
"sax": "*",
|
"sax": "^1.2.4",
|
||||||
"async": "*",
|
"should": "^13.2.1",
|
||||||
"sinon": "*"
|
"sinon": "^7.2.5"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "node test-runner.js",
|
"test": "node test-runner.js",
|
||||||
"prepublish": "npm prune"
|
"prepublish": "npm prune"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {}
|
||||||
"os-homedir": "^1.0.1"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -63,7 +63,7 @@ describe('Atoms and atom names cache', function() {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should be used after the first request for non-std atom_names', function(done) {
|
xit('should be used after the first request for non-std atom_names', function(done) {
|
||||||
var self = this;
|
var self = this;
|
||||||
var my_name;
|
var my_name;
|
||||||
/*
|
/*
|
||||||
|
|
@ -94,7 +94,7 @@ describe('Atoms and atom names cache', function() {
|
||||||
function(err) {
|
function(err) {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
should.exist(my_name);
|
should.exist(my_name);
|
||||||
self.spy.reset();
|
self.spy.resetHistory();
|
||||||
self.X.InternAtom(true, my_name, function(err, atom) {
|
self.X.InternAtom(true, my_name, function(err, atom) {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
my_atom.should.equal(atom);
|
my_atom.should.equal(atom);
|
||||||
|
|
|
||||||
|
|
@ -27,7 +27,7 @@ describe('ChangeProperty', function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
var raw = new Buffer(4);
|
var raw = Buffer.alloc(4);
|
||||||
raw.writeUInt32LE(self.wid, 0);
|
raw.writeUInt32LE(self.wid, 0);
|
||||||
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.WINDOW, 32, raw);
|
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.WINDOW, 32, raw);
|
||||||
self.X.once('event', function(ev) {
|
self.X.once('event', function(ev) {
|
||||||
|
|
@ -47,7 +47,7 @@ describe('ChangeProperty', function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
var raw = new Buffer(new Array(8));
|
var raw = Buffer.from(new Array(8));
|
||||||
raw.writeUInt32LE(self.wid, 0);
|
raw.writeUInt32LE(self.wid, 0);
|
||||||
raw.writeUInt32LE(self.wid_helper, 4);
|
raw.writeUInt32LE(self.wid_helper, 4);
|
||||||
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.ATOM, 32, raw);
|
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.ATOM, 32, raw);
|
||||||
|
|
@ -69,7 +69,7 @@ describe('ChangeProperty', function() {
|
||||||
var self = this;
|
var self = this;
|
||||||
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
this.X.InternAtom(false, TEST_PROPERTY, function(err, atom) {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
var raw = new Buffer(0);
|
var raw = Buffer.alloc(0);
|
||||||
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.WINDOW, 32, raw);
|
self.X.ChangeProperty(0, self.wid, atom, self.X.atoms.WINDOW, 32, raw);
|
||||||
self.X.once('event', function(ev) {
|
self.X.once('event', function(ev) {
|
||||||
ev.type.should.equal(28);
|
ev.type.should.equal(28);
|
||||||
|
|
|
||||||
54
test/changeGC.js
Normal file
54
test/changeGC.js
Normal file
|
|
@ -0,0 +1,54 @@
|
||||||
|
var x11 = require('../lib');
|
||||||
|
var should = require('should');
|
||||||
|
|
||||||
|
describe('CreateGC', function() {
|
||||||
|
before(function(done) {
|
||||||
|
var self = this;
|
||||||
|
this.client = x11.createClient(function(err, dpy) {
|
||||||
|
should.not.exist(err);
|
||||||
|
self.X = dpy.client;
|
||||||
|
self.root = dpy.screen[0].root;
|
||||||
|
self.white = dpy.screen[0].white_pixel;
|
||||||
|
self.black = dpy.screen[0].black_pixel;
|
||||||
|
self.wid = self.X.AllocID();
|
||||||
|
self.X.CreateWindow(self.wid, self.root, 0, 0, 1, 1); // 1x1 pixel window
|
||||||
|
self.X.MapWindow(self.wid);
|
||||||
|
self.X.QueryTree(self.root, function(err, list) {
|
||||||
|
should.not.exist(err);
|
||||||
|
list.children.indexOf(self.wid).should.not.equal(-1);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create a Graphic Context correctly', function() {
|
||||||
|
var self = this;
|
||||||
|
this.client.on('error', function(err) {
|
||||||
|
should.not.exist(err);
|
||||||
|
});
|
||||||
|
|
||||||
|
this.gc = this.X.AllocID();
|
||||||
|
this.X.CreateGC(this.gc,
|
||||||
|
this.wid,
|
||||||
|
{
|
||||||
|
foreground: this.black,
|
||||||
|
background: this.white,
|
||||||
|
lineStyle : 0
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
this.X.ChangeGC(this.gc,
|
||||||
|
{
|
||||||
|
foreground: 0xffff00,
|
||||||
|
background: 0x0000ff,
|
||||||
|
lineStyle : 2
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
after(function(done) {
|
||||||
|
this.X.DestroyWindow(this.wid);
|
||||||
|
this.X.on('end', done);
|
||||||
|
this.X.terminate();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
@ -40,7 +40,7 @@ describe('ClientMessage', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
var X = dpy.client;
|
var X = dpy.client;
|
||||||
var eventData = new Buffer(32);
|
var eventData = Buffer.alloc(32);
|
||||||
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
||||||
eventData.writeInt8(8, 1); //Format
|
eventData.writeInt8(8, 1); //Format
|
||||||
eventData.writeInt32LE(self.wid, 4); //Window ID
|
eventData.writeInt32LE(self.wid, 4); //Window ID
|
||||||
|
|
@ -67,7 +67,7 @@ describe('ClientMessage', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
var X = dpy.client;
|
var X = dpy.client;
|
||||||
var eventData = new Buffer(32);
|
var eventData = Buffer.alloc(32);
|
||||||
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
||||||
eventData.writeInt8(16, 1); //Format
|
eventData.writeInt8(16, 1); //Format
|
||||||
eventData.writeInt32LE(self.wid, 4); //Window ID
|
eventData.writeInt32LE(self.wid, 4); //Window ID
|
||||||
|
|
@ -94,7 +94,7 @@ describe('ClientMessage', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
var X = dpy.client;
|
var X = dpy.client;
|
||||||
var eventData = new Buffer(32);
|
var eventData = Buffer.alloc(32);
|
||||||
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
eventData.writeInt8(33, 0); //Event Type 33 = ClientMessage
|
||||||
eventData.writeInt8(32, 1); //Format
|
eventData.writeInt8(32, 1); //Format
|
||||||
eventData.writeInt32LE(self.wid, 4); //Window ID
|
eventData.writeInt32LE(self.wid, 4); //Window ID
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@ describe('KillKlient request', function() {
|
||||||
should.not.exist(err);
|
should.not.exist(err);
|
||||||
display = dpy;
|
display = dpy;
|
||||||
X = display.client;
|
X = display.client;
|
||||||
root = display.screen[0].root;
|
var root = display.screen[0].root;
|
||||||
var eventMask = x11.eventMask.SubstructureNotify;
|
var eventMask = x11.eventMask.SubstructureNotify;
|
||||||
X.ChangeWindowAttributes(root, { eventMask: eventMask });
|
X.ChangeWindowAttributes(root, { eventMask: eventMask });
|
||||||
done();
|
done();
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue