Split initialization commands

Initialization commands are sent individually. Improves connection
speed.
This commit is contained in:
David Cormier 2013-11-09 16:52:26 -05:00
parent 026881a29c
commit c03dc77e49

View file

@ -280,49 +280,31 @@ weechat.factory('connection', ['$q', '$rootScope', '$log', '$store', 'handlers',
$log.info("Connected to relay"); $log.info("Connected to relay");
// First message must be an init request // First command asks for the password and issues
// with the password // a version command. If it fails, it means the we
send(weeChat.Protocol.formatInit({ // did not provide the proper password.
sendAll([
weeChat.Protocol.formatInit({
password: passwd, password: passwd,
compression: 'off' compression: 'off'
}));
/*
* Send all the initialization commands
* and resolve them as a single promise.
*/
sendAll([
weeChat.Protocol.formatInfo({
name: 'version',
}), }),
weeChat.Protocol.formatInfo({
name: 'version',
})
]).then(
null,
function(error) {
$rootScope.passwordError = true;
}
);
send(
weeChat.Protocol.formatHdata({ weeChat.Protocol.formatHdata({
path: 'buffer:gui_buffers(*)', path: 'buffer:gui_buffers(*)',
keys: ['local_variables,notify,number,full_name,short_name,title'] keys: ['local_variables,notify,number,full_name,short_name,title']
}),
weeChat.Protocol.formatHdata({
path: "buffer:gui_buffers(*)/own_lines/last_line(-"+storage.get('lines')+")/data",
keys: []
}),
weeChat.Protocol.formatHdata({
path: "hotlist:gui_hotlist(*)",
keys: []
}),
weeChat.Protocol.formatNicklist({
}) })
).then(function(bufinfo) {
]).then(
function(messages) {
var version = messages[0];
var bufinfo = messages[1];
var lineinfo = messages[2];
var hotlist = messages[3];
var nicklist = messages[4];
$log.info("Parsing bufinfo");
var bufferInfos = bufinfo['objects'][0]['content']; var bufferInfos = bufinfo['objects'][0]['content'];
// buffers objects // buffers objects
for (var i = 0; i < bufferInfos.length ; i++) { for (var i = 0; i < bufferInfos.length ; i++) {
@ -333,22 +315,41 @@ weechat.factory('connection', ['$q', '$rootScope', '$log', '$store', 'handlers',
models.setActiveBuffer(buffer.id); models.setActiveBuffer(buffer.id);
} }
} }
});
// Send all the other commands required for initialization
send(
weeChat.Protocol.formatHdata({
path: "buffer:gui_buffers(*)/own_lines/last_line(-"+storage.get('lines')+")/data",
keys: []
})
).then(function(lineinfo) {
handlers.handleLineInfo(lineinfo); handlers.handleLineInfo(lineinfo);
handlers.handleHotlistInfo(hotlist) });
handlers.handleNicklist(nicklist)
send(weeChat.Protocol.formatSync({})); send(
$log.info("Synced"); weeChat.Protocol.formatHdata({
path: "hotlist:gui_hotlist(*)",
keys: []
})
).then(function(hotlist) {
handlers.handleHotlistInfo(hotlist);
});
send(
weeChat.Protocol.formatNicklist({
})
).then(function(nicklist) {
handlers.handleNicklist(nicklist)
});
send(
weeChat.Protocol.formatSync({})
)
// here we are really connected !
$rootScope.connected = true; $rootScope.connected = true;
},
function(error) {
// If the first command fails, it means that we do not have the
// proper password
$rootScope.passwordError = true;
}
);
} }