[Spice-devel] [PATCH] Basic SPICE port implementation

Oliver Gutierrez ogutierrez at redhat.com
Mon Oct 3 12:12:05 UTC 2016


OMG. THe patch attached to same thread. Now is Ok

On Mon, Oct 3, 2016 at 2:10 PM, Oliver Gutierrez <ogutierrez at redhat.com>
wrote:

> Forget this one. Missing one file.
>
> On Mon, Oct 3, 2016 at 2:02 PM, Oliver Gutierrez <ogutierrez at redhat.com>
> wrote:
>
>> ---
>>  enums.js        |  9 +++++++++
>>  main.js         |  3 +++
>>  spice.html      | 13 +++++++++++++
>>  spice_auto.html | 13 +++++++++++++
>>  spicemsg.js     | 18 ++++++++++++++++++
>>  utils.js        |  7 +++++++
>>  6 files changed, 63 insertions(+)
>>
>> diff --git a/enums.js b/enums.js
>> index 301fea0..b6e013c 100644
>> --- a/enums.js
>> +++ b/enums.js
>> @@ -166,6 +166,15 @@ var SPICE_MSG_PLAYBACK_VOLUME           = 105;
>>  var SPICE_MSG_PLAYBACK_MUTE             = 106;
>>  var SPICE_MSG_PLAYBACK_LATENCY          = 107;
>>
>> +var SPICE_MSG_SPICEVMC_DATA             = 101;
>> +var SPICE_MSG_PORT_INIT                 = 201;
>> +var SPICE_MSG_PORT_EVENT                = 202;
>> +var SPICE_MSG_END_PORT                  = 203;
>> +
>> +var SPICE_MSGC_SPICEVMC_DATA            = 101;
>> +var SPICE_MSGC_PORT_EVENT               = 201;
>> +var SPICE_MSGC_END_PORT                 = 202;
>> +
>>  var SPICE_PLAYBACK_CAP_CELT_0_5_1       = 0;
>>  var SPICE_PLAYBACK_CAP_VOLUME           = 1;
>>  var SPICE_PLAYBACK_CAP_LATENCY          = 2;
>> diff --git a/main.js b/main.js
>> index 874a038..2d8a1ff 100644
>> --- a/main.js
>> +++ b/main.js
>> @@ -59,6 +59,7 @@ function SpiceMainConn()
>>      this.file_xfer_tasks = {};
>>      this.file_xfer_task_id = 0;
>>      this.file_xfer_read_queue = [];
>> +    this.ports = [];
>>  }
>>
>>  SpiceMainConn.prototype = Object.create(SpiceConn.prototype);
>> @@ -154,6 +155,8 @@ SpiceMainConn.prototype.process_channel_message =
>> function(msg)
>>                  this.cursor = new SpiceCursorConn(conn);
>>              else if (chans.channels[i].type == SPICE_CHANNEL_PLAYBACK)
>>                  this.cursor = new SpicePlaybackConn(conn);
>> +            else if (chans.channels[i].type == SPICE_CHANNEL_PORT)
>> +                this.ports.push(new SpicePortConn(conn));
>>              else
>>              {
>>                  if (! ("extra_channels" in this))
>> diff --git a/spice.html b/spice.html
>> index c473678..d4c9962 100644
>> --- a/spice.html
>> +++ b/spice.html
>> @@ -42,6 +42,7 @@
>>          <script src="wire.js"></script>
>>          <script src="spiceconn.js"></script>
>>          <script src="display.js"></script>
>> +        <script src="port.js"></script>
>>          <script src="main.js"></script>
>>          <script src="inputs.js"></script>
>>          <script src="webm.js"></script>
>> @@ -142,6 +143,18 @@
>>                  }
>>              }
>>
>> +            /* SPICE port event listeners
>> +            window.addEventListener('spice-port-data', function(event) {
>> +                // Here we convert data to text, but really we can
>> obtain binary data also
>> +                var msg_text = arraybuffer_to_str(new
>> Uint8Array(event.detail.data));
>> +                DEBUG > 0 && console.log('SPICE port',
>> event.detail.channel.portName, 'message text:', msg_text);
>> +            });
>> +
>> +            window.addEventListener('spice-port-event', function(event)
>> {
>> +                DEBUG > 0 && console.log('SPICE port',
>> event.detail.channel.portName, 'event data:', event.detail.spiceEvent);
>> +            });
>> +            */
>> +
>>          </script>
>>
>>      </head>
>> diff --git a/spice_auto.html b/spice_auto.html
>> index 1179ebe..2f04fc9 100644
>> --- a/spice_auto.html
>> +++ b/spice_auto.html
>> @@ -42,6 +42,7 @@
>>          <script src="wire.js"></script>
>>          <script src="spiceconn.js"></script>
>>          <script src="display.js"></script>
>> +        <script src="port.js"></script>
>>          <script src="main.js"></script>
>>          <script src="inputs.js"></script>
>>          <script src="webm.js"></script>
>> @@ -182,6 +183,18 @@
>>                  }
>>              }
>>
>> +            /* SPICE port event listeners
>> +            window.addEventListener('spice-port-data', function(event) {
>> +                // Here we convert data to text, but really we can
>> obtain binary data also
>> +                var msg_text = arraybuffer_to_str(new
>> Uint8Array(event.detail.data));
>> +                DEBUG > 0 && console.log('SPICE port',
>> event.detail.channel.portName, 'message text:', msg_text);
>> +            });
>> +
>> +            window.addEventListener('spice-port-event', function(event)
>> {
>> +                DEBUG > 0 && console.log('SPICE port',
>> event.detail.channel.portName, 'event data:', event.detail.spiceEvent);
>> +            });
>> +            */
>> +
>>              connect();
>>          </script>
>>
>> diff --git a/spicemsg.js b/spicemsg.js
>> index 0321cc7..3619996 100644
>> --- a/spicemsg.js
>> +++ b/spicemsg.js
>> @@ -1278,3 +1278,21 @@ SpiceMsgDisplayInvalList.prototype =
>>          }
>>      },
>>  }
>> +
>> +function SpiceMsgPortInit(a, at)
>> +{
>> +    this.from_buffer(a,at);
>> +};
>> +
>> +SpiceMsgPortInit.prototype =
>> +{
>> +    from_buffer: function (a, at)
>> +    {
>> +        at = at || 0;
>> +        var dv = new SpiceDataView(a);
>> +        var namesize = dv.getUint32(at, true); at += 4;
>> +        var offset = dv.getUint32(at, true); at += 4;
>> +        this.opened = dv.getUint8(at, true); at += 1;
>> +        this.name = a.slice(offset, offset + namesize - 1);
>> +    }
>> +}
>> diff --git a/utils.js b/utils.js
>> index 9093a24..a22d0ae 100644
>> --- a/utils.js
>> +++ b/utils.js
>> @@ -100,6 +100,13 @@ function hexdump_buffer(a)
>>  }
>>
>>  /*---------------------------------------------------------
>> -------------------
>> +**  Convert arraybuffer to string
>> +**---------------------------------------------------------
>> -----------------*/
>> +function arraybuffer_to_str(buf) {
>> +  return String.fromCharCode.apply(null, new Uint16Array(buf));
>> +}
>> +
>> +/*---------------------------------------------------------
>> -------------------
>>  ** Converting keycodes to AT scancodes is very hard.
>>  ** luckly there are some resources on the web and in the Xorg driver
>> that help
>>  ** us figure out what browser dependent keycodes match to what scancodes.
>> --
>> 2.9.3
>>
>>
>
>
> --
> Oliver Gutierrez
> Associate Software Engineer - Desktop Management tools
> Red Hat
>



-- 
Oliver Gutierrez
Associate Software Engineer - Desktop Management tools
Red Hat
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/spice-devel/attachments/20161003/12d785e6/attachment.html>


More information about the Spice-devel mailing list