Hi there, I'm using the Infragistics Android trial release on a few devices (we have a license for iOS and Android too I think).
This crash in particular is on a Samsung Galaxy Tab 8.0 (GT-5110) running Android 4.4.2. I'm getting this crash when adding some amount (300-400 entries) of data to a DataChartView. The DataChartView has a RangeAreaSeries and an overlapping LineSeries.
As would typically happen with a stack overflow, we lose the actual root of the stack, unfortunately.
E/AndroidRuntime( 3327): java.lang.StackOverflowErrorE/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:487)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)E/AndroidRuntime( 3327): at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:485)
Hello Ben,
Thank you for your post.
I am investigating into this issue to see if I can reproduce the StackOverflowError that you are seeing. It is also possible that this may have been fixed internally as well. I will update this thread again as soon as I have more information for you on this matter.
Please let me know if you have any other questions or concerns on this matter.
Sincerely,AndrewAssociate DeveloperInfragistics Inc.www.infragistics.com/support
Thanks. FWIW, I've only seen this on this specific device. I don't see the same crash ever running a Genymotion emulator (5.x and 4.x) or on my Nexus 5 running Android 5.1.
We continue to see crashes on certain data sets. Here's one sample that causes a stack overflow on a Samsung Tab S.
https://www.dropbox.com/s/f9o8bht3knzkchm/csv.txt?dl=0
Here's a screenshot of the crash:http://i.glui.me/1Dg2EXo
I understand this isn't a lot to go on. Perhaps you could comment on what kind of data might induce fragility into the recursive algorithm.
Here's the full trace:
java.lang.StackOverflowErrorat com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:516)at com.infragistics.controls.Flattener.fastFlattenRecursive(Flattener.java:514)at com.infragistics.controls.Flattener.fastFlatten(Flattener.java:305)at com.infragistics.controls.Flattener.fastFlatten(Flattener.java:268)at com.infragistics.controls.Flattener.chunkedFastFlatten(Flattener.java:226)at com.infragistics.controls.CategoryLineRasterizer.flattenPoints(CategoryLineRasterizer.java:234)at com.infragistics.controls.CategoryLineRasterizer.rasterizePolyline(CategoryLineRasterizer.java:309)at com.infragistics.controls.CategoryLineRasterizer.rasterizePolylinePaths(CategoryLineRasterizer.java:104)at com.infragistics.controls.LineSeriesView.rasterizeLine(LineSeriesView.java:68)at com.infragistics.controls.LineSeriesImplementation.renderFrame(LineSeriesImplementation.java:82)at com.infragistics.controls.CategorySeriesImplementation.renderSeriesOverride(CategorySeriesImplementation.java:925)at com.infragistics.controls.SeriesImplementation.doRenderSeries(SeriesImplementation.java:977)at com.infragistics.controls.SeriesImplementation.access$100(SeriesImplementation.java:24)at com.infragistics.controls.SeriesImplementation$10.invoke(SeriesImplementation.java:1455)at com.infragistics.controls.SeriesImplementation$10.invoke(SeriesImplementation.java:1455)at com.infragistics.controls.ContentInfo.doRefresh(ContentInfo.java:117)at com.infragistics.controls.ChartContentManager.doRefresh(ChartContentManager.java:209)at com.infragistics.controls.ChartContentManager.force(ChartContentManager.java:189)at com.infragistics.controls.SeriesViewerView.beforeContentRefresh(SeriesViewerView.java:2085)at com.infragistics.controls.SeriesViewerImplementation.beforeContentRefresh(SeriesViewerImplementation.java:3903)at com.infragistics.controls.ChartContentManager.doRefresh(ChartContentManager.java:203)at com.infragistics.controls.ChartContentManager.access$000(ChartContentManager.java:19)at com.infragistics.controls.ChartContentManager$1.invoke(ChartContentManager.java:93)at com.infragistics.controls.ComponentProxy.doInvalidate(ComponentProxy.java:239)at com.infragistics.controls.SeriesViewerBaseView.onDraw(SeriesViewerBaseView.java:94)at android.view.View.draw(View.java:15423)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.draw(View.java:15426)at android.widget.FrameLayout.draw(FrameLayout.java:472)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.draw(View.java:15426)at android.widget.FrameLayout.draw(FrameLayout.java:472)at android.view.View.getDisplayList(View.java:14317)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.View.draw(View.java:15137)at android.view.ViewGroup.drawChild(ViewGroup.java:3322)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3158)at android.view.View.getDisplayList(View.java:14312)at android.view.View.getDisplayList(View.java:14359)at android.view.HardwareRenderer$GlRenderer.buildDisplayList(HardwareRenderer.java:1585)at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1457)at android.view.ViewRootImpl.draw(ViewRootImpl.java:2779)at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2645)at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2213)at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1256)at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6649)at android.view.Choreographer$CallbackRecord.run(Choreographer.java:813)at android.view.Choreographer.doCallbacks(Choreographer.java:613)at android.view.Choreographer.doFrame(Choreographer.java:583)at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:799)at android.os.Handler.handleCallback(Handler.java:733)at android.os.Handler.dispatchMessage(Handler.java:95)at android.os.Looper.loop(Looper.java:146)at android.app.ActivityThread.main(ActivityThread.java:5653)at java.lang.reflect.Method.invokeNative(Native Method)at java.lang.reflect.Method.invoke(Method.java:515)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1291)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1107)at dalvik.system.NativeStart.main(Native Method)
Hello Caylan,
Thank you for your response, but the dropbox link was to a csv.txt file, and not so much a sample application that reproduces this error. Could you please attach a sample application in a .zip file so that I can see what you are seeing?
Caylan,
Looking at your stack trace it seems like you are running the safer code, but we may need to increase the protection against runaway stack depth due to lower stack limits on Android. If you could get that sample data to Andrew, if you haven't done that already, it should hasten our diagnosis.
-Graham
BTW, the largeheap recommendation I made in the other thread my apply here, since requesting a larger heap allocation may also result in a larger stack size limit. Since you can't reproduce the issue on every device, it likely means that this relates to total heap space and free heap space, since those can vary per device.
Thank you for your response.
I have been testing out the private build, and it appears to solve the issues that you were having with the Flattener exception as well as the orientation flip OutOfMemory exception. I have created a case for you so that I can send you this private build. It has a case ID of CAS-152678-X1X7T7 and you can access it here: https://ko.infragistics.com/my-account/support-activity. I will be sending an update to that case shortly with more information on the build changes, along with the private build attached to it.
Hi Andrew, that's great news. Thank you.
We only use the Android components, no Xamarin Forms.
Ben
We have internally created a parameter that can be set to solve this current issue you are having, and I just need to test it a little bit more before sending it, just to be sure. I will likely be creating a case tomorrow that will be viewable to Ben through which I will send a new private build. One thing though, are you using the Android components exclusively, or are you using Xamarin Forms?
Great. Thanks for all your hard work! Our only concern is to have this fixed as soon as possible. This issue is a showstopper for our app release and we are a few days behind schedule because of it.
Hello Caylan/Ben,
I have been testing the standalone application that was provided, and I have reproduced this issue. I also noticed that after lowering the multiplier on the data in the MainActivity load and getting the application to startup, if you zoom in on the chart, the same exception is thrown. I am currently collaborating with Graham to see what can be done about this. I will update you again soon.