playback.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. /*
  2. * noVNC: HTML5 VNC client
  3. * Copyright (C) 2012 Joel Martin
  4. * Licensed under MPL 2.0 (see LICENSE.txt)
  5. */
  6. "use strict";
  7. /*jslint browser: true, white: false */
  8. /*global Util, VNC_frame_data, finish */
  9. var rfb, mode, test_state, frame_idx, frame_length,
  10. iteration, iterations, istart_time,
  11. // Pre-declarations for jslint
  12. send_array, next_iteration, queue_next_packet, do_packet, enable_test_mode;
  13. // Override send_array
  14. send_array = function (arr) {
  15. // Stub out send_array
  16. };
  17. enable_test_mode = function () {
  18. rfb._sock._mode = VNC_frame_encoding;
  19. rfb._sock.send = send_array;
  20. rfb._sock.close = function () {};
  21. rfb._sock.flush = function () {};
  22. rfb._checkEvents = function () {};
  23. rfb.connect = function (host, port, password, path) {
  24. this._rfb_host = host;
  25. this._rfb_port = port;
  26. this._rfb_password = (password !== undefined) ? password : "";
  27. this._rfb_path = (path !== undefined) ? path : "";
  28. this._updateState('ProtocolVersion', "Starting VNC handshake");
  29. };
  30. };
  31. next_iteration = function () {
  32. rfb = new RFB({'target': $D('VNC_canvas'),
  33. 'onUpdateState': updateState});
  34. enable_test_mode();
  35. if (iteration === 0) {
  36. frame_length = VNC_frame_data.length;
  37. test_state = 'running';
  38. }
  39. if (test_state !== 'running') { return; }
  40. iteration += 1;
  41. if (iteration > iterations) {
  42. finish();
  43. return;
  44. }
  45. frame_idx = 0;
  46. istart_time = (new Date()).getTime();
  47. rfb.connect('test', 0, "bogus");
  48. queue_next_packet();
  49. };
  50. queue_next_packet = function () {
  51. var frame, foffset, toffset, delay;
  52. if (test_state !== 'running') { return; }
  53. frame = VNC_frame_data[frame_idx];
  54. while ((frame_idx < frame_length) && (frame.charAt(0) === "}")) {
  55. //Util.Debug("Send frame " + frame_idx);
  56. frame_idx += 1;
  57. frame = VNC_frame_data[frame_idx];
  58. }
  59. if (frame === 'EOF') {
  60. Util.Debug("Finished, found EOF");
  61. next_iteration();
  62. return;
  63. }
  64. if (frame_idx >= frame_length) {
  65. Util.Debug("Finished, no more frames");
  66. next_iteration();
  67. return;
  68. }
  69. if (mode === 'realtime') {
  70. foffset = frame.slice(1, frame.indexOf('{', 1));
  71. toffset = (new Date()).getTime() - istart_time;
  72. delay = foffset - toffset;
  73. if (delay < 1) {
  74. delay = 1;
  75. }
  76. setTimeout(do_packet, delay);
  77. } else {
  78. setTimeout(do_packet, 1);
  79. }
  80. };
  81. var bytes_processed = 0;
  82. do_packet = function () {
  83. //Util.Debug("Processing frame: " + frame_idx);
  84. var frame = VNC_frame_data[frame_idx],
  85. start = frame.indexOf('{', 1) + 1;
  86. bytes_processed += frame.length - start;
  87. if (VNC_frame_encoding === 'binary') {
  88. var u8 = new Uint8Array(frame.length - start);
  89. for (var i = 0; i < frame.length - start; i++) {
  90. u8[i] = frame.charCodeAt(start + i);
  91. }
  92. rfb._sock._recv_message({'data' : u8});
  93. } else {
  94. rfb._sock._recv_message({'data' : frame.slice(start)});
  95. }
  96. frame_idx += 1;
  97. queue_next_packet();
  98. };