-
Notifications
You must be signed in to change notification settings - Fork 139
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
StringLiteral.getLiteralValue
is not thread-safe
#3424
Comments
Please paste the Exception Stacktrace and why it is used in multiple threads |
Example stack traces can be found here: spring-projects/sts4#1434 - but this comes from the Spring Tools using JDT Core to parse and analyze source code, so the stack traces have no origins in JDT or Eclipse itself. We use the AST over there to implement content-assist, do additional validations, and extract index information from a Spring perspective. |
That reference only shows a IllegalArgumentException, not a IllegalStateException , also the line number does not match master. I don't see a connection to concurrent use. You should be able to set a breakpoint to find the sourcecode in question that cannot be parsed. |
You are right, my bad, it is an
I am not yet convinced about this not being related to concurrent use, but let me try to dig deeper here. Always hard to reproduce those things, but let me see what I can find out with our hints here. Thanks so much for looking into this so quickly and for providing the feedback here. |
This issue still has not enough information to process. |
@jukzi I am on it and will provide more details / information as soon as possible... :-) |
I created a code snippet to reproduce this issue with concurrent calls to
This should result in a few exceptions being thrown due to issues within Looking at the implementation of |
org.eclipse.jdt.core.dom.StringLiteral.getLiteralValue() unsynchronized use of shared org.eclipse.jdt.core.dom.AST.scanner reproducer for eclipse-jdt#3424
was already reported in https://bugs.eclipse.org/bugs/show_bug.cgi?id=508586 |
as per https://bugs.eclipse.org/bugs/show_bug.cgi?id=508586#c14 the scanner should be cloned. @martinlippert can you contribute a fix? |
…ance StringLiteral.getLiteralValue and CharacterLiteral.charValue need to use their own local scanner instances in order to avoid issues when used concurrently Fixes eclipse-jdt#3424
…ance StringLiteral.getLiteralValue and CharacterLiteral.charValue need to use their own local scanner instances in order to avoid issues when used concurrently Fixes eclipse-jdt#3424
It looks like
StringLiteral.getLiteralValue
is throwingIllegalStateExceptions
in some cases when used from multiple threads, most likely due to the internal scanner object being used in a stateful way.The text was updated successfully, but these errors were encountered: