-
Notifications
You must be signed in to change notification settings - Fork 5
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
Smartypants plugin seems to be drastically slower #33
Comments
Perhaps some kind of "lite" option that just does the old behavior?
|
That could be a separate extension. Something like I think the best approach would be to make smartypants faster. |
Any update on this issue? I was about to update Marked (requiring this new extension) when I found this issue, so now I'm holding off until I know I'm not going to lose performance. |
I ended up making a "lite" version of this extension that didn't have such slowdown. I'll see if I can publish it as a package shortly. |
@sernaferna Try out this package: https://www.npmjs.com/package/marked-smartypants-lite |
Honestly, I'm going to leave it alone for now and leave marked at version 4.3.0. I don't like having an out of date package like that, but the whole "ecosystem" is a mess. It's not just smartypants, xhtml support has also been pulled into its own extension, which isn't playing nicely in TypeScript. (I could create my own definition file and probably get it working but... what problem would I find next?) When things have settled down and all of the extensions are working properly I'll look into this again. |
@sernaferna sticking with marked v4 should be fine, but if you are going to wait until marked doesn't have any more problems you are going to be waiting a long time (probably forever). Since marked is free open source software not backed by any company those problems only go away when someone who find a problem has enough ambition and free time to fix it. A better approach than waiting would be to contribute a fix for problems that you find. That would make the problems that you care about go away faster. (Like marked-xhtml working well with typescript) |
If I had the expertise I'd be happy to, but unfortunately I was leveraging this library because I don't have the expertise. I may have to move off of marked altogether at some point (maybe to PageDown?), and it's in my backlog to look into it, it just hasn't bubbled up to the top yet... |
No one has the expertise until they try 😁. The best thing about open source software is that you don't need expertise to try. |
A cursory look at the source code reveals that the smartypants library:
|
@webketje that would be a good list to post on the smartypants repo |
In a 5-page document, Markdown 4.3.0 with the smartypants option takes ~140 ms in my application to render the document.
In v5.0.4, switching to the
marked-smartypants
extension, parsing now takes ~307 ms. I.e., more than half of the parsing time is spent inside this plugin. This makes live-editing a document very laggy.Any ideas to speed this extension up? Performance profiling in Chrome show it is spending a lot of time in the
educateQuotes()
function, but in general the bulk of the processing is getting hung up on the manystr = str.replace(
functions:Of the ~167 ms slowdown I see:
educateQuotes()
educateDashesOldschool()
educateBackticks()
educateEllipses()
ProcessEscapes()
I realize this is just including the
smartyPants
package directly, so editing the code isn't really feasible, but it is so slow compared to the simpler Marked.js approach. With Marked.js 5 deprecating this feature natively, this extension is a bit overkill for the "high speed" goal of Marked.js.Thoughts?
The text was updated successfully, but these errors were encountered: