BVB Source Codes

waterline Show sum.js Source code

Return Download waterline: download sum.js Source code - Download waterline Source code - Type:.js
  1. /**
  2.  * Module dependencies
  3.  */
  4.  
  5. var util = require('util');
  6. var _ = require('@sailshq/lodash');
  7. var flaverr = require('flaverr');
  8. var forgeStageTwoQuery = require('../utils/query/forge-stage-two-query');
  9. var forgeStageThreeQuery = require('../utils/query/forge-stage-three-query');
  10. var Deferred = require('../utils/query/deferred');
  11.  
  12.  
  13. /**
  14.  * sum()
  15.  *
  16.  * Get the aggregate sum of the specified attribute across all matching records.
  17.  *
  18.  * ```
  19.  * // The cumulative account balance of all bank accounts that have
  20.  * // less than $32,000, or that are flagged as "suspended".
  21.  * BankAccount.sum('balance').where({
  22.  *   or: [
  23.  *     { balance: { '<': 32000 } },
  24.  *     { suspended: true }
  25.  *   ]
  26.  * }).exec(function (err, total){
  27.  *   // ...
  28.  * });
  29.  * ```
  30.  *
  31.  * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  32.  *
  33.  * Usage without deferred object:
  34.  * ================================================
  35.  *
  36.  * @param {String?} numericAttrName
  37.  *
  38.  * @param {Dictionary?} criteria
  39.  *
  40.  * @param {Dictionary} moreQueryKeys
  41.  *        For internal use.
  42.  *        (A dictionary of query keys.)
  43.  *
  44.  * @param {Function?} done
  45.  *        Callback function to run when query has either finished successfully or errored.
  46.  *        (If unspecified, will return a Deferred object instead of actually doing anything.)
  47.  *
  48.  * @param {Ref?} meta
  49.  *     For internal use.
  50.  *
  51.  * @returns {Ref?} Deferred object if no `done` callback was provided
  52.  *
  53.  * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  54.  *
  55.  * The underlying query keys:
  56.  * ==============================
  57.  *
  58.  * @qkey {String} numericAttrName
  59.  *     The name of a numeric attribute.
  60.  *     (Must be declared as `type: 'number'`.)
  61.  *
  62.  * @qkey {Dictionary?} criteria
  63.  *
  64.  * @qkey {Dictionary?} meta
  65.  * @qkey {String} using
  66.  * @qkey {String} method
  67.  *
  68.  * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  69.  */
  70.  
  71. module.exports = function sum( /* numericAttrName?, criteria?, moreQueryKeys?, done?, meta? */ ) {
  72.  
  73.   // Set up a few, common local vars for convenience / familiarity.
  74.   var WLModel = this;
  75.   var orm = this.waterline;
  76.   var modelIdentity = this.identity;
  77.  
  78.  
  79.   // Build query w/ initial, universal keys.
  80.   var query = {
  81.     method: 'sum',
  82.     using: modelIdentity
  83.   };
  84.  
  85.  
  86.   //  鈻堚枅鈺   鈻堚枅鈺 鈻堚枅鈻堚枅鈻堚晽 鈻堚枅鈻堚枅鈻堚枅鈺 鈻堚枅鈺 鈻堚枅鈻堚枅鈻堚晽 鈻堚枅鈻堚枅鈻堚枅鈺 鈻堚枅鈺 鈻堚枅鈻堚枅鈻堚枅鈺椻枅鈻堚枅鈻堚枅鈻堚枅鈺
  87.   //  鈻堚枅鈺   鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈻堚枅鈺椻枅鈻堚晹鈺愨晲鈻堚枅鈺椻枅鈻堚晳鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈺愨晲鈺濃枅鈻堚晹鈺愨晲鈺愨晲鈺
  88.   //  鈻堚枅鈺   鈻堚枅鈺戔枅鈻堚枅鈻堚枅鈻堚枅鈺戔枅鈻堚枅鈻堚枅鈻堚晹鈺濃枅鈻堚晳鈻堚枅鈻堚枅鈻堚枅鈻堚晳鈻堚枅鈺  鈻堚枅鈺戔枅鈻堚晳鈻堚枅鈺     鈻堚枅鈻堚枅鈻堚枅鈻堚晽
  89.   //  鈺氣枅鈻堚晽 鈻堚枅鈺斺暆鈻堚枅鈺斺晲鈺愨枅鈻堚晳鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈻堚枅鈺戔枅鈻堚晳  鈻堚枅鈺戔枅鈻堚晳鈻堚枅鈺     鈺氣晲鈺愨晲鈺愨枅鈻堚晳
  90.   //   鈺氣枅鈻堚枅鈻堚晹鈺 鈻堚枅鈺  鈻堚枅鈺戔枅鈻堚晳  鈻堚枅鈺戔枅鈻堚晳鈻堚枅鈺  鈻堚枅鈺戔枅鈻堚枅鈻堚枅鈻堚晹鈺濃枅鈻堚晳鈺氣枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈻堚枅鈻堚枅鈻堚晳
  91.   //    鈺氣晲鈺愨晲鈺  鈺氣晲鈺  鈺氣晲鈺濃暁鈺愨暆  鈺氣晲鈺濃暁鈺愨暆鈺氣晲鈺  鈺氣晲鈺濃暁鈺愨晲鈺愨晲鈺愨暆 鈺氣晲鈺 鈺氣晲鈺愨晲鈺愨晲鈺濃暁鈺愨晲鈺愨晲鈺愨晲鈺
  92.   //
  93.  
  94.   // The `done` callback, if one was provided.
  95.   var done;
  96.  
  97.   // Handle the various supported usage possibilities
  98.   // (locate the `done` callback, and extend the `query` dictionary)
  99.   //
  100.   // > Note that we define `args` so that we can insulate access
  101.   // > to the arguments provided to this function.
  102.   var args = arguments;
  103.   (function _handleVariadicUsage(){
  104.  
  105.  
  106.     // Additional query keys.
  107.     var _moreQueryKeys;
  108.  
  109.     // The metadata container, if one was provided.
  110.     var _meta;
  111.  
  112.  
  113.     // Handle first argument:
  114.     //
  115.     // 鈥 sum(numericAttrName, ...)
  116.     query.numericAttrName = args[0];
  117.  
  118.  
  119.     // Handle double meaning of second argument:
  120.     //
  121.     // 鈥 sum(..., criteria, done, _meta)
  122.     var is2ndArgDictionary = (_.isObject(args[1]) && !_.isFunction(args[1]) && !_.isArray(args[1]));
  123.     if (is2ndArgDictionary) {
  124.       query.criteria = args[1];
  125.       done = args[2];
  126.       _meta = args[3];
  127.     }
  128.     // 鈥 sum(..., done, _meta)
  129.     else {
  130.       done = args[1];
  131.       _meta = args[2];
  132.     }
  133.  
  134.  
  135.     // Handle double meaning of third argument:
  136.     //
  137.     // 鈥 sum(..., ..., _moreQueryKeys, done, _meta)
  138.     var is3rdArgDictionary = (_.isObject(args[2]) && !_.isFunction(args[2]) && !_.isArray(args[2]));
  139.     if (is3rdArgDictionary) {
  140.       _moreQueryKeys = args[2];
  141.       done = args[3];
  142.       _meta = args[4];
  143.     }
  144.     // 鈥 sum(..., ..., done, _meta)
  145.     else {
  146.       done = args[2];
  147.       _meta = args[3];
  148.     }
  149.  
  150.  
  151.     // Fold in `_moreQueryKeys`, if relevant.
  152.     //
  153.     // > Userland is prevented from overriding any of the universal keys this way.
  154.     if (_moreQueryKeys) {
  155.       delete _moreQueryKeys.method;
  156.       delete _moreQueryKeys.using;
  157.       delete _moreQueryKeys.meta;
  158.       _.extend(query, _moreQueryKeys);
  159.     } // >-
  160.  
  161.  
  162.     // Fold in `_meta`, if relevant.
  163.     if (_meta) {
  164.       query.meta = _meta;
  165.     } // >-
  166.  
  167.   })();
  168.  
  169.  
  170.  
  171.  
  172.   //  鈻堚枅鈻堚枅鈻堚枅鈺 鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈻堚枅鈻堚枅鈺
  173.   //  鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈻堚枅鈺斺晲鈺愨枅鈻堚晽
  174.   //  鈻堚枅鈺  鈻堚枅鈺戔枅鈻堚枅鈻堚枅鈺  鈻堚枅鈻堚枅鈻堚晽  鈻堚枅鈻堚枅鈻堚晽  鈻堚枅鈻堚枅鈻堚枅鈺斺暆
  175.   //  鈻堚枅鈺  鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈺  鈻堚枅鈺斺晲鈺愨暆  鈻堚枅鈺斺晲鈺愨暆  鈻堚枅鈺斺晲鈺愨枅鈻堚晽
  176.   //  鈻堚枅鈻堚枅鈻堚枅鈺斺暆鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺     鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺  鈻堚枅鈺
  177.   //  鈺氣晲鈺愨晲鈺愨晲鈺 鈺氣晲鈺愨晲鈺愨晲鈺愨暆鈺氣晲鈺     鈺氣晲鈺愨晲鈺愨晲鈺愨暆鈺氣晲鈺  鈺氣晲鈺
  178.   //
  179.   //   鈻堚枅鈺椻枅鈻堚枅鈺   鈻堚枅鈻堚晽 鈻堚枅鈻堚枅鈻堚晽 鈻堚枅鈺   鈻堚枅鈺椻枅鈻堚枅鈻堚枅鈻堚晽 鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺
  180.   //  鈻堚枅鈺斺暆鈻堚枅鈻堚枅鈺 鈻堚枅鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈻堚枅鈺椻暁鈻堚枅鈺 鈻堚枅鈺斺暆鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈺氣枅鈻堚晽
  181.   //  鈻堚枅鈺 鈻堚枅鈺斺枅鈻堚枅鈻堚晹鈻堚枅鈺戔枅鈻堚枅鈻堚枅鈻堚枅鈺 鈺氣枅鈻堚枅鈻堚晹鈺 鈻堚枅鈻堚枅鈻堚枅鈺斺暆鈻堚枅鈻堚枅鈻堚晽   鈻堚枅鈺
  182.   //  鈻堚枅鈺 鈻堚枅鈺戔暁鈻堚枅鈺斺暆鈻堚枅鈺戔枅鈻堚晹鈺愨晲鈻堚枅鈺  鈺氣枅鈻堚晹鈺  鈻堚枅鈺斺晲鈺愨枅鈻堚晽鈻堚枅鈺斺晲鈺愨暆   鈻堚枅鈺
  183.   //  鈺氣枅鈻堚晽鈻堚枅鈺 鈺氣晲鈺 鈻堚枅鈺戔枅鈻堚晳  鈻堚枅鈺   鈻堚枅鈺   鈻堚枅鈻堚枅鈻堚枅鈺斺暆鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺斺暆
  184.   //   鈺氣晲鈺濃暁鈺愨暆     鈺氣晲鈺濃暁鈺愨暆  鈺氣晲鈺   鈺氣晲鈺   鈺氣晲鈺愨晲鈺愨晲鈺 鈺氣晲鈺愨晲鈺愨晲鈺愨暆鈺氣晲鈺
  185.   //
  186.   //  鈹屸攼 鈹 鈹敩鈹  鈹屸敩鈹   鈹   鈹攢鈹愨攲鈹€鈹愨攲鈹攼鈹 鈹敩鈹€鈹愨攲鈹愨攲  鈹屸攼鈹屸攲鈹€鈹愨敩 鈹  鈹屸敩鈹愨攲鈹€鈹愨攲鈹€鈹愨攲鈹€鈹愨敩鈹€鈹愨敩鈹€鈹愨攲鈹€鈹愨攲鈹攼
  187.   //  鈹溾敶鈹愨攤 鈹傗攤鈹   鈹傗攤  鈹屸敿鈹€  鈹溾敩鈹樷敎鈹  鈹 鈹 鈹傗敎鈹敇鈹傗攤鈹  鈹傗攤鈹傗敎鈹 鈹傗攤鈹   鈹傗攤鈹溾敜 鈹溾敜 鈹溾敜 鈹溾敩鈹樷敎鈹敇鈹溾敜  鈹傗攤
  188.   //  鈹斺攢鈹樷敂鈹€鈹樷敶鈹粹攢鈹樷攢鈹粹敇  鈹斺敇   鈹粹敂鈹€鈹斺攢鈹 鈹 鈹斺攢鈹樷敶鈹斺攢鈹樷敂鈹  鈹樷敂鈹樷敂鈹€鈹樷敂鈹粹敇  鈹€鈹粹敇鈹斺攢鈹樷敂  鈹斺攢鈹樷敶鈹斺攢鈹粹敂鈹€鈹斺攢鈹樷攢鈹粹敇
  189.   //  鈹屸攢    鈹攲鈹€鈹  鈹攢鈹愨攲鈹€鈹愨敩  鈹屸攢鈹愨敩  鈹攲鈹€鈹愨攲鈹愨攲鈹屸敩鈹    鈹€鈹
  190.   //  鈹傗攢鈹€鈹€  鈹傗敎鈹   鈹溾敩鈹樷敎鈹 鈹  鈹溾敜 鈹斺攼鈹屸敇鈹溾攢鈹も攤鈹傗攤 鈹   鈹€鈹€鈹€鈹
  191.   //  鈹斺攢    鈹粹敂    鈹粹敂鈹€鈹斺攢鈹樷敶鈹€鈹樷敂鈹€鈹 鈹斺敇 鈹 鈹粹敇鈹斺敇 鈹     鈹€鈹
  192.   // If a callback function was not specified, then build a new `Deferred` and bail now.
  193.   //
  194.   // > This method will be called AGAIN automatically when the Deferred is executed.
  195.   // > and next time, it'll have a callback.
  196.   if (!done) {
  197.     return new Deferred(WLModel, sum, query);
  198.   } // --鈥
  199.  
  200.  
  201.   // Otherwise, IWMIH, we know that a callback was specified.
  202.   // So...
  203.   //
  204.   //  鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺  鈻堚枅鈺椻枅鈻堚枅鈻堚枅鈻堚枅鈺 鈻堚枅鈻堚枅鈻堚枅鈺椻枅鈻堚晽   鈻堚枅鈺椻枅鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈻堚枅鈻堚枅鈻堚晽
  205.   //  鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈺氣枅鈻堚晽鈻堚枅鈺斺暆鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈻堚枅鈺斺晲鈺愨晲鈺愨暆鈻堚枅鈺   鈻堚枅鈺戔暁鈺愨晲鈻堚枅鈺斺晲鈺愨暆鈻堚枅鈺斺晲鈺愨晲鈺愨暆
  206.   //  鈻堚枅鈻堚枅鈻堚晽   鈺氣枅鈻堚枅鈺斺暆 鈻堚枅鈻堚枅鈻堚晽  鈻堚枅鈺     鈻堚枅鈺   鈻堚枅鈺   鈻堚枅鈺   鈻堚枅鈻堚枅鈻堚晽
  207.   //  鈻堚枅鈺斺晲鈺愨暆   鈻堚枅鈺斺枅鈻堚晽 鈻堚枅鈺斺晲鈺愨暆  鈻堚枅鈺     鈻堚枅鈺   鈻堚枅鈺   鈻堚枅鈺   鈻堚枅鈺斺晲鈺愨暆
  208.   //  鈻堚枅鈻堚枅鈻堚枅鈻堚晽鈻堚枅鈺斺暆 鈻堚枅鈺椻枅鈻堚枅鈻堚枅鈻堚枅鈺椻暁鈻堚枅鈻堚枅鈻堚枅鈺椻暁鈻堚枅鈻堚枅鈻堚枅鈺斺暆   鈻堚枅鈺   鈻堚枅鈻堚枅鈻堚枅鈻堚晽
  209.   //  鈺氣晲鈺愨晲鈺愨晲鈺愨暆鈺氣晲鈺  鈺氣晲鈺濃暁鈺愨晲鈺愨晲鈺愨晲鈺 鈺氣晲鈺愨晲鈺愨晲鈺 鈺氣晲鈺愨晲鈺愨晲鈺    鈺氣晲鈺   鈺氣晲鈺愨晲鈺愨晲鈺愨暆
  210.  
  211.   //  鈺斺晲鈺椻晹鈺愨晽鈺︹晲鈺椻晹鈺愨晽鈺斺晲鈺  鈹屸攢鈹愨攲鈹攼鈹屸攢鈹愨攲鈹€鈹愨攲鈹€鈹  鈹屸敩鈹愨敩 鈹攲鈹€鈹  鈹屸攢鈹 鈹 鈹攲鈹€鈹愨敩鈹€鈹愨敩 鈹
  212.   //  鈺犫暎 鈺 鈺戔暊鈺︹暆鈺 鈺︹晳鈺   鈹斺攢鈹 鈹 鈹溾攢鈹も攤 鈹敎鈹    鈹 鈹傗攤鈹傗攤 鈹  鈹傗攢鈹尖攼鈹 鈹傗敎鈹 鈹溾敩鈹樷敂鈹敇
  213.   //  鈺  鈺氣晲鈺濃暕鈺氣晲鈺氣晲鈺濃暁鈺愨暆  鈹斺攢鈹 鈹 鈹 鈹粹敂鈹€鈹樷敂鈹€鈹   鈹 鈹斺敶鈹樷敂鈹€鈹  鈹斺攢鈹樷敂鈹斺攢鈹樷敂鈹€鈹樷敶鈹斺攢 鈹
  214.   //
  215.   // Forge a stage 2 query (aka logical protostatement)
  216.   try {
  217.     forgeStageTwoQuery(query, orm);
  218.   } catch (e) {
  219.     switch (e.code) {
  220.  
  221.       case 'E_INVALID_NUMERIC_ATTR_NAME':
  222.         return done(
  223.           flaverr(
  224.             { name: 'UsageError' },
  225.             new Error(
  226.               'The numeric attr name (i.e. first argument) to `.sum()` should '+
  227.               'be the name of an attribute in this model which is defined with `type: \'number\'`.\n'+
  228.               'Details:\n'+
  229.               '  ' + e.details + '\n'
  230.             )
  231.           )
  232.         );
  233.         // ^ custom override for the standard usage error.  Note that we use `.details` to get at
  234.         //   the underlying, lower-level error message (instead of logging redundant stuff from
  235.         //   the envelope provided by the default error msg.)
  236.  
  237.       case 'E_INVALID_CRITERIA':
  238.       case 'E_INVALID_META':
  239.         return done(e);
  240.         // ^ when the standard usage error is good enough as-is, without any further customization
  241.  
  242.       case 'E_NOOP':
  243.         return done(undefined, 0);
  244.  
  245.       default:
  246.         return done(e);
  247.         // ^ when an internal, miscellaneous, or unexpected error occurs
  248.     }
  249.   } // >-鈥
  250.  
  251.  
  252.   //  鈺斺晲鈺椻晹鈺愨晽鈺︹晲鈺椻晹鈺愨晽鈺斺晲鈺  鈹屸攢鈹愨攲鈹攼鈹屸攢鈹愨攲鈹€鈹愨攲鈹€鈹  鈹屸敩鈹愨敩 鈹敩鈹€鈹愨攲鈹€鈹愨攲鈹€鈹  鈹屸攢鈹 鈹 鈹攲鈹€鈹愨敩鈹€鈹愨敩 鈹
  253.   //  鈺犫暎 鈺 鈺戔暊鈺︹暆鈺 鈺︹晳鈺   鈹斺攢鈹 鈹 鈹溾攢鈹も攤 鈹敎鈹    鈹 鈹溾攢鈹も敎鈹敇鈹溾敜 鈹溾敜   鈹傗攢鈹尖攼鈹 鈹傗敎鈹 鈹溾敩鈹樷敂鈹敇
  254.   //  鈺  鈺氣晲鈺濃暕鈺氣晲鈺氣晲鈺濃暁鈺愨暆  鈹斺攢鈹 鈹 鈹 鈹粹敂鈹€鈹樷敂鈹€鈹   鈹 鈹 鈹粹敶鈹斺攢鈹斺攢鈹樷敂鈹€鈹  鈹斺攢鈹樷敂鈹斺攢鈹樷敂鈹€鈹樷敶鈹斺攢 鈹
  255.   try {
  256.     query = forgeStageThreeQuery({
  257.       stageTwoQuery: query,
  258.       identity: modelIdentity,
  259.       transformer: WLModel._transformer,
  260.       originalModels: orm.collections
  261.     });
  262.   } catch (e) { return done(e); }
  263.  
  264.  
  265.   //  鈹屸攢鈹愨攲鈹€鈹愨攲鈹愨攲鈹屸敩鈹  鈹屸敩鈹愨攲鈹€鈹  鈺斺晲鈺椻晹鈺︹晽鈺斺晲鈺椻晹鈺愨晽鈺斺暒鈺椻晹鈺愨晽鈺︹晲鈺
  266.   //  鈹斺攢鈹愨敎鈹 鈹傗攤鈹 鈹傗攤   鈹 鈹 鈹  鈺犫晲鈺 鈺戔晳鈺犫晲鈺b暊鈺愨暆 鈺 鈺戔暎 鈺犫暒鈺
  267.   //  鈹斺攢鈹樷敂鈹€鈹樷敇鈹斺敇鈹€鈹粹敇   鈹 鈹斺攢鈹  鈺 鈺┾晲鈺┾暆鈺 鈺┾暕   鈺 鈺氣晲鈺濃暕鈺氣晲
  268.   // Grab the appropriate adapter method and call it.
  269.   var adapter = WLModel._adapter;
  270.   if (!adapter.sum) {
  271.     return done(new Error('Cannot complete query: The adapter used by this model (`' + modelIdentity + '`) doesn\'t support the `'+query.method+'` method.'));
  272.   }
  273.  
  274.   adapter.sum(WLModel.datastore, query, function _afterTalkingToAdapter(err, sum) {
  275.     if (err) {
  276.  
  277.       if (!_.isError(err)) {
  278.         return done(new Error(
  279.           'If an error is sent back from the adapter, it should always be an Error instance.  '+
  280.           'But instead, got: '+util.inspect(err, {depth:5})+''
  281.         ));
  282.       }//-鈥
  283.  
  284.       // Attach the identity of this model (for convenience).
  285.       err.modelIdentity = modelIdentity;
  286.       return done(err);
  287.     }//-鈥
  288.  
  289.     return done(undefined, sum);
  290.  
  291.   });//</adapter.sum()>
  292.  
  293. };
  294.  
