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' ) ;
2017-11-10 22:18:00 +00:00
let 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' ) ;
2017-11-10 22:18:00 +00:00
let 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' ) ;
let output = path . split ( '.' ) ;
if ( output . length <= 1 ) return '' ;
return output [ output . length - 1 ] ;
}
2017-06-23 18:51:02 +00:00
function isHidden ( path ) {
let b = basename ( path ) ;
if ( ! b . length ) throw new Error ( 'Path empty or not a valid path: ' + path ) ;
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 '' ;
2018-09-04 11:59:09 +01:00
const regex = allowSpaces ? /[^a-zA-Z0-9\-_\(\)\. ]/g : /[^a-zA-Z0-9\-_\(\)\.]/g
let 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 ) ;
}
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" ] ;
function friendlySafeFilename ( e , maxLength = null ) {
if ( maxLength === null ) maxLength = 255 ;
if ( ! e || ! e . replace ) return _ ( 'Untitled' ) ;
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 ;
}
}
2018-11-20 00:42:21 +00:00
if ( ! output ) return _ ( 'Untitled' ) ;
return output . substr ( 0 , maxLength ) ;
}
2019-07-29 12:16:47 +02:00
function toFileProtocolPath ( filePathEncode , os = null ) {
if ( os === null ) os = process . platform ;
if ( os === 'win32' ) {
filePathEncode = filePathEncode . replace ( /\\/g , '/' ) ; // replace backslash in windows pathname with slash e.g. c:\temp to c:/temp
filePathEncode = "/" + filePathEncode ; // put slash in front of path to comply with windows fileURL syntax
}
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
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 ;
2017-12-08 21:51:59 +00:00
if ( os === 'win32' ) return path . replace ( /\//g , "\\" ) ;
return path . replace ( /\\/g , "/" ) ;
}
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 ( /"/ , '\\"' ) ;
return '"' + path + '"' ;
}
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 '' ;
const quoteType = [ '"' , "'" ] . indexOf ( cmd [ 0 ] ) >= 0 ? cmd [ 0 ] : '' ;
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-04-20 21:12:19 +01:00
module . exports = { toFileProtocolPath , extractExecutablePath , basename , dirname , filename , isHidden , fileExtension , safeFilename , friendlySafeFilename , safeFileExtension , toSystemSlashes , rtrimSlashes , ltrimSlashes , quotePath , unquotePath } ;