Skip to content

Commit

Permalink
Fix for #219 - Folder path separators are incorrectly replaced (#224)
Browse files Browse the repository at this point in the history
* Add separate illegal char regex for folders

* Fix correct folder path separators being replaced

Issue #219
  • Loading branch information
Tesselay authored Apr 18, 2024
1 parent c0ff468 commit d27e7bb
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 23 deletions.
34 changes: 17 additions & 17 deletions src/__tests__/path_validation.spec.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import * as fs from 'fs'
import {
ILLEGAL_CHAR_REGEX,
replaceIllegalChars,
ILLEGAL_CHAR_REGEX_FILE,
replaceIllegalCharsFile,
REPLACEMENT_CHAR,
} from '../util'

Expand All @@ -22,56 +22,56 @@ const expectedManualIllegalChars: string[] = [
// ZERO WIDTH JOINER and SOFT HYPHEN
const expectedInvisibleChars: string[] = ['­', '‍']

describe('replaceIllegalChars() removes all expected characters', () => {
describe('replaceIllegalCharsFile() removes all expected characters', () => {
test.each(expectedManualIllegalChars)(
'Illegal character "%s" is removed',
(character) => {
const input = `this${character}string`
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).not.toContain(character)
},
)
})

describe('replaceIllegalChars() function replaces illegal characters with replacement char', () => {
describe('replaceIllegalCharsFile() function replaces illegal characters with replacement char', () => {
test.each(expectedManualIllegalChars)(
"Illegal character '%s' is replaced",
(char) => {
const input = `this${char}string`
const expectedOutput = `this${REPLACEMENT_CHAR}string`
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).toEqual(expectedOutput)
},
)
})

describe('replaceIllegalChars() function does not modify string without illegal characters', () => {
describe('replaceIllegalCharsFile() function does not modify string without illegal characters', () => {
test.each(['this_is_a_valid_string', 'this is a valid string'])(
"String '%s' is not modified",
(input) => {
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).toEqual(input)
},
)
})

describe('replaceIllegalChars() function handles empty string', () => {
describe('replaceIllegalCharsFile() function handles empty string', () => {
test('Empty string is not modified', () => {
const input = ''
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).toEqual(input)
})
})

describe('replaceIllegalChars() function replaces all occurrences of illegal characters', () => {
describe('replaceIllegalCharsFile() function replaces all occurrences of illegal characters', () => {
test.each(expectedManualIllegalChars)(
"Illegal character '%s' is replaced",
(char) => {
const input = `${char}foo${char}bar`
const expectedOutput = `${REPLACEMENT_CHAR}foo${REPLACEMENT_CHAR}bar`
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).toEqual(expectedOutput)
expect(output.match(ILLEGAL_CHAR_REGEX)).toBeNull()
expect(output.match(ILLEGAL_CHAR_REGEX_FILE)).toBeNull()
},
)
})
Expand All @@ -82,7 +82,7 @@ describe('file system behavior with non-alphanumeric characters not in the illeg
(_, i) => String.fromCharCode(i + 32),
)
.filter((char) => !/^[a-zA-Z0-9]+$/.test(char))
.map(replaceIllegalChars)
.map(replaceIllegalCharsFile)

test.each(nonAlphanumericCharactersWithoutIllegal)(
"File system allows creation of file with character '%s'",
Expand All @@ -101,15 +101,15 @@ describe('file system behavior with non-alphanumeric characters not in the illeg
)
})

describe('replaceIllegalChars() function removes all occurrences of invisible characters', () => {
describe('replaceIllegalCharsFile() function removes all occurrences of invisible characters', () => {
test.each(expectedInvisibleChars)(
"Invisible character '%s' is replaced",
(char) => {
const input = `${char}foo${char}bar`
const expectedOutput = 'foobar'
const output = replaceIllegalChars(input)
const output = replaceIllegalCharsFile(input)
expect(output).toEqual(expectedOutput)
expect(output.match(ILLEGAL_CHAR_REGEX)).toBeNull()
expect(output.match(ILLEGAL_CHAR_REGEX_FILE)).toBeNull()
},
)
})
7 changes: 4 additions & 3 deletions src/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ import {
parseDateTime,
parseFrontMatterFromContent,
removeFrontMatterFromContent,
replaceIllegalChars,
replaceIllegalCharsFile,
replaceIllegalCharsFolder,
setOrUpdateHighlightColors,
} from './util'
import { OmnivoreSettingTab } from './settingsTab'
Expand Down Expand Up @@ -247,7 +248,7 @@ export default class OmnivorePlugin extends Plugin {
)

for (const item of items) {
const folderName = replaceIllegalChars(
const folderName = replaceIllegalCharsFolder(
normalizePath(render(item, folder, this.settings.folderDateFormat)),
)
const omnivoreFolder =
Expand All @@ -274,7 +275,7 @@ export default class OmnivorePlugin extends Plugin {
fileAttachment,
)
// use the custom filename
const customFilename = replaceIllegalChars(
const customFilename = replaceIllegalCharsFile(
renderFilename(item, filename, this.settings.filenameDateFormat),
)
const pageName = `${folderName}/${customFilename}.md`
Expand Down
11 changes: 8 additions & 3 deletions src/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@ export const REPLACEMENT_CHAR = '-'
// On Unix-like systems / is reserved and <>:"/\|?* as well as non-printable characters \u0000-\u001F on Windows
// credit: https://github.com/sindresorhus/filename-reserved-regex
// eslint-disable-next-line no-control-regex
export const ILLEGAL_CHAR_REGEX = /[<>:"/\\|?*\u0000-\u001F]/g
export const ILLEGAL_CHAR_REGEX_FILE = /[<>:"/\\|?*\u0000-\u001F]/g
export const ILLEGAL_CHAR_REGEX_FOLDER = /[<>"\\|?*\u0000-\u001F]/g

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 18.x)

Unexpected control character(s) in regular expression: \x00, \x1f

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 20.x)

Unexpected control character(s) in regular expression: \x00, \x1f

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 18.x)

Unexpected control character(s) in regular expression: \x00, \x1f

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 20.x)

Unexpected control character(s) in regular expression: \x00, \x1f

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 18.x)

Unexpected control character(s) in regular expression: \x00, \x1f

Check failure on line 16 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 20.x)

Unexpected control character(s) in regular expression: \x00, \x1f

export interface HighlightPoint {
left: number
Expand Down Expand Up @@ -103,8 +104,12 @@ export const unicodeSlug = (str: string, savedAt: string) => {
)
}

export const replaceIllegalChars = (str: string): string => {
return removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX, REPLACEMENT_CHAR))
export const replaceIllegalCharsFile = (str: string): string => {
return removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FILE, REPLACEMENT_CHAR))

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 18.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),⏎··`

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 20.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),⏎··`

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 18.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),⏎··`

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 20.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),⏎··`

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 18.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `␍⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),␍⏎··`

Check failure on line 108 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 20.x)

Replace `str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR)` with `␍⏎····str.replace(ILLEGAL_CHAR_REGEX_FILE,·REPLACEMENT_CHAR),␍⏎··`
}

export const replaceIllegalCharsFolder = (str: string): string => {
return removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER, REPLACEMENT_CHAR))

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 18.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),⏎··`

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (ubuntu-latest, 20.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),⏎··`

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 18.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),⏎··`

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (macos-latest, 20.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),⏎··`

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 18.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(␍⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),␍⏎··`

Check failure on line 112 in src/util.ts

View workflow job for this annotation

GitHub Actions / build (windows-latest, 20.x)

Replace `↹return·removeInvisibleChars(str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR)` with `··return·removeInvisibleChars(␍⏎····str.replace(ILLEGAL_CHAR_REGEX_FOLDER,·REPLACEMENT_CHAR),␍⏎··`
}

export function formatDate(date: string, format: string): string {
Expand Down

0 comments on commit d27e7bb

Please sign in to comment.