l0bsterssg

node.js static responsive blog post generator
Log | Files | Refs | README

group.js (2330B)


      1 /** internal
      2  * class ArgumentGroup
      3  *
      4  * Group arguments.
      5  * By default, ArgumentParser groups command-line arguments
      6  * into “positional arguments” and “optional arguments”
      7  * when displaying help messages. When there is a better
      8  * conceptual grouping of arguments than this default one,
      9  * appropriate groups can be created using the addArgumentGroup() method
     10  *
     11  * This class inherited from [[ArgumentContainer]]
     12  **/
     13 'use strict';
     14 
     15 var util = require('util');
     16 
     17 var ActionContainer = require('../action_container');
     18 
     19 
     20 /**
     21  * new ArgumentGroup(container, options)
     22  * - container (object): main container
     23  * - options (object): hash of group options
     24  *
     25  * #### options
     26  * - **prefixChars**  group name prefix
     27  * - **argumentDefault**  default argument value
     28  * - **title**  group title
     29  * - **description** group description
     30  *
     31  **/
     32 var ArgumentGroup = module.exports = function ArgumentGroup(container, options) {
     33 
     34   options = options || {};
     35 
     36   // add any missing keyword arguments by checking the container
     37   options.conflictHandler = (options.conflictHandler || container.conflictHandler);
     38   options.prefixChars = (options.prefixChars || container.prefixChars);
     39   options.argumentDefault = (options.argumentDefault || container.argumentDefault);
     40 
     41   ActionContainer.call(this, options);
     42 
     43   // group attributes
     44   this.title = options.title;
     45   this._groupActions = [];
     46 
     47   // share most attributes with the container
     48   this._container = container;
     49   this._registries = container._registries;
     50   this._actions = container._actions;
     51   this._optionStringActions = container._optionStringActions;
     52   this._defaults = container._defaults;
     53   this._hasNegativeNumberOptionals = container._hasNegativeNumberOptionals;
     54   this._mutuallyExclusiveGroups = container._mutuallyExclusiveGroups;
     55 };
     56 util.inherits(ArgumentGroup, ActionContainer);
     57 
     58 
     59 ArgumentGroup.prototype._addAction = function (action) {
     60   // Parent add action
     61   action = ActionContainer.prototype._addAction.call(this, action);
     62   this._groupActions.push(action);
     63   return action;
     64 };
     65 
     66 
     67 ArgumentGroup.prototype._removeAction = function (action) {
     68   // Parent remove action
     69   ActionContainer.prototype._removeAction.call(this, action);
     70   var actionIndex = this._groupActions.indexOf(action);
     71   if (actionIndex >= 0) {
     72     this._groupActions.splice(actionIndex, 1);
     73   }
     74 };
     75