Merge branch 'issue-7'

pull/14/head
Christoph Oberhofer 11 years ago
commit 93d92f2a6f

28
dist/quagga.js vendored

@ -6865,8 +6865,7 @@ define('events',[],function() {
} }
} }
return { function subscribe(event, callback, async) {
subscribe : function(event, callback, async) {
var subscription; var subscription;
if ( typeof callback === "function") { if ( typeof callback === "function") {
@ -6882,12 +6881,27 @@ define('events',[],function() {
} }
getEvent(event).subscribers.push(subscription); getEvent(event).subscribers.push(subscription);
}
return {
subscribe : function(event, callback, async) {
return subscribe(event, callback, async);
}, },
publish : function(eventName, data) { publish : function(eventName, data) {
var subscribers = getEvent(eventName).subscribers, i; var event = getEvent(eventName),
for ( i = 0; i < subscribers.length; i++) { subscribers = event.subscribers;
publishSubscription(subscribers[i], data);
} event.subscribers = subscribers.filter(function(subscriber) {
publishSubscription(subscriber, data);
return !subscriber.once;
});
},
once: function(event, callback, async) {
subscribe(event, {
callback: callback,
async: async,
once: true
});
} }
}; };
}(); }();
@ -7212,7 +7226,7 @@ function(Code128Reader, EANReader, InputStream, ImageWrapper, BarcodeLocator, Ba
size: 800 size: 800
}; };
config.readyFunc = function() { config.readyFunc = function() {
Events.subscribe("detected", function(result) { Events.once("detected", function(result) {
_stopped = true; _stopped = true;
resultCallback.call(null, result); resultCallback.call(null, result);
}, true); }, true);

File diff suppressed because one or more lines are too long

@ -0,0 +1,114 @@
define(['events'], function(Events){
beforeEach(function() {
Events.unsubscribe();
});
describe("subscribe", function() {
it("should call one callback for a single event", function() {
var callbackA = sinon.stub(),
callbackB = sinon.stub();
Events.subscribe("test", callbackA);
Events.subscribe("test", callbackB);
Events.publish("test");
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
});
it("should call one callback twice if published twice", function() {
var callback = sinon.stub();
Events.subscribe("test", callback);
Events.publish("test");
Events.publish("test");
expect(callback.calledTwice).to.be.equal(true);
});
it("should call the callback asynchronuously", function(done) {
var test = {
callback: function() {
}
};
sinon.stub(test, "callback", function() {
expect(test.callback.calledOnce).to.be.true;
done();
});
Events.subscribe("test", test.callback, true);
Events.publish("test");
expect(test.callback.called).to.be.false;
});
});
describe("once", function() {
it("should call the callback once, even when published twice", function() {
var callbackA = sinon.stub(),
callbackB = sinon.stub();
Events.once("test", callbackA);
Events.subscribe("test", callbackB);
Events.publish("test");
Events.publish("test");
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledTwice).to.be.equal(true);
});
});
describe("unsubscribe", function() {
it("should unsubscribe all callbacks from a single event", function() {
var callbackA = sinon.stub(),
callbackB = sinon.stub(),
callbackC = sinon.stub();
Events.subscribe("test", callbackA);
Events.subscribe("test", callbackB);
Events.subscribe("testC", callbackC);
Events.publish("test");
expect(callbackC.called).to.be.equal(false);
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
Events.publish("testC");
expect(callbackC.calledOnce).to.be.equal(true);
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
Events.unsubscribe("test");
Events.publish("test");
expect(callbackC.calledOnce).to.be.equal(true);
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
});
it("should unsubscribe a single callback from a single event", function() {
var callbackA = sinon.stub(),
callbackB = sinon.stub();
Events.subscribe("test", callbackA);
Events.subscribe("test", callbackB);
Events.publish("test");
expect(callbackA.calledOnce).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
Events.unsubscribe("test", callbackB);
Events.publish("test");
expect(callbackA.calledTwice).to.be.equal(true);
expect(callbackB.calledOnce).to.be.equal(true);
});
});
});

@ -16,6 +16,10 @@ define(function() {
return events[eventName]; return events[eventName];
} }
function clearEvents(){
events = {};
}
function publishSubscription(subscription, data) { function publishSubscription(subscription, data) {
if (subscription.async) { if (subscription.async) {
setTimeout(function() { setTimeout(function() {
@ -26,8 +30,7 @@ define(function() {
} }
} }
return { function subscribe(event, callback, async) {
subscribe : function(event, callback, async) {
var subscription; var subscription;
if ( typeof callback === "function") { if ( typeof callback === "function") {
@ -43,11 +46,42 @@ define(function() {
} }
getEvent(event).subscribers.push(subscription); getEvent(event).subscribers.push(subscription);
}
return {
subscribe : function(event, callback, async) {
return subscribe(event, callback, async);
}, },
publish : function(eventName, data) { publish : function(eventName, data) {
var subscribers = getEvent(eventName).subscribers, i; var event = getEvent(eventName),
for ( i = 0; i < subscribers.length; i++) { subscribers = event.subscribers;
publishSubscription(subscribers[i], data);
event.subscribers = subscribers.filter(function(subscriber) {
publishSubscription(subscriber, data);
return !subscriber.once;
});
},
once: function(event, callback, async) {
subscribe(event, {
callback: callback,
async: async,
once: true
});
},
unsubscribe: function(eventName, callback) {
var event;
if (eventName) {
event = getEvent(eventName);
if (event && callback) {
event.subscribers = event.subscribers.filter(function(subscriber){
return subscriber.callback !== callback;
});
} else {
event.subscribers = [];
}
} else {
clearEvents();
} }
} }
}; };

@ -213,7 +213,7 @@ function(Code128Reader, EANReader, InputStream, ImageWrapper, BarcodeLocator, Ba
size: 800 size: 800
}; };
config.readyFunc = function() { config.readyFunc = function() {
Events.subscribe("detected", function(result) { Events.once("detected", function(result) {
_stopped = true; _stopped = true;
resultCallback.call(null, result); resultCallback.call(null, result);
}, true); }, true);

@ -20,7 +20,8 @@ require.config({
'typedefs': 'src/typedefs', 'typedefs': 'src/typedefs',
'glMatrixAddon': 'src/glMatrixAddon', 'glMatrixAddon': 'src/glMatrixAddon',
'cluster': 'src/cluster', 'cluster': 'src/cluster',
'camera_access': 'src/camera_access' 'camera_access': 'src/camera_access',
'events': 'src/events'
}, },
deps: allTestFiles, deps: allTestFiles,
callback: window.__karma__.start callback: window.__karma__.start

Loading…
Cancel
Save