46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
'use strict';
 | 
						|
 | 
						|
// See http://www.robvanderwoude.com/escapechars.php
 | 
						|
const metaCharsRegExp = /([()\][%!^"`<>&|;, *?])/g;
 | 
						|
 | 
						|
function escapeCommand(arg) {
 | 
						|
    // Escape meta chars
 | 
						|
    arg = arg.replace(metaCharsRegExp, '^$1');
 | 
						|
 | 
						|
    return arg;
 | 
						|
}
 | 
						|
 | 
						|
function escapeArgument(arg, doubleEscapeMetaChars) {
 | 
						|
    // Convert to string
 | 
						|
    arg = `${arg}`;
 | 
						|
 | 
						|
    // Algorithm below is based on https://qntm.org/cmd
 | 
						|
 | 
						|
    // Sequence of backslashes followed by a double quote:
 | 
						|
    // double up all the backslashes and escape the double quote
 | 
						|
    arg = arg.replace(/(\\*)"/g, '$1$1\\"');
 | 
						|
 | 
						|
    // Sequence of backslashes followed by the end of the string
 | 
						|
    // (which will become a double quote later):
 | 
						|
    // double up all the backslashes
 | 
						|
    arg = arg.replace(/(\\*)$/, '$1$1');
 | 
						|
 | 
						|
    // All other backslashes occur literally
 | 
						|
 | 
						|
    // Quote the whole thing:
 | 
						|
    arg = `"${arg}"`;
 | 
						|
 | 
						|
    // Escape meta chars
 | 
						|
    arg = arg.replace(metaCharsRegExp, '^$1');
 | 
						|
 | 
						|
    // Double escape meta chars if necessary
 | 
						|
    if (doubleEscapeMetaChars) {
 | 
						|
        arg = arg.replace(metaCharsRegExp, '^$1');
 | 
						|
    }
 | 
						|
 | 
						|
    return arg;
 | 
						|
}
 | 
						|
 | 
						|
module.exports.command = escapeCommand;
 | 
						|
module.exports.argument = escapeArgument;
 |