airbnb / epoxy

Epoxy is an Android library for building complex screens in a RecyclerView
https://goo.gl/eIK82p
Apache License 2.0
8.46k stars 730 forks source link

Crash when drag models #1314

Open phongbm opened 1 year ago

phongbm commented 1 year ago

I implement drag & drop, but sometimes it crash randomly. How to fix that? Please. That is log:

java.lang.IndexOutOfBoundsException: Index: 3, Size: 3
        at java.util.ArrayList.remove(ArrayList.java:503)
        at com.airbnb.epoxy.EpoxyControllerAdapter.moveModel(EpoxyControllerAdapter.java:202)
        at com.airbnb.epoxy.EpoxyController.moveModel(EpoxyController.java:688)
        at com.airbnb.epoxy.TypedEpoxyController.moveModel(TypedEpoxyController.java:51)
        at com.airbnb.epoxy.EpoxyModelTouchCallback.onMove(EpoxyModelTouchCallback.java:77)
        at com.airbnb.epoxy.EpoxyTouchHelperCallback.onMove(EpoxyTouchHelperCallback.kt:30)
        at androidx.recyclerview.widget.ItemTouchHelper.moveIfNecessary(ItemTouchHelper.java:885)
        at androidx.recyclerview.widget.ItemTouchHelper$2.onTouchEvent(ItemTouchHelper.java:389)
        at androidx.recyclerview.widget.RecyclerView.dispatchToOnItemTouchListeners(RecyclerView.java:3259)
        at androidx.recyclerview.widget.RecyclerView.onTouchEvent(RecyclerView.java:3421)
        at android.view.View.dispatchTouchEvent(View.java:15076)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3917)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3581)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3923)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:3597)
        at com.android.internal.policy.DecorView.superDispatchTouchEvent(DecorView.java:1015)
        at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1962)
        at android.app.Activity.dispatchTouchEvent(Activity.java:4265)
        at androidx.appcompat.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:69)
        at com.android.internal.policy.DecorView.dispatchTouchEvent(DecorView.java:973)
        at android.view.View.dispatchPointerEvent(View.java:15335)
        at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:7794)
        at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:7567)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:6901)
        at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:6958)
        at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:6924)
        at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:7122)
        at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:6932)
        at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:7179)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:6905)
        at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:6958)
2022-09-23 10:18:32.711 30827-30827/moola.dev E/AndroidRuntime:     at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:6924)
        at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:6932)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:6905)
        at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:10354)
        at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:10202)
        at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:10158)
        at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:10486)
        at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:259)
        at android.view.InputEventReceiver.nativeConsumeBatchedInputEvents(Native Method)
        at android.view.InputEventReceiver.consumeBatchedInputEvents(InputEventReceiver.java:239)
        at android.view.ViewRootImpl.doConsumeBatchedInput(ViewRootImpl.java:10434)
        at android.view.ViewRootImpl$ConsumeBatchedInputRunnable.run(ViewRootImpl.java:10575)
        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1108)
        at android.view.Choreographer.doCallbacks(Choreographer.java:866)
        at android.view.Choreographer.doFrame(Choreographer.java:789)
        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1092)
        at android.os.Handler.handleCallback(Handler.java:938)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loopOnce(Looper.java:226)
        at android.os.Looper.loop(Looper.java:313)
        at android.app.ActivityThread.main(ActivityThread.java:8663)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:567)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1135)