SwiftLinkPreview icon indicating copy to clipboard operation
SwiftLinkPreview copied to clipboard

Attempting to preview certain links will leave the previewer Regex running and unable to cancel

Open pocketlim opened this issue 4 years ago • 5 comments

Hey Leonardo Cardoso! Just wanted to say big thank you to a cool little kit of code making it really easy to get a preview of a URL! ❤️

Certain links, however, will cause the previewer to get down to the Regex.pregMatchAll() method and there it will churn pretty much indefinitely, tasking one of the cores to maximum. Because it's already beyond the request part, it's unable to be cancelled at that point. It will continue to task the CPU as you navigate around the app, but at least it stops when the app is backgrounded.

Example URL: https://news.ycombinator.com/item?id=22598009

Screen Shot 2020-03-16 at 8 54 43 PM

Would you have any suggestion on how to handle a case like this, or a way/means to cancel the churning after a specific amount of time has passed?

For now, I will try and collect bad URLs and just avoid sending them to the previewer

Here's a sample project to test with:

LinkPreviewHighCPUStuck-CancelAdded.zip

(Edit: Updated with a version that doesn't use a cache, and with cancel button) I know, it's crude, but it tests one working link preview and the bad link.

Xcode: 11.3.1 iOS targeted: 11.x, 12.x, 13.x Stack trace and time graph shown above

Let me know if you'd like any more help.

pocketlim avatar Mar 17 '20 05:03 pocketlim

@pocketlim is this still an issue or have you found a way to fix it?

inPhilly avatar Jun 24 '20 03:06 inPhilly

Unfortunately, no, it is still happening as far as I know. I am blacklisting the URLs that I found that aren't working or that cause issues so far.

pocketlim avatar Jun 24 '20 20:06 pocketlim

Thanks for the detailed report. I will add it to investigation needed.

LeonardoCardoso avatar Feb 01 '21 11:02 LeonardoCardoso

I'm facing this, it's still an issue.

huanghui1998hhh avatar Dec 24 '21 05:12 huanghui1998hhh