topical media & game development 
  
 
 
 
 
  
    
    
  
 lib-present-graphic-canvas-processing.js / js
  /*
   * Processing.js - John Resig (http://ejohn.org/)
   * MIT Licensed
   * http://ejohn.org/blog/processingjs/
   *
   * This is a port of the Processing Visualization Language.
   * More information: http://processing.org/
   */
  
  (function(){
  
  this.Processing = function Processing( aElement, aCode ) {
    if ( typeof aElement == "string" )
      aElement = document.getElementById( aElement );
  
    var p = buildProcessing( aElement );
  
    if ( aCode )
      p.init( aCode );
  
    return p;
  };
  
  function log() {
    try {
      console.log.apply( console, arguments );
    } catch(e) {
      try {
        opera.postError.apply( opera, arguments );
      } catch(e){}
    }
  }
  
  var parse = Processing.parse = function parse( aCode, p ) {
    // Angels weep at this parsing code :-(
  
    // Remove end-of-line comments
    aCode = aCode.replace(/\/\/ .*\n/g, "\n");
  
    // Weird parsing errors with %
    aCode = aCode.replace(/([^\s])%([^\s])/g, "$1 % $2");
   
    // Simple convert a function-like thing to function
    aCode = aCode.replace(/(?:static )?(\w+ )(\w+)\s*(\([^\)]*\)\s*{)/g, function(all, type, name, args) {
      if ( name == "if" || name == "for" || name == "while" ) {
        return all;
      } else {
        return "Processing." + name + " = function " + name + args;
      }
    });
  
    // Force .length() to be .length
    aCode = aCode.replace(/\.length\(\)/g, ".length");
  
    // foo( int foo, float bar )
    aCode = aCode.replace(/([\(,]\s*)(\w+)((?:\[\])+| )\s*(\w+\s*[\),])/g, "14");
    aCode = aCode.replace(/([\(,]\s*)(\w+)((?:\[\])+| )\s*(\w+\s*[\),])/g, "14");
  
    // float[] foo = new float[5];
    aCode = aCode.replace(/new (\w+)((?:\[([^\]]*)\])+)/g, function(all, name, args) {
      return "new ArrayList(" + args.slice(1,-1).split("][").join(", ") + ")";
    });
    
    aCode = aCode.replace(/(?:static )?\w+\[\]\s*(\w+)\[?\]?\s*=\s*{.*?};/g, function(all) {
      return all.replace(/{/g, "[").replace(/}/g, "]");
    });
  
    // int|float foo;
    var intFloat = /(\n\s*(?:int|float)(?:\[\])?(?:\s*|[^\(]*?,\s*))([a-z]\w*)(;|,)/i;
    while ( intFloat.test(aCode) ) {
      aCode = aCode.replace(new RegExp(intFloat), function(all, type, name, sep) {
        return type + " " + name + " = 0" + sep;
      });
    }
  
    // float foo = 5;
    aCode = aCode.replace(/(?:static )?(\w+)((?:\[\])+| ) *(\w+)\[?\]?(\s*[=,;])/g, function(all, type, arr, name, sep) {
      if ( type == "return" )
        return all;
      else
        return "var " + name + sep;
    });
  
    // Fix Array[] foo = {...} to [...]
    aCode = aCode.replace(/=\s*{((.|\s)*?)};/g, function(all,data) {
      return "= [" + data.replace(/{/g, "[").replace(/}/g, "]") + "]";
    });
    
    // static { ... } blocks
    aCode = aCode.replace(/static\s*{((.|\n)*?)}/g, function(all, init) {
      // Convert the static definitons to variable assignments
      //return init.replace(/\((.*?)\)/g, " = $1");
      return init;
    });
  
    // super() is a reserved word
    aCode = aCode.replace(/super\(/g, "superMethod(");
  
    var classes = ["int", "float", "boolean", "string"];
  
    function ClassReplace(all, name, extend, vars, last) {
      classes.push( name );
  
      var static = "";
  
      vars = vars.replace(/final\s+var\s+(\w+\s*=\s*.*?;)/g, function(all,set) {
        static += " " + name + "." + set;
        return "";
      });
  
      // Move arguments up from constructor and wrap contents with
      // a with(this), and unwrap constructor
      return "function " + name + "() {with(this){\n  " +
        (extend ? "var __self=this;function superMethod(){extendClass(__self,arguments," + extend + ");}\n" : "") +
        // Replace var foo = 0; with this.foo = 0;
        // and force var foo; to become this.foo = null;
        vars
          .replace(/,\s?/g, ";\n  this.")
          .replace(/\b(var |final |public )+\s*/g, "this.")
          .replace(/this.(\w+);/g, "this.$1 = null;") + 
          (extend ? "extendClass(this, " + extend + ");\n" : "") +
          "<CLASS " + name + " " + static + ">" + (typeof last == "string" ? last : name + "(");
    }
  
    var matchClasses = /(?:public |abstract |static )*class (\w+)\s*(?:extends\s*(\w+)\s*)?{\s*((?:.|\n)*?)\b\1\s*\(/g;
    var matchNoCon = /(?:public |abstract |static )*class (\w+)\s*(?:extends\s*(\w+)\s*)?{\s*((?:.|\n)*?)(Processing)/g;
    
    aCode = aCode.replace(matchClasses, ClassReplace);
    aCode = aCode.replace(matchNoCon, ClassReplace);
  
    var matchClass = /<CLASS (\w+) (.*?)>/, m;
    
    while ( (m = aCode.match( matchClass )) ) {
      var left = RegExp.leftContext,
        allRest = RegExp.rightContext,
        rest = nextBrace(allRest),
        className = m[1],
        staticVars = m[2] || "";
        
      allRest = allRest.slice( rest.length + 1 );
  
      rest = rest.replace(new RegExp("\\b" + className + "\\(([^\\)]*?)\\)\\s*{", "g"), function(all, args) {
        args = args.split(/,\s*?/);
        
        if ( args[0].match(/^\s*
  
  
(C) Æliens 
27/08/2009
You may not copy or print any of this material without explicit permission of the author or the publisher. 
In case of other copyright issues, contact the author.