- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 3k
Fix for issue: Sanitization of generated filenames (remove LaTeX commands) #12188 #12802
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
This fixes an issue where LaTeX commands (e.g., \mkbibquote{...}) were retained in generated filenames using the [fulltitle] pattern.
- Added RemoveLatexCommandsFormatter to createFileNameFromPattern
- Added test case to FileUtilTest to validate filename sanitization
    | Hi @koppor, I’ve just submitted PR #12802 to address issue #12188. This is my first time contributing to an open source project, and I tried my best to understand the issue description, the project structure, and the coding style, but please let me know if I’ve misunderstood anything. I’d really really appreciate it if you could take a look when you get the chance since your feedback would help me learn and improve. Thanks a lot! | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The solution is that what I had in mind. Thank you for that!
Just a nitpick
|  | ||
| // Remove LaTeX commands (e.g., \mkbibquote{}) from expanded fields before cleaning filename | ||
| // See: https://github.com/JabRef/jabref/issues/12188 | ||
| targetName = new RemoveLatexCommandsFormatter().format(targetName); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please make this a class constant (private static final ...). This saves some time when executing this (we use this pattern in other places in JabRef)
Keep the empty line before.
| BibEntry entry = new BibEntry(); | ||
| entry.setCitationKey("BrayBuildingCommunity"); | ||
| entry.setField(StandardField.TITLE, "Building \\mkbibquote{Community}"); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Chain - .withCitationKey and .withField.
Head branch was pushed to by a user without write access
| // Remove LaTeX commands (e.g., \mkbibquote{}) from expanded fields before cleaning filename | ||
| // See: https://github.com/JabRef/jabref/issues/12188 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Comment should be in JavaDoc format since it explains the method's behavior. Regular comments should not be used for method documentation according to best practices.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This comment is inside a method, so I kept it as a regular inline one
…ands) JabRef#12188 (JabRef#12802) * Fix JabRef#12188: Remove LaTeX commands from generated filenames This fixes an issue where LaTeX commands (e.g., \mkbibquote{...}) were retained in generated filenames using the [fulltitle] pattern. - Added RemoveLatexCommandsFormatter to createFileNameFromPattern - Added test case to FileUtilTest to validate filename sanitization * Change in described * Change in CHANGELOG.md: describe LaTeX filename cleanup (Closes JabRef#12188) * Fix test case style and markdown format in CHANGELOG * Refactor: use class constant and method chaining
…ands) JabRef#12188 (JabRef#12802) * Fix JabRef#12188: Remove LaTeX commands from generated filenames This fixes an issue where LaTeX commands (e.g., \mkbibquote{...}) were retained in generated filenames using the [fulltitle] pattern. - Added RemoveLatexCommandsFormatter to createFileNameFromPattern - Added test case to FileUtilTest to validate filename sanitization * Change in described * Change in CHANGELOG.md: describe LaTeX filename cleanup (Closes JabRef#12188) * Fix test case style and markdown format in CHANGELOG * Refactor: use class constant and method chaining
Closes #12188
This fixes an issue where LaTeX commands (e.g., \mkbibquote{...}) were retained in generated filenames using the [fulltitle] pattern.
Describe the changes you have made here: what, where, why, ...
When the filename pattern is set to
[bibtexkey] - [fulltitle], and linked files are renamed automatically (e.g., during PDF import or when using "Rename file to pattern"), the classLinkedFileHandlercallsFileUtil.createFileNameFromPattern()to generate the new filename.Previously, this method only applied
FileNameCleaner.cleanFileName(targetName), which removes illegal characters, but does not strip LaTeX commands such as\mkbibquote{}. This led to filenames like:BrayBuildingCommunity - Building _mkbibquote_Community_.pdfTo fix this, I added a call to
RemoveLatexCommandsFormatter.format()before cleaning the filename. This ensures LaTeX commands are properly stripped, while keeping their inner content.Example:
Mandatory checks
CHANGELOG.mddescribed in a way that is understandable for the average user (if change is visible to the user)