Names gui buffer hda call
Removes the need for alternate message handling
This commit is contained in:
parent
987a3b4933
commit
7fa45cbc4f
2 changed files with 26 additions and 46 deletions
|
@ -134,8 +134,8 @@ var Protocol = function() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
self.parse = function() {
|
self.parse = function(data) {
|
||||||
|
self.setData(data);
|
||||||
var header = getHeader();
|
var header = getHeader();
|
||||||
var id = getId();
|
var id = getId();
|
||||||
var objects = [];
|
var objects = [];
|
||||||
|
|
|
@ -126,8 +126,25 @@ weechat.factory('handlers', ['$rootScope', 'colors', function($rootScope, colors
|
||||||
console.log($rootScope.buffers);
|
console.log($rootScope.buffers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var handleBufferInfo = function(message) {
|
||||||
|
// buffer info from message
|
||||||
|
var bufferInfos = message['objects'][0]['content'];
|
||||||
|
// buffers objects
|
||||||
|
var buffers = {};
|
||||||
|
for (var i = 0; i < bufferInfos.length ; i++) {
|
||||||
|
var bufferInfo = bufferInfos[i];
|
||||||
|
var pointer = bufferInfo['pointers'][0];
|
||||||
|
|
||||||
|
bufferInfo['lines'] = [];
|
||||||
|
buffers[pointer] = bufferInfo
|
||||||
|
}
|
||||||
|
$rootScope.buffers = buffers;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
var handleEvent = function(message) {
|
var handleEvent = function(message) {
|
||||||
types[message['id']](message);
|
console.log(message);
|
||||||
|
types[message['id']](message);
|
||||||
}
|
}
|
||||||
|
|
||||||
var findMetaData = function(message) {
|
var findMetaData = function(message) {
|
||||||
|
@ -141,6 +158,7 @@ weechat.factory('handlers', ['$rootScope', 'colors', function($rootScope, colors
|
||||||
}
|
}
|
||||||
|
|
||||||
var types = {
|
var types = {
|
||||||
|
bufinfo: handleBufferInfo,
|
||||||
_buffer_line_added: handleBufferLineAdded,
|
_buffer_line_added: handleBufferLineAdded,
|
||||||
_buffer_opened: handleBufferOpened
|
_buffer_opened: handleBufferOpened
|
||||||
}
|
}
|
||||||
|
@ -172,7 +190,7 @@ weechat.factory('connection', ['$rootScope', '$http', 'handlers', 'colors', func
|
||||||
websocket.onopen = function (evt) {
|
websocket.onopen = function (evt) {
|
||||||
if (proto == "weechat") {
|
if (proto == "weechat") {
|
||||||
doSend("init compression=off\nversion\n");
|
doSend("init compression=off\nversion\n");
|
||||||
doSend("hdata buffer:gui_buffers(*) full_name\n");
|
doSend("(bufinfo) hdata buffer:gui_buffers(*) full_name\n");
|
||||||
doSend("sync\n");
|
doSend("sync\n");
|
||||||
} else {
|
} else {
|
||||||
doSend("PASS " + password + "\r\nNICK test\r\nUSER test 0 * :test\r\n");
|
doSend("PASS " + password + "\r\nNICK test\r\nUSER test 0 * :test\r\n");
|
||||||
|
@ -187,12 +205,11 @@ weechat.factory('connection', ['$rootScope', '$http', 'handlers', 'colors', func
|
||||||
}
|
}
|
||||||
|
|
||||||
websocket.onmessage = function (evt) {
|
websocket.onmessage = function (evt) {
|
||||||
protocol.setData(evt.data);
|
|
||||||
message = protocol.parse()
|
message = protocol.parse(evt.data)
|
||||||
console.log(message);
|
handlers.handleEvent(message);
|
||||||
|
|
||||||
$rootScope.commands.push("RECV: " + evt.data + " TYPE:" + evt.type) ;
|
$rootScope.commands.push("RECV: " + evt.data + " TYPE:" + evt.type) ;
|
||||||
parseMessage(message);
|
|
||||||
data = evt.data;
|
|
||||||
$rootScope.$apply();
|
$rootScope.$apply();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,43 +221,6 @@ weechat.factory('connection', ['$rootScope', '$http', 'handlers', 'colors', func
|
||||||
this.websocket = websocket;
|
this.websocket = websocket;
|
||||||
}
|
}
|
||||||
|
|
||||||
var parseMessage = function(message) {
|
|
||||||
|
|
||||||
if (protocol.isEvent(message)) {
|
|
||||||
handlers.handleEvent(message);
|
|
||||||
} else {
|
|
||||||
parseObjects(message['objects']);
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
var parseObjects = function(objects) {
|
|
||||||
|
|
||||||
for (var i = 0; i < objects.length ; i++) {
|
|
||||||
console.log('type', objects[i]['type']);
|
|
||||||
if (objects[i]['type'] == 'hda') {
|
|
||||||
parseHdaObject(objects[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var parseHdaObject = function(hdaObject) {
|
|
||||||
console.log('parse hda', hdaObject['content'], hdaObject['content'].length);
|
|
||||||
buffers = {};
|
|
||||||
for (var i = 0; i < hdaObject['content'].length; i++) {
|
|
||||||
content = hdaObject['content'][i];
|
|
||||||
content['lines'] = [];
|
|
||||||
console.log('content', content);
|
|
||||||
var pointer = content['pointers'][0];
|
|
||||||
buffers[pointer] = content;
|
|
||||||
}
|
|
||||||
|
|
||||||
$rootScope.buffers = buffers;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
var sendMessage = function(message) {
|
var sendMessage = function(message) {
|
||||||
message = "input " + $rootScope.activeBuffer['full_name'] + " " + message + "\n"
|
message = "input " + $rootScope.activeBuffer['full_name'] + " " + message + "\n"
|
||||||
console.log($rootScope.activeBuffer);
|
console.log($rootScope.activeBuffer);
|
||||||
|
|
Loading…
Add table
Reference in a new issue