/** * Debugging support for web applications. * * @author David I. Lehn * * Copyright 2008-2013 Digital Bazaar, Inc. */ var forge = require('./forge'); /* DEBUG API */ module.exports = forge.debug = forge.debug || {}; // Private storage for debugging. // Useful to expose data that is otherwise unviewable behind closures. // NOTE: remember that this can hold references to data and cause leaks! // format is "forge._debug.. = data" // Example: // (function() { // var cat = 'forge.test.Test'; // debugging category // var sState = {...}; // local state // forge.debug.set(cat, 'sState', sState); // })(); forge.debug.storage = {}; /** * Gets debug data. Omit name for all cat data Omit name and cat for * all data. * * @param cat name of debugging category. * @param name name of data to get (optional). * @return object with requested debug data or undefined. */ forge.debug.get = function(cat, name) { var rval; if(typeof(cat) === 'undefined') { rval = forge.debug.storage; } else if(cat in forge.debug.storage) { if(typeof(name) === 'undefined') { rval = forge.debug.storage[cat]; } else { rval = forge.debug.storage[cat][name]; } } return rval; }; /** * Sets debug data. * * @param cat name of debugging category. * @param name name of data to set. * @param data data to set. */ forge.debug.set = function(cat, name, data) { if(!(cat in forge.debug.storage)) { forge.debug.storage[cat] = {}; } forge.debug.storage[cat][name] = data; }; /** * Clears debug data. Omit name for all cat data. Omit name and cat for * all data. * * @param cat name of debugging category. * @param name name of data to clear or omit to clear entire category. */ forge.debug.clear = function(cat, name) { if(typeof(cat) === 'undefined') { forge.debug.storage = {}; } else if(cat in forge.debug.storage) { if(typeof(name) === 'undefined') { delete forge.debug.storage[cat]; } else { delete forge.debug.storage[cat][name]; } } };