Skip to content

Commit

Permalink
indentation
Browse files Browse the repository at this point in the history
  • Loading branch information
mansurt committed Apr 26, 2017
1 parent 9a02e81 commit a46e6bf
Show file tree
Hide file tree
Showing 2 changed files with 137 additions and 139 deletions.
272 changes: 135 additions & 137 deletions lib/list.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
'use strict';
var path = require('path');
var when = require('when');

var u = {
run: require('../util/run'),
switches: require('../util/switches')
run: require('../util/run'),
switches: require('../util/switches')
};

/**
Expand All @@ -18,128 +17,127 @@ var u = {
*/
module.exports = function(archive, options, filesRequiredFields) {
return when.promise(function(resolve, reject, progress) {
var spec = {};
/* jshint maxlen: 130 */
var regex = /(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) ([\.DA]+)\s+(\d+)\s*(?:\d+)\s+(\S+?\.\S+)/;
/* jshint maxlen: 80 */

// Create a string that can be parsed by `run`.
var command = '7z l "' + archive + '" ';

var buffer = ""; //Store imcomplete line of a progress data.
// Start the command
u.run(command, options)

// When a stdout is emitted, parse each line and search for a pattern. When
// the pattern is found, extract the file (or directory) name from it and
// pass it to an array. Finally returns this array.
.progress(function(data) {
var entries = [];

// Last progress had an incomplete line. Prepend it to the data and clear
// buffer.
if (buffer.length > 0) {
data = buffer + data;
buffer = "";
}

if (options && options.slt) {
try {
let retval = parseSltOutput(data, filesRequiredFields);
return resolve(retval);
}
catch(err) {
return reject(retval);
};
}

data.split('\n').forEach(function(line) {
// Populate the tech specs of the archive that are passed to the
// resolve handler.
if (line.substr(0, 7) === 'Path = ') {
if (isRequiredProperty(filesRequiredFields, 'Path')) {
spec.path = line.substr(7, line.length);
}
} else if (line.substr(0, 7) === 'Type = ') {
if (isRequiredProperty(filesRequiredFields, 'Type')) {
spec.type = line.substr(7, line.length);
}
} else if (line.substr(0, 9) === 'Method = ') {
if (isRequiredProperty(filesRequiredFields, 'Method')) {
spec.method = line.substr(9, line.length);
}
} else if (line.substr(0, 16) === 'Physical Size = ') {
if (isRequiredProperty(filesRequiredFields, 'Physical Size')) {
spec.physicalSize = parseInt(line.substr(16, line.length), 10);
}
} else if (line.substr(0, 15) === 'Headers Size = ') {
if (isRequiredProperty(filesRequiredFields, 'Headers Size')) {
spec.headersSize = parseInt(line.substr(15, line.length), 10);
}
} else if (line.substr(0, 12) === 'Encrypted = ') {
if (isRequiredProperty(filesRequiredFields, 'Encrypted')) {
pec.encrypted = line.substr(12, line.length);
}
} else {
// Parse the stdout to find entries
var res = regex.exec(line);
if (res) {
if (parseInt(res[1])) {
var return_date = new Date(res[1]);
} else {
var return_date = null;
}

var e = {
date: return_date,
attr: res[2],
size: parseInt(res[3], 10),
name: res[5].replace(path.sep, '/')
};

entries.push(e);
}

// Line may be incomplete, Save it to the buffer.
else buffer = line;

}
});
return progress(entries);
})

var spec = {};
/* jshint maxlen: 130 */
var regex = /(\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) ([\.DA]+)\s+(\d+)\s*(?:\d+)\s+(\S+?\.\S+)/;
/* jshint maxlen: 80 */

// Create a string that can be parsed by `run`.
var command = '7z l "' + archive + '" ';

var buffer = ""; //Store imcomplete line of a progress data.
// Start the command
u.run(command, options)

// When a stdout is emitted, parse each line and search for a pattern. When
// the pattern is found, extract the file (or directory) name from it and
// pass it to an array. Finally returns this array.
.progress(function(data) {
var entries = [];

// Last progress had an incomplete line. Prepend it to the data and clear
// buffer.
if (buffer.length > 0) {
data = buffer + data;
buffer = "";
}

if (options && options.slt) {
try {
let retval = parseSltOutput(data, filesRequiredFields);
return resolve(retval);
}
catch(err) {
return reject(retval);
};
}

data.split('\n').forEach(function(line) {
// Populate the tech specs of the archive that are passed to the
// resolve handler.
if (line.substr(0, 7) === 'Path = ') {
if (isRequiredProperty(filesRequiredFields, 'Path')) {
spec.path = line.substr(7, line.length);
}
} else if (line.substr(0, 7) === 'Type = ') {
if (isRequiredProperty(filesRequiredFields, 'Type')) {
spec.type = line.substr(7, line.length);
}
} else if (line.substr(0, 9) === 'Method = ') {
if (isRequiredProperty(filesRequiredFields, 'Method')) {
spec.method = line.substr(9, line.length);
}
} else if (line.substr(0, 16) === 'Physical Size = ') {
if (isRequiredProperty(filesRequiredFields, 'Physical Size')) {
spec.physicalSize = parseInt(line.substr(16, line.length), 10);
}
} else if (line.substr(0, 15) === 'Headers Size = ') {
if (isRequiredProperty(filesRequiredFields, 'Headers Size')) {
spec.headersSize = parseInt(line.substr(15, line.length), 10);
}
} else if (line.substr(0, 12) === 'Encrypted = ') {
if (isRequiredProperty(filesRequiredFields, 'Encrypted')) {
spec.encrypted = line.substr(12, line.length);
}
} else {
// Parse the stdout to find entries
var res = regex.exec(line);
if (res) {
if (parseInt(res[1])) {
var return_date = new Date(res[1]);
} else {
var return_date = null;
}

var e = {
date: return_date,
attr: res[2],
size: parseInt(res[3], 10),
name: res[5].replace(path.sep, '/')
};

entries.push(e);
}

// Line may be incomplete, Save it to the buffer.
else buffer = line;

}
});
return progress(entries);
})

// When all is done resolve the Promise.
.then(function() {
return resolve(spec);
})

// Catch the error and pass it to the reject function of the Promise.
.catch(function(err) {
return reject(err);
});
// When all is done resolve the Promise.
.then(function() {
return resolve(spec);
})

// Catch the error and pass it to the reject function of the Promise.
.catch(function(err) {
return reject(err);
});

});
};

