fnp
/
fnpeditor.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge in canvas refactorizations
[fnpeditor.git]
/
src
/
smartxml
/
smartxml.js
diff --git
a/src/smartxml/smartxml.js
b/src/smartxml/smartxml.js
index
31faef0
..
35c5299
100644
(file)
--- a/
src/smartxml/smartxml.js
+++ b/
src/smartxml/smartxml.js
@@
-583,10
+583,19
@@
$.extend(Document.prototype, Backbone.Events, {
this._currentTransaction = null;
},
this._currentTransaction = null;
},
- transaction: function(callback,
context, metadata
) {
+ transaction: function(callback,
params
) {
var toret;
var toret;
- this.startTransaction(metadata);
- toret = callback.call(context);
+ params = params || {};
+ this.startTransaction(params.metadata);
+ try {
+ toret = callback.call(params.context || this);
+ } catch(e) {
+ if(params.error) {
+ params.error(e);
+ }
+ this.rollbackTransaction();
+ return;
+ }
this.endTransaction();
return toret;
},
this.endTransaction();
return toret;
},