Skip to content

Conversation

@wanling0000
Copy link
Collaborator

@wanling0000 wanling0000 commented Mar 23, 2025

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 class LinkedFileHandler calls FileUtil.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_.pdf

  • To 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:

  • Input title: Building \mkbibquote{Community}
  • File pattern: [bibtexkey] - [fulltitle]
  • Old output: BrayBuildingCommunity - Building mkbibquote_Community.pdf
  • New output: BrayBuildingCommunity - Building Community.pdf

Mandatory checks

  • I own the copyright of the code submitted and I license it under the MIT license
  • Change in CHANGELOG.md described in a way that is understandable for the average user (if change is visible to the user)
  • Tests created for changes (if applicable)
  • Manually tested changed features in running JabRef (always required)
  • [/] Screenshots added in PR description (if change is visible to the user)
  • [/] Checked developer's documentation: Is the information available and up to date? If not, I outlined it in this pull request.
  • [/] Checked documentation: Is the information available and up to date? If not, I created an issue at https://github.com/JabRef/user-documentation/issues or, even better, I submitted a pull request to the documentation repository.

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
@wanling0000 wanling0000 marked this pull request as draft March 23, 2025 02:37
@wanling0000 wanling0000 marked this pull request as ready for review March 23, 2025 13:20
@wanling0000
Copy link
Collaborator Author

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!

Copy link
Member

@koppor koppor left a 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);
Copy link
Member

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.

Comment on lines 158 to 160
BibEntry entry = new BibEntry();
entry.setCitationKey("BrayBuildingCommunity");
entry.setField(StandardField.TITLE, "Building \\mkbibquote{Community}");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Chain - .withCitationKey and .withField.

@koppor koppor enabled auto-merge March 23, 2025 19:14
auto-merge was automatically disabled March 24, 2025 15:18

Head branch was pushed to by a user without write access

Comment on lines +335 to +336
// Remove LaTeX commands (e.g., \mkbibquote{}) from expanded fields before cleaning filename
// See: https://github.com/JabRef/jabref/issues/12188
Copy link

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.

Copy link
Collaborator Author

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

@wanling0000 wanling0000 requested a review from koppor March 24, 2025 15:29
@koppor koppor added this pull request to the merge queue Mar 25, 2025
Merged via the queue into JabRef:main with commit 1e997b7 Mar 25, 2025
1 check passed
GuilhermeRibeiroPereira pushed a commit to GuilhermeRibeiroPereira/jabref that referenced this pull request Apr 1, 2025
…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
krishnagjsForGit pushed a commit to krishnagjsForGit/jabref that referenced this pull request May 2, 2025
…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
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Sanitization of generated filenames (remove LaTeX commands)

3 participants