Blame view

node_modules/node-forge/lib/debug.js 2.03 KB
aaac7fed   liuqimichale   add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
  /**
   * Debugging support for web applications.
   *
   * @author David I. Lehn <dlehn@digitalbazaar.com>
   *
   * 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.<modulename>.<dataname> = 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];
      }
    }
  };