2019-10-09 21:35:13 +02:00
/* eslint no-useless-escape: 0*/
2019-07-30 09:35:42 +02:00
2018-11-20 00:42:21 +00:00
const { _ } = require ( 'lib/locale' ) ;
2017-06-23 22:32:24 +01:00
function dirname ( path ) {
if ( ! path ) throw new Error ( 'Path is empty' ) ;
2020-03-13 23:46:14 +00:00
const s = path . split ( /\/|\\/ ) ;
2017-06-23 22:32:24 +01:00
s . pop ( ) ;
return s . join ( '/' ) ;
}
2017-06-23 18:51:02 +00:00
function basename ( path ) {
if ( ! path ) throw new Error ( 'Path is empty' ) ;
2020-03-13 23:46:14 +00:00
const s = path . split ( /\/|\\/ ) ;
2017-06-23 18:51:02 +00:00
return s [ s . length - 1 ] ;
}
2018-11-20 00:42:21 +00:00
function filename ( path , includeDir = false ) {
2017-06-25 00:19:11 +01:00
if ( ! path ) throw new Error ( 'Path is empty' ) ;
2018-11-20 00:42:21 +00:00
let output = includeDir ? path : basename ( path ) ;
2017-06-25 00:19:11 +01:00
if ( output . indexOf ( '.' ) < 0 ) return output ;
output = output . split ( '.' ) ;
output . pop ( ) ;
return output . join ( '.' ) ;
}
2017-07-10 18:17:03 +00:00
function fileExtension ( path ) {
if ( ! path ) throw new Error ( 'Path is empty' ) ;
2020-03-13 23:46:14 +00:00
const output = path . split ( '.' ) ;
2017-07-10 18:17:03 +00:00
if ( output . length <= 1 ) return '' ;
return output [ output . length - 1 ] ;
}
2017-06-23 18:51:02 +00:00
function isHidden ( path ) {
2020-03-13 23:46:14 +00:00
const b = basename ( path ) ;
2019-09-19 22:51:18 +01:00
if ( ! b . length ) throw new Error ( ` Path empty or not a valid path: ${ path } ` ) ;
2017-06-23 18:51:02 +00:00
return b [ 0 ] === '.' ;
}
2019-06-12 09:45:31 +01:00
function safeFileExtension ( e , maxLength = null ) {
if ( maxLength === null ) maxLength = 8 ;
2017-12-01 23:15:49 +00:00
if ( ! e || ! e . replace ) return '' ;
2019-06-12 09:45:31 +01:00
return e . replace ( /[^a-zA-Z0-9]/g , '' ) . substr ( 0 , maxLength ) ;
2017-12-01 23:15:49 +00:00
}
2018-09-04 11:59:09 +01:00
function safeFilename ( e , maxLength = null , allowSpaces = false ) {
if ( maxLength === null ) maxLength = 32 ;
2018-05-23 14:25:59 +01:00
if ( ! e || ! e . replace ) return '' ;
2019-07-29 15:43:53 +02:00
const regex = allowSpaces ? /[^a-zA-Z0-9\-_\(\)\. ]/g : /[^a-zA-Z0-9\-_\(\)\.]/g ;
2020-03-13 23:46:14 +00:00
const output = e . replace ( regex , '_' ) ;
2018-05-23 14:25:59 +01:00
return output . substr ( 0 , maxLength ) ;
}
2018-11-20 00:42:21 +00:00
let friendlySafeFilename _blackListChars = '/<>:\'"\\|?*' ;
for ( let i = 0 ; i < 32 ; i ++ ) {
friendlySafeFilename _blackListChars += String . fromCharCode ( i ) ;
}
2019-07-29 15:43:53 +02:00
const friendlySafeFilename _blackListNames = [ '.' , '..' , 'CON' , 'PRN' , 'AUX' , 'NUL' , 'COM1' , 'COM2' , 'COM3' , 'COM4' , 'COM5' , 'COM6' , 'COM7' , 'COM8' , 'COM9' , 'LPT1' , 'LPT2' , 'LPT3' , 'LPT4' , 'LPT5' , 'LPT6' , 'LPT7' , 'LPT8' , 'LPT9' ] ;
2018-11-20 00:42:21 +00:00
function friendlySafeFilename ( e , maxLength = null ) {
if ( maxLength === null ) maxLength = 255 ;
if ( ! e || ! e . replace ) return _ ( 'Untitled' ) ;
2019-07-29 15:43:53 +02:00
2018-11-20 00:42:21 +00:00
let output = '' ;
for ( let i = 0 ; i < e . length ; i ++ ) {
const c = e [ i ] ;
if ( friendlySafeFilename _blackListChars . indexOf ( c ) >= 0 ) {
output += '_' ;
} else {
output += c ;
}
}
if ( output . length <= 4 ) {
if ( friendlySafeFilename _blackListNames . indexOf ( output . toUpperCase ( ) ) >= 0 ) {
output = '___' ;
}
}
while ( output . length ) {
const c = output [ output . length - 1 ] ;
if ( c === ' ' || c === '.' ) {
output = output . substr ( 0 , output . length - 1 ) ;
} else {
break ;
}
}
2018-11-21 00:36:23 +00:00
while ( output . length ) {
const c = output [ 0 ] ;
if ( c === ' ' ) {
output = output . substr ( 1 , output . length - 1 ) ;
} else {
break ;
}
}
2019-07-29 15:43:53 +02:00
if ( ! output ) return _ ( 'Untitled' ) ;
2018-11-20 00:42:21 +00:00
return output . substr ( 0 , maxLength ) ;
}
2019-07-29 12:16:47 +02:00
function toFileProtocolPath ( filePathEncode , os = null ) {
if ( os === null ) os = process . platform ;
2019-07-29 15:43:53 +02:00
2019-07-29 12:16:47 +02:00
if ( os === 'win32' ) {
filePathEncode = filePathEncode . replace ( /\\/g , '/' ) ; // replace backslash in windows pathname with slash e.g. c:\temp to c:/temp
2019-09-19 22:51:18 +01:00
filePathEncode = ` / ${ filePathEncode } ` ; // put slash in front of path to comply with windows fileURL syntax
2019-07-29 12:16:47 +02:00
}
filePathEncode = encodeURI ( filePathEncode ) ;
filePathEncode = filePathEncode . replace ( /\+/g , '%2B' ) ; // escape '+' with unicode
filePathEncode = filePathEncode . replace ( /%20/g , '+' ) ; // switch space (%20) with '+'. To comply with syntax used by joplin, see urldecode_(str) in MdToHtml.js
2019-09-19 22:51:18 +01:00
return ` file:// ${ filePathEncode . replace ( /\'/g , '%27' ) } ` ; // escape '(single quote) with unicode, to prevent crashing the html view
2019-04-20 21:12:19 +01:00
}
2018-05-14 18:46:04 +01:00
function toSystemSlashes ( path , os = null ) {
if ( os === null ) os = process . platform ;
2019-07-29 15:43:53 +02:00
if ( os === 'win32' ) return path . replace ( /\//g , '\\' ) ;
return path . replace ( /\\/g , '/' ) ;
2017-12-08 21:51:59 +00:00
}
2018-01-25 19:01:14 +00:00
function rtrimSlashes ( path ) {
2018-05-08 11:29:25 +01:00
return path . replace ( /[\/\\]+$/ , '' ) ;
2018-01-25 19:01:14 +00:00
}
function ltrimSlashes ( path ) {
return path . replace ( /^\/+/ , '' ) ;
}
2019-01-30 19:19:06 +00:00
function quotePath ( path ) {
if ( ! path ) return '' ;
if ( path . indexOf ( '"' ) < 0 && path . indexOf ( ' ' ) < 0 ) return path ;
path = path . replace ( /"/ , '\\"' ) ;
2019-09-19 22:51:18 +01:00
return ` " ${ path } " ` ;
2019-01-30 19:19:06 +00:00
}
function unquotePath ( path ) {
if ( ! path . length ) return '' ;
if ( path . length && path [ 0 ] === '"' ) {
path = path . substr ( 1 , path . length - 2 ) ;
}
path = path . replace ( /\\"/ , '"' ) ;
return path ;
}
function extractExecutablePath ( cmd ) {
if ( ! cmd . length ) return '' ;
2019-07-30 09:35:42 +02:00
const quoteType = [ '"' , '\'' ] . indexOf ( cmd [ 0 ] ) >= 0 ? cmd [ 0 ] : '' ;
2019-01-30 19:19:06 +00:00
let output = '' ;
for ( let i = 0 ; i < cmd . length ; i ++ ) {
const c = cmd [ i ] ;
if ( quoteType ) {
if ( i > 0 && c === quoteType ) {
output += c ;
break ;
}
} else {
if ( c === ' ' ) break ;
}
output += c ;
}
return output ;
}
2019-07-29 15:43:53 +02:00
module . exports = { toFileProtocolPath , extractExecutablePath , basename , dirname , filename , isHidden , fileExtension , safeFilename , friendlySafeFilename , safeFileExtension , toSystemSlashes , rtrimSlashes , ltrimSlashes , quotePath , unquotePath } ;