|
Rank: Newbie Groups: Member
Joined: 3/1/2014 Posts: 5
|
Hi
I am using the Web-browser version 3.0.38 and in the documentation there is a line about dead lock situation So Can u explain little more by means of a example (Inside the event handler of certain WebView events. Calling Eval Script is not allowed in these handlers because it can potentially causes deadlock in the browser engine)
Regards, Sarath
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
Hi,
The design goal is that whenever a deadlock can could potential occur, EO.WebBrowser will throw an exception or fail the call instead of allowing your code to proceed and fall into a deadlock. For example, say you handle WebView's BeforeNavigate event and you call EvalScript inside this event. If we were to allow this then this is what will happen:
1. The browser engine starts to load a page, but before it starts loading, it calls your BeforeNavigate event handler. The browser will not proceed to load the page unless you return from that handler because in your handler you can cancel the request. So the browser engine must hear from you first in order to decide whether it needs to continue load the page or not; 2. Now in your handler you call EvalScript. EvalScript must wait for the page starting loading (in order to have window and document object). However since you are inside BeforeNavigate event, your page sure will not start loading until you return. However your code will not return until EvalScript return. Now a deadlock occurs;
To avoid such deadlocks, EO.WebBrowser will automatically detect such situations and throw an exception or fail the call. In the above situation, if you try to call EvalScript inside BeforeNavigate, the call will fail, thus avoiding the deadlock.
We have just posted 3.0.39 which fixed a number of such issues. So if you were experiencing deadlock with 3.0.38, you can try to update to 3.0.39 and see if it resolves the issue for you.
Thanks!
|
|
Rank: Newbie Groups: Member
Joined: 3/1/2014 Posts: 5
|
Well thanks for the new version
To my bad luck it does not fulfill my requirement now it fails with the exception
EvalScript failed because JavaScript code can not be executed at this moment. This may occur if you try to re-enter JavaScript engine. For example, if the call chain is JavaScript -> .NET -> JavaScript, then it's not allowed because it would cause re-entry on the JavaScript side. In this case please use QueueScriptCall instead of EvalScript to execute JavaScript code. at EO.WebBrowser.WebView.a(String A_0, ba A_1, ak A_2, Boolean A_3) at EO.WebBrowser.WebView.a(t A_0, Action`1 A_1, Boolean A_2, Boolean A_3, String A_4) at EO.WebBrowser.WebView.a(String A_0, Boolean A_1, Boolean A_2) at EO.WebBrowser.WebView.EvalScript(String code, Boolean throwOnError)
which use to come before also nothing much improvement for me In documentation you have mentioned that for [if the call chain is JavaScript -> .NET -> JavaScript, then it's not allowed because it would cause re-entry on the JavaScript side. In this case please use QueueScriptCall instead of EvalScript to execute JavaScript code.]
I am using the web browser in a form to display a web page and than i will add it to tab-pages
To tell u more if i have 5 tabs with web-browser in each and if one web browser hangs rest of all the tabs with web-browser fails and their i am using only QueueScriptCall ex webView.QueueScriptCall("My Call goes"); this line works fine until it is fine and fails suddenly with this line in my console
A first chance exception of type 'System.Exception' occurred in EO.WebBrowser.dll
after that i have to close the tab so that rest of the tabs can come back to normal form
Kindly tell me any alternative for QueueScriptCall because it hangs a lot
In my application i need to call JavaScript min of 20 times and with this QueueScriptCall it fails a lot with multiple tabs opened
I also tried using webView.GetDomWindow().Invokefunction() which also fails with this same Exception
can i have any exception class of EO. Webbrowser in order to catch those exceptions instead this message or else any location where these logs will be created by EO. Webbrowser
Regards, Sarath
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
Hi,
QueueScriptCall should not hang. If you are trying to call any script code from a timer, check CanEvalScript property first (if that property is false, then don't try to call QueueScriptCall or EvalScript). If you still have problem, please try to isolate the problem into a test project and send the test project to us. We will PM you as to where to send the project.
Thanks!
|
|