| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | 
							- 'use strict';
 
- /**
 
-  * Parse the content of a passwd file into a list of user objects.
 
-  * This function ignores blank lines and comments.
 
-  *
 
-  * ```js
 
-  * // assuming '/etc/passwd' contains:
 
-  * // doowb:*:123:123:Brian Woodward:/Users/doowb:/bin/bash
 
-  * console.log(parse(fs.readFileSync('/etc/passwd', 'utf8')));
 
-  *
 
-  * //=> [
 
-  * //=>   {
 
-  * //=>     username: 'doowb',
 
-  * //=>     password: '*',
 
-  * //=>     uid: '123',
 
-  * //=>     gid: '123',
 
-  * //=>     gecos: 'Brian Woodward',
 
-  * //=>     homedir: '/Users/doowb',
 
-  * //=>     shell: '/bin/bash'
 
-  * //=>   }
 
-  * //=> ]
 
-  * ```
 
-  * @param  {String} `content` Content of a passwd file to parse.
 
-  * @return {Array} Array of user objects parsed from the content.
 
-  * @api public
 
-  */
 
- module.exports = function(content) {
 
-   if (typeof content !== 'string') {
 
-     throw new Error('expected a string');
 
-   }
 
-   return content
 
-     .split('\n')
 
-     .map(user)
 
-     .filter(Boolean);
 
- };
 
- function user(line, i) {
 
-   if (!line || !line.length || line.charAt(0) === '#') {
 
-     return null;
 
-   }
 
-   // see https://en.wikipedia.org/wiki/Passwd for field descriptions
 
-   var fields = line.split(':');
 
-   return {
 
-     username: fields[0],
 
-     password: fields[1],
 
-     uid: fields[2],
 
-     gid: fields[3],
 
-     // see https://en.wikipedia.org/wiki/Gecos_field for GECOS field descriptions
 
-     gecos: fields[4],
 
-     homedir: fields[5],
 
-     shell: fields[6]
 
-   };
 
- }
 
 
  |