downloadsum.js Source code - Download waterline Source code
Related Source Codes/Software:
notepad-plus-plus - Notepad++ official repository h... 2017-01-10
che - Eclipse Che: Next-generation Eclipse IDE. Open sou... 2017-01-10
Gource - oftware version control visualization ... 2017-01-10
FDFullscreenPopGesture - A UINavigationController's category to enable full... 2017-01-10
node-style-guide - A guide for styling your node.js / JavaScript code... 2017-01-09
Workerman - An asynchronous event driven PHP framework for eas... 2017-01-10
structor - An advanced visual editor for React components ... 2017-01-10
golearn - Machine Learning for Go 2017-01-10
poisontap - Exploits locked/password protected computers over ... 2017-01-10
kcptun - A Simple UDP Tunnel Based On KCP 2017-01-11
CRYENGINE - CRYENGINE is a powerful real-time game development... 2017-06-11
postal - 2017-06-11
reactide - Reactide is the first dedicated IDE for React web ... 2017-06-11
rkt - rkt is a pod-native container engine for Linux. It... 2017-06-11
uWebSockets - Tiny WebSockets https://for... 2017-06-11
realworld - TodoMVC for the RealWorld - Exemplary fullstack Me... 2017-06-11
goreplay - GoReplay is an open-source tool for capturing and ... 2017-06-10
pyenv - Simple Python version management 2017-06-10
redux-saga - An alternative side effect model for Redux apps ... 2017-06-10
angular-starter - 2017-06-10

 Back to top