123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650 |
- smalltalk.addPackage('Trapped-Backend', {});
- smalltalk.addClass('EavModel', smalltalk.Object, ['getBlock', 'putBlock'], 'Trapped-Backend');
- smalltalk.EavModel.comment="External actor value model."
- smalltalk.addMethod(
- "_getBlock_",
- smalltalk.method({
- selector: "getBlock:",
- category: 'accessing',
- fn: function (aBlock){
- var self=this;
- self["@getBlock"]=aBlock;
- return self},
- args: ["aBlock"],
- source: "getBlock: aBlock\x0a\x0agetBlock := aBlock",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.EavModel);
- smalltalk.addMethod(
- "_initialize",
- smalltalk.method({
- selector: "initialize",
- category: 'initialization',
- fn: function (){
- var self=this;
- smalltalk.send(self,"_initialize",[],smalltalk.Object);
- self["@getBlock"]=(function(){
- return smalltalk.send(self,"_error_",["No getter block."]);
- });
- self["@putBlock"]=(function(){
- return smalltalk.send(self,"_error_",["No putter block."]);
- });
- return self},
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09getBlock := [ self error: 'No getter block.' ].\x0a\x09putBlock := [ self error: 'No putter block.' ].",
- messageSends: ["initialize", "error:"],
- referencedClasses: []
- }),
- smalltalk.EavModel);
- smalltalk.addMethod(
- "_on_",
- smalltalk.method({
- selector: "on:",
- category: 'accessing',
- fn: function (anObject){
- var self=this;
- var $1;
- $1=smalltalk.send(self["@getBlock"],"_value_",[anObject]);
- return $1;
- },
- args: ["anObject"],
- source: "on: anObject\x0a\x22Returns value of model applied on object\x22\x0a\x0a^getBlock value: anObject",
- messageSends: ["value:"],
- referencedClasses: []
- }),
- smalltalk.EavModel);
- smalltalk.addMethod(
- "_on_put_",
- smalltalk.method({
- selector: "on:put:",
- category: 'accessing',
- fn: function (anObject,anObject2){
- var self=this;
- var $1;
- $1=smalltalk.send(self["@putBlock"],"_value_value_",[anObject,anObject2]);
- return $1;
- },
- args: ["anObject", "anObject2"],
- source: "on: anObject put: anObject2\x0a\x22Puts a value via model applied on object\x22\x0a\x0a^putBlock value: anObject value: anObject2",
- messageSends: ["value:value:"],
- referencedClasses: []
- }),
- smalltalk.EavModel);
- smalltalk.addMethod(
- "_putBlock_",
- smalltalk.method({
- selector: "putBlock:",
- category: 'accessing',
- fn: function (aBlock){
- var self=this;
- self["@putBlock"]=aBlock;
- return self},
- args: ["aBlock"],
- source: "putBlock: aBlock\x0a\x0aputBlock := aBlock",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.EavModel);
- smalltalk.addClass('Isolator', smalltalk.Object, ['root'], 'Trapped-Backend');
- smalltalk.addMethod(
- "_model_modify_",
- smalltalk.method({
- selector: "model:modify:",
- category: 'action',
- fn: function (anEavModel,aBlock){
- var self=this;
- var newValue;
- newValue=smalltalk.send(aBlock,"_value_",[smalltalk.send(anEavModel,"_on_",[self])]);
- smalltalk.send(anEavModel,"_on_put_",[self,smalltalk.send(newValue,"_deepCopy",[])]);
- return self},
- args: ["anEavModel", "aBlock"],
- source: "model: anEavModel modify: aBlock\x0a\x0a| newValue |\x0anewValue := aBlock value: (anEavModel on: self).\x0aanEavModel on: self put: newValue deepCopy\x0a",
- messageSends: ["value:", "on:", "on:put:", "deepCopy"],
- referencedClasses: []
- }),
- smalltalk.Isolator);
- smalltalk.addMethod(
- "_model_read_",
- smalltalk.method({
- selector: "model:read:",
- category: 'action',
- fn: function (anEavModel,aBlock){
- var self=this;
- smalltalk.send(aBlock,"_value_",[smalltalk.send(smalltalk.send(anEavModel,"_on_",[self]),"_deepCopy",[])]);
- return self},
- args: ["anEavModel", "aBlock"],
- source: "model: anEavModel read: aBlock\x0a\x0aaBlock value: (anEavModel on: self) deepCopy",
- messageSends: ["value:", "deepCopy", "on:"],
- referencedClasses: []
- }),
- smalltalk.Isolator);
- smalltalk.addMethod(
- "_root",
- smalltalk.method({
- selector: "root",
- category: 'accessing',
- fn: function (){
- var self=this;
- return self["@root"];
- },
- args: [],
- source: "root\x0a\x0a^root\x0a",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.Isolator);
- smalltalk.addMethod(
- "_root_",
- smalltalk.method({
- selector: "root:",
- category: 'accessing',
- fn: function (anObject){
- var self=this;
- self["@root"]=anObject;
- return self},
- args: ["anObject"],
- source: "root: anObject\x0a\x0aroot := anObject",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.Isolator);
- smalltalk.addMethod(
- "_on_",
- smalltalk.method({
- selector: "on:",
- category: 'instance creation',
- fn: function (anObject){
- var self=this;
- var $1;
- $1=smalltalk.send(smalltalk.send(self,"_new",[]),"_root_",[anObject]);
- return $1;
- },
- args: ["anObject"],
- source: "on: anObject\x0a^self new root: anObject",
- messageSends: ["root:", "new"],
- referencedClasses: []
- }),
- smalltalk.Isolator.klass);
- smalltalk.addClass('TrappedDispatcher', smalltalk.Object, [], 'Trapped-Backend');
- smalltalk.TrappedDispatcher.comment="I am base class for change event dispatchers.\x0aI manage changed path - action block subscriptions.\x0aThese subscription must be three-element arrays\x0a\x09{ dirty. path. block }\x0a\x0aMy subclasses need to provide implementation for:\x0a\x09add:\x0a do:\x0a clean\x0a (optionally) run\x0a"
- smalltalk.addMethod(
- "_changed_",
- smalltalk.method({
- selector: "changed:",
- category: 'action',
- fn: function (path){
- var self=this;
- var $1;
- var needsToRun;
- needsToRun=false;
- smalltalk.send(self,"_do_",[(function(each){
- $1=smalltalk.send(each,"_accepts_",[path]);
- if(smalltalk.assert($1)){
- smalltalk.send(each,"_flag",[]);
- needsToRun=true;
- return needsToRun;
- };
- })]);
- smalltalk.send(self,"_dirty_",[needsToRun]);
- return self},
- args: ["path"],
- source: "changed: path\x0a\x09| needsToRun |\x0a needsToRun := false.\x0a\x09self do: [ :each |\x0a\x09\x09(each accepts: path) ifTrue: [\x0a\x09\x09\x09each flag.\x0a needsToRun := true.\x0a\x09\x09]\x0a\x09].\x0a\x09self dirty: needsToRun",
- messageSends: ["do:", "ifTrue:", "flag", "accepts:", "dirty:"],
- referencedClasses: []
- }),
- smalltalk.TrappedDispatcher);
- smalltalk.addMethod(
- "_dirty_",
- smalltalk.method({
- selector: "dirty:",
- category: 'action',
- fn: function (aBoolean){
- var self=this;
- if(smalltalk.assert(aBoolean)){
- smalltalk.send((function(){
- return smalltalk.send(self,"_run",[]);
- }),"_fork",[]);
- };
- return self},
- args: ["aBoolean"],
- source: "dirty: aBoolean\x0a\x09aBoolean ifTrue: [[ self run ] fork]",
- messageSends: ["ifTrue:", "fork", "run"],
- referencedClasses: []
- }),
- smalltalk.TrappedDispatcher);
- smalltalk.addMethod(
- "_on_hook_",
- smalltalk.method({
- selector: "on:hook:",
- category: 'action',
- fn: function (path,aBlock){
- var self=this;
- smalltalk.send(self,"_add_",[smalltalk.send(smalltalk.send((smalltalk.TrappedSubscription || TrappedSubscription),"_path_action_",[path,aBlock]),"_flag",[])]);
- smalltalk.send(self,"_dirty_",[true]);
- return self},
- args: ["path", "aBlock"],
- source: "on: path hook: aBlock\x0a\x09self add: (TrappedSubscription path: path action: aBlock) flag.\x0a \x09self dirty: true",
- messageSends: ["add:", "flag", "path:action:", "dirty:"],
- referencedClasses: ["TrappedSubscription"]
- }),
- smalltalk.TrappedDispatcher);
- smalltalk.addMethod(
- "_run",
- smalltalk.method({
- selector: "run",
- category: 'action',
- fn: function (){
- var self=this;
- var $1,$2;
- var needsClean;
- needsClean=false;
- smalltalk.send(self,"_do_",[(function(each){
- $1=smalltalk.send(each,"_isFlagged",[]);
- if(smalltalk.assert($1)){
- smalltalk.send(each,"_run",[]);
- $2=smalltalk.send(each,"_isEnabled",[]);
- if(! smalltalk.assert($2)){
- needsClean=true;
- return needsClean;
- };
- };
- })]);
- if(smalltalk.assert(needsClean)){
- smalltalk.send(self,"_clean",[]);
- };
- return self},
- args: [],
- source: "run\x0a\x09| needsClean |\x0a needsClean := false.\x0a\x09self do: [ :each |\x0a\x09\x09each isFlagged ifTrue: [\x0a each run.\x0a each isEnabled ifFalse: [ needsClean := true ]\x0a ]\x0a\x09].\x0a needsClean ifTrue: [ self clean ]",
- messageSends: ["do:", "ifTrue:", "run", "ifFalse:", "isEnabled", "isFlagged", "clean"],
- referencedClasses: []
- }),
- smalltalk.TrappedDispatcher);
- smalltalk.addClass('TrappedSubscription', smalltalk.Object, ['path', 'actionBlock', 'flagged'], 'Trapped-Backend');
- smalltalk.addMethod(
- "_accepts_",
- smalltalk.method({
- selector: "accepts:",
- category: 'testing',
- fn: function (aPath){
- var self=this;
- var $1;
- var lesser;
- lesser=smalltalk.send(smalltalk.send(self["@path"],"_size",[]),"_min_",[smalltalk.send(aPath,"_size",[])]);
- $1=smalltalk.send(smalltalk.send(aPath,"_copyFrom_to_",[(1),lesser]),"__eq",[smalltalk.send(self["@path"],"_copyFrom_to_",[(1),lesser])]);
- return $1;
- },
- args: ["aPath"],
- source: "accepts: aPath\x0a | lesser |\x0a lesser := path size min: aPath size.\x0a ^(aPath copyFrom: 1 to: lesser) = (path copyFrom: 1 to: lesser)",
- messageSends: ["min:", "size", "=", "copyFrom:to:"],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_flag",
- smalltalk.method({
- selector: "flag",
- category: 'accessing',
- fn: function (){
- var self=this;
- self["@flagged"]=true;
- return self},
- args: [],
- source: "flag\x0a\x09flagged := true",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_initialize",
- smalltalk.method({
- selector: "initialize",
- category: 'initialization',
- fn: function (){
- var self=this;
- smalltalk.send(self,"_initialize",[],smalltalk.Object);
- self["@path"]=nil;
- self["@actionBlock"]=nil;
- self["@flagged"]=false;
- return self},
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a path := nil.\x0a actionBlock := nil.\x0a flagged := false.",
- messageSends: ["initialize"],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_isEnabled",
- smalltalk.method({
- selector: "isEnabled",
- category: 'testing',
- fn: function (){
- var self=this;
- var $1;
- $1=smalltalk.send(self["@actionBlock"],"_notNil",[]);
- return $1;
- },
- args: [],
- source: "isEnabled\x0a\x09^actionBlock notNil",
- messageSends: ["notNil"],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_isFlagged",
- smalltalk.method({
- selector: "isFlagged",
- category: 'testing',
- fn: function (){
- var self=this;
- return self["@flagged"];
- },
- args: [],
- source: "isFlagged\x0a\x09^flagged",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_path_actionBlock_",
- smalltalk.method({
- selector: "path:actionBlock:",
- category: 'accessing',
- fn: function (anArray,aBlock){
- var self=this;
- self["@path"]=anArray;
- self["@actionBlock"]=aBlock;
- return self},
- args: ["anArray", "aBlock"],
- source: "path: anArray actionBlock: aBlock\x0a\x09path := anArray.\x0a actionBlock := aBlock",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_run",
- smalltalk.method({
- selector: "run",
- category: 'action',
- fn: function (){
- var self=this;
- smalltalk.send((function(){
- return smalltalk.send((function(){
- return smalltalk.send(self["@actionBlock"],"_value",[]);
- }),"_ensure_",[(function(){
- self["@flagged"]=false;
- return self["@flagged"];
- })]);
- }),"_on_do_",[(smalltalk.TrappedUnwatch || TrappedUnwatch),(function(){
- self["@actionBlock"]=nil;
- return self["@actionBlock"];
- })]);
- return self},
- args: [],
- source: "run\x0a\x09[[ actionBlock value ] ensure: [ flagged := false ]]\x0a on: TrappedUnwatch do: [ actionBlock := nil ]",
- messageSends: ["on:do:", "ensure:", "value"],
- referencedClasses: ["TrappedUnwatch"]
- }),
- smalltalk.TrappedSubscription);
- smalltalk.addMethod(
- "_new",
- smalltalk.method({
- selector: "new",
- category: 'instance creation',
- fn: function (){
- var self=this;
- smalltalk.send(self,"_shouldNotImplement",[]);
- return self},
- args: [],
- source: "new\x0a\x09self shouldNotImplement",
- messageSends: ["shouldNotImplement"],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription.klass);
- smalltalk.addMethod(
- "_path_action_",
- smalltalk.method({
- selector: "path:action:",
- category: 'instance creation',
- fn: function (anArray,aBlock){
- var self=this;
- var $1;
- $1=smalltalk.send(smalltalk.send(self,"_new",[],smalltalk.Object.klass),"_path_actionBlock_",[anArray,aBlock]);
- return $1;
- },
- args: ["anArray", "aBlock"],
- source: "path: anArray action: aBlock\x0a\x09^super new path: anArray actionBlock: aBlock",
- messageSends: ["path:actionBlock:", "new"],
- referencedClasses: []
- }),
- smalltalk.TrappedSubscription.klass);
- smalltalk.addClass('TrappedUnwatch', smalltalk.Error, [], 'Trapped-Backend');
- smalltalk.TrappedUnwatch.comment="SIgnal me from the watch: block to unwatch it."
- smalltalk.addMethod(
- "_reverseTrapAt_",
- smalltalk.method({
- selector: "reverseTrapAt:",
- category: '*Trapped-Backend',
- fn: function (anObject){
- var self=this;
- return nil;
- },
- args: ["anObject"],
- source: "reverseTrapAt: anObject\x0a\x09^nil",
- messageSends: [],
- referencedClasses: []
- }),
- smalltalk.Object);
- smalltalk.addMethod(
- "_reverseTrapAt_put_",
- smalltalk.method({
- selector: "reverseTrapAt:put:",
- category: '*Trapped-Backend',
- fn: function (anObject,value){
- var self=this;
- smalltalk.send(self,"_error_",[smalltalk.send(smalltalk.send("Trapped cannot put at ","__comma",[smalltalk.send(smalltalk.send(self,"_class",[]),"_name",[])]),"__comma",[" type key."])]);
- return self},
- args: ["anObject", "value"],
- source: "reverseTrapAt: anObject put: value\x0a\x09self error: 'Trapped cannot put at ', self class name, ' type key.'",
- messageSends: ["error:", ",", "name", "class"],
- referencedClasses: []
- }),
- smalltalk.Object);
- smalltalk.addMethod(
- "_asEavModel",
- smalltalk.method({
- selector: "asEavModel",
- category: '*Trapped-Backend',
- fn: function (){
- var self=this;
- var $1;
- var model;
- model=smalltalk.send((smalltalk.EavModel || EavModel),"_new",[]);
- smalltalk.send(model,"_getBlock_",[(function(anObject){
- return smalltalk.send(self,"_inject_into_",[anObject,(function(soFar,segment){
- if(($receiver = soFar) == nil || $receiver == undefined){
- return soFar;
- } else {
- return smalltalk.send(segment,"_reverseTrapAt_",[soFar]);
- };
- })]);
- })]);
- $1=smalltalk.send(self,"_isEmpty",[]);
- if(! smalltalk.assert($1)){
- smalltalk.send(model,"_putBlock_",[(function(anObject,value){
- var penultimate;
- penultimate=smalltalk.send(smalltalk.send(self,"_allButLast",[]),"_inject_into_",[anObject,(function(soFar,segment){
- if(($receiver = soFar) == nil || $receiver == undefined){
- return soFar;
- } else {
- return smalltalk.send(segment,"_reverseTrapAt_",[soFar]);
- };
- })]);
- penultimate;
- return smalltalk.send(smalltalk.send(self,"_last",[]),"_reverseTrapAt_put_",[penultimate,value]);
- })]);
- };
- return model;
- },
- args: [],
- source: "asEavModel\x0a | model |\x0a model := EavModel new.\x0a model getBlock: [ :anObject |\x0a self inject: anObject into: [ :soFar :segment |\x0a soFar ifNotNil: [ segment reverseTrapAt: soFar ]]].\x0a self isEmpty ifFalse: [\x0a model putBlock: [ :anObject :value | | penultimate |\x0a penultimate := self allButLast inject: anObject into: [ :soFar :segment |\x0a soFar ifNotNil: [ segment reverseTrapAt: soFar ]].\x0a self last reverseTrapAt: penultimate put: value ]].\x0a ^model",
- messageSends: ["new", "getBlock:", "inject:into:", "ifNotNil:", "reverseTrapAt:", "ifFalse:", "putBlock:", "allButLast", "reverseTrapAt:put:", "last", "isEmpty"],
- referencedClasses: ["EavModel"]
- }),
- smalltalk.SequenceableCollection);
- smalltalk.addMethod(
- "_reverseTrapAt_",
- smalltalk.method({
- selector: "reverseTrapAt:",
- category: '*Trapped-Backend',
- fn: function (anObject){
- var self=this;
- var $1;
- $1=smalltalk.send(anObject,"_at_ifAbsent_",[self,(function(){
- return nil;
- })]);
- return $1;
- },
- args: ["anObject"],
- source: "reverseTrapAt: anObject\x0a\x09^anObject at: self ifAbsent: [nil]",
- messageSends: ["at:ifAbsent:"],
- referencedClasses: []
- }),
- smalltalk.String);
- smalltalk.addMethod(
- "_reverseTrapAt_put_",
- smalltalk.method({
- selector: "reverseTrapAt:put:",
- category: '*Trapped-Backend',
- fn: function (anObject,value){
- var self=this;
- var $1;
- $1=smalltalk.send(anObject,"_at_put_",[self,value]);
- return $1;
- },
- args: ["anObject", "value"],
- source: "reverseTrapAt: anObject put: value\x0a\x09^anObject at: self put: value",
- messageSends: ["at:put:"],
- referencedClasses: []
- }),
- smalltalk.String);
- smalltalk.addMethod(
- "_reverseTrapAt_",
- smalltalk.method({
- selector: "reverseTrapAt:",
- category: '*Trapped-Backend',
- fn: function (anObject){
- var self=this;
- var $1;
- var $early={};
- try {
- $1=smalltalk.send((function(){
- return smalltalk.send(anObject,"_perform_",[self]);
- }),"_on_do_",[(smalltalk.MessageNotUnderstood || MessageNotUnderstood),(function(){
- throw $early=[nil];
- })]);
- return $1;
- }
- catch(e) {if(e===$early)return e[0]; throw e}
- },
- args: ["anObject"],
- source: "reverseTrapAt: anObject\x0a\x09^[anObject perform: self] on: MessageNotUnderstood do: [^nil]",
- messageSends: ["on:do:", "perform:"],
- referencedClasses: ["MessageNotUnderstood"]
- }),
- smalltalk.Symbol);
- smalltalk.addMethod(
- "_reverseTrapAt_put_",
- smalltalk.method({
- selector: "reverseTrapAt:put:",
- category: '*Trapped-Backend',
- fn: function (anObject,value){
- var self=this;
- var $1;
- $1=smalltalk.send(anObject,"_perform_withArguments_",[smalltalk.send(smalltalk.send(self,"__comma",[":"]),"_asSymbol",[]),[value]]);
- return $1;
- },
- args: ["anObject", "value"],
- source: "reverseTrapAt: anObject put: value\x0a ^anObject perform: (self, ':') asSymbol withArguments: { value }",
- messageSends: ["perform:withArguments:", "asSymbol", ","],
- referencedClasses: []
- }),
- smalltalk.Symbol);
- smalltalk.addMethod(
- "_reverseTrapAt_",
- smalltalk.method({
- selector: "reverseTrapAt:",
- category: '*Trapped-Backend',
- fn: function (anObject){
- var self=this;
- var $1;
- $1=smalltalk.send(anObject,"_at_ifAbsent_",[self,(function(){
- return nil;
- })]);
- return $1;
- },
- args: ["anObject"],
- source: "reverseTrapAt: anObject\x0a\x09^anObject at: self ifAbsent: [nil]",
- messageSends: ["at:ifAbsent:"],
- referencedClasses: []
- }),
- smalltalk.Number);
- smalltalk.addMethod(
- "_reverseTrapAt_put_",
- smalltalk.method({
- selector: "reverseTrapAt:put:",
- category: '*Trapped-Backend',
- fn: function (anObject,value){
- var self=this;
- var $1;
- $1=smalltalk.send(anObject,"_at_put_",[self,value]);
- return $1;
- },
- args: ["anObject", "value"],
- source: "reverseTrapAt: anObject put: value\x0a\x09^anObject at: self put: value",
- messageSends: ["at:put:"],
- referencedClasses: []
- }),
- smalltalk.Number);
|