Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Excerpt

I will process tasks associated with events..Process an "Action Object".

 

Purpose

When a task is triggered, NEXUS performs a search to find an associated Action Object. For more information on how the search is performed, see The Concept.

Once an Action Object has been found, it's the job of a Process subroutine to perform the action.

Build your own

Commander, it is strongly recommended that you base any custom process subroutines on the standard NEXUS.process.js subroutine, as that subroutine handles everything that you can find in the Memory Banks.

A process subroutine defines the NEXUS.process() method. It will be passed the following parameters:

  • task – the full name of the task that was called (taskName + objectKey + suffix)
  • action – the action object associated with the task
  • obj – the main object passed from the external event/function
  • etc... – any additional data passed form the external event/function

Your subroutine should be structured like this:

Code Block
themeRDark
languagejavascript
linenumberstrue
NEXUS.process = (function() {
 
  // /////////////////////////////////////////////////////////////////
  // PRIVATE VARS

  var chimp = "hairy"; // just an example :p
 
  // /////////////////////////////////////////////////////////////////
  // PUBLIC PROCESS FUNCTION

  var process = function(task,action,obj,etc) { 
    // process the event object
    // up to you how to do that, take a look at existing mods for examples (:
 
    // when processing functions, always wrap in a try..catch
    try {
      action.fn.apply(this,arguments);
    } catch(e) {
      console(task+" error:"+e.message);
    }
 
    return true;// Return values can be:
    //  * true  = processedaction successfully, performed, no further work
    //  * false = action failed, no further work
    //  * -1    = action performed, continue search
    return true;
  }
 
  // /////////////////////////////////////////////////////////////////
  // PRIVATE FUNCTIONS
 
  var isFoo = function(foo) { // just an example :p
    return (foo != "bar");
  }
 
  // return your process function
  return process;
 
})(); 

If you want to be super-helpful to other people looking at your code:

  1. Make it easy to understand!
  2. Make it deal with common event handler object properties!
  3. Document deviations and differences compared to the standard NEXUS.process.js

File name convention

Process subroutines use the following naming convention: "NEXUS.process_modName.js", where "modName" is the name of your mod.

Div
classbox notice

You can only define one Process subroutine per NEXUS instance.

Div
classbox

Subroutines

Absorb:

Child pages (Children Display)
alltrue
depthall
excerpttrue

Div
classbox

Memory Banks

Observe:

Child pages (Children Display)
pageMemory Banks
excerpttrue