Skip to content

Commit

Permalink
update syncedclock so it syncs faster
Browse files Browse the repository at this point in the history
  • Loading branch information
greggman committed Oct 3, 2014
1 parent 12c2431 commit 03d6f2f
Showing 1 changed file with 40 additions and 34 deletions.
74 changes: 40 additions & 34 deletions public/hft/0.x.x/scripts/syncedclock.js
Original file line number Diff line number Diff line change
@@ -112,43 +112,49 @@ define(["./io"], function(IO) {
* keep the clock synced to the server.
* @constructor
*/
var SyncedClock = function(opt_syncRateSeconds, opt_callback) {
this.url = window.location.href;
this.syncRateMS = (opt_syncRateSeconds || 10) * 1000;
this.timeOffset = 0;
this.callback = opt_callback;
this.syncToServer();
};
var SyncedClock = function(opt_syncRateSeconds, callback) {
var url = window.location.href;
var syncRateMS = (opt_syncRateSeconds || 10) * 1000;
var timeOffset = 0;
var callback = opt_callback;

var syncToServer = function(queueNext) {
var sendTime = getLocalTime();
IO.sendJSON(url, {cmd: 'time'}, function(exception, obj) {
if (exception) {
//g_services.logger.error("syncToServer: " + exception);
} else {
var receiveTime = getLocalTime();
var duration = receiveTime - sendTime;
var serverTime = obj.time + duration * 0.5;
timeOffset = serverTime - receiveTime;
if (callback) {
callback();
callback = undefined;
}
//g_services.logger.log("duration: ", duration, " timeOff:", timeOffset);
}

SyncedClock.prototype.syncToServer = function() {
var that = this;
var sendTime = getLocalTime();
IO.sendJSON(this.url, {cmd: 'time'}, function(exception, obj) {
if (exception) {
//g_services.logger.error("syncToServer: " + exception);
} else {
var receiveTime = getLocalTime();
var duration = receiveTime - sendTime;
var serverTime = obj.time + duration * 0.5;
that.timeOffset = serverTime - receiveTime;
if (that.callback) {
that.callback();
that.callback = undefined;
if (queueNext) {
setTimeout(function() {
syncToServer(true);
}, syncRateMS);
}
//g_services.logger.log("duration: ", duration, " timeOff:", that.timeOffset);
}
setTimeout(function() {
that.syncToServer();
}, that.syncRateMS);
});
};
});
};
syncToServer(true);
setTimeout(function() {syncToServer(false)}, 1000);
setTimeout(function() {syncToServer(false)}, 2000);
setTimeout(function() {syncToServer(false)}, 4000);

/**
* Gets the current time in seconds.
* @private
*/
this.getTime = function() {
return getLocalTime() + timeOffset;
};

/**
* Gets the current time in seconds.
* @private
*/
SyncedClock.prototype.getTime = function() {
return getLocalTime() + this.timeOffset;
};

return online ? new SyncedClock(opt_syncRateSeconds, opt_callback) : new LocalClock(opt_callback);

0 comments on commit 03d6f2f

Please sign in to comment.