function isRequiredProperty(requiredPropertyArr, name) {
return !requiredPropertyArr || (requiredPropertyArr.indexOf(name) >= 0);
return !requiredPropertyArr || (requiredPropertyArr.indexOf(name) >= 0);
}

const propertyDelim = ' = ';

function parseProperty(data, propObj, requiredPropertyArr) {
let pos = data.indexOf(propertyDelim);
let pos = data.indexOf(propertyDelim);

if (pos === -1) {
return;
}
if (pos === -1) {
return;
}

let key = data.substring(0, pos);
let value = data.substring(pos + propertyDelim.length, data.length);
if (isRequiredProperty(requiredPropertyArr, key)) {
propObj[key] = value;
}
let key = data.substring(0, pos);
let value = data.substring(pos + propertyDelim.length, data.length);
if (isRequiredProperty(requiredPropertyArr, key)) {
propObj[key] = value;
}
};

const metaBegining = '--';
Expand Down Expand Up @@ -188,36 +186,36 @@ const fileDelim = '';
* Block = 0
*/
function parseSltOutput(data, filesRequiredFields) {
let lines = data.split('\n');
let retval = {metaData: {}, files: []};
let lines = data.split('\n');
let retval = {metaData: {}, files: []};

let i = lines.indexOf(metaBegining);
if (i < 0) {
throw new Error('Invalid data ' + JSON.stringify(data));
}

for (i = i + 1; i < lines.length && lines[i] !== metaDataDelim; i++) {
if (lines[i].length === 0) {
continue;
}
let i = lines.indexOf(metaBegining);
if (i < 0) {
throw new Error('Invalid data ' + JSON.stringify(data));
}

parseProperty(lines[i], retval.metaData, null /* shouldn't filter metaData properties */);
for (i = i + 1; i < lines.length && lines[i] !== metaDataDelim; i++) {
if (lines[i].length === 0) {
continue;
}

i++; //for metaDataDelim
parseProperty(lines[i], retval.metaData, null /* shouldn't filter metaData properties */);
}

//parse files
for (; i < lines.length; i++) {
if (!lines[i].length) {
continue;
}
let file = {};
for (; i < lines.length && lines[i] !== fileDelim; i++) {
parseProperty(lines[i], file, filesRequiredFields);
}
i++; //for metaDataDelim

retval.files.push(file);
//parse files
for (; i < lines.length; i++) {
if (!lines[i].length) {
continue;
}
let file = {};
for (; i < lines.length && lines[i] !== fileDelim; i++) {
parseProperty(lines[i], file, filesRequiredFields);
}

return retval;
};
retval.files.push(file);
}

return retval;
};
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@
},
"homepage": "https://github.com/quentinrossetti/node-7zip.git",
"dependencies": {
"cross-spawn": "^5.1.0",
"when": "^3.7.8"
"when": "^3.7.8",
"cross-spawn": "^5.1.0"
},
"devDependencies": {
"chai": "^3.5.0",
Expand Down

0 comments on commit a46e6bf

Please sign in to comment.