Locking: RowAlreadyLockedException: Could not acquire lock
Description
Initial behaviour:
--------------------------------------------------------------
I have the kfz-DB and a window with a table and a formular.
I´m using the EXTRAS-Table.
I enable the lock in the formular.
Then i click on the 5th line in the table and I get the lock
for the record.
--------------------------------------------------------------
Real behaviour:
--------------------------------------------------------------
When I click in a second running program on the same record
an Exception is thrown:
xdev.db.locking.RowAlreadyLockedException: Could not acquire lock xdev.db.locking.HybridVirtualTabelLock$1@3a9d23c0
at xdev.db.locking.HybridVirtualTabelLock$1.write(HybridVirtualTabelLock.java:415)
at xdev.db.Transaction.execute(Transaction.java:89)
at xdev.db.locking.HybridVirtualTabelLock.getLock(HybridVirtualTabelLock.java:435)
at xdev.ui.XdevFormular.initLockingComponent(XdevFormular.java:1006)
at xdev.ui.XdevFormular.setModel(XdevFormular.java:941)
at xdev.ui.DefaultMasterDetailHandler$1.valueChanged(DefaultMasterDetailHandler.java:138)
at xdev.ui.TableSupport$1.valueChanged(TableSupport.java:1056)
at javax.swing.DefaultListSelectionModel.fireValueChanged(DefaultListSelectionModel.java:184)
at javax.swing.DefaultListSelectionModel.fireValueChanged(DefaultListSelectionModel.java:154)
at javax.swing.DefaultListSelectionModel.setValueIsAdjusting(DefaultListSelectionModel.java:685)
at javax.swing.plaf.basic.BasicTableUI$Handler.setValueIsAdjusting(BasicTableUI.java:953)
at javax.swing.plaf.basic.BasicTableUI$Handler.mouseReleased(BasicTableUI.java:1166)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:290)
at java.awt.Component.processMouseEvent(Component.java:6504)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6269)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4860)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2713)
at java.awt.Component.dispatchEvent(Component.java:4686)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:707)
at java.awt.EventQueue.access$000(EventQueue.java:101)
at java.awt.EventQueue$3.run(EventQueue.java:666)
at java.awt.EventQueue$3.run(EventQueue.java:664)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:680)
at java.awt.EventQueue$4.run(EventQueue.java:678)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:677)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:211)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:128)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:117)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:113)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:90)
--------------------------------------------------------------
Expected behaviour:
--------------------------------------------------------------
No Exception is thrown. Only the formular is disabled until
the lock of the other is out of date.
--------------------------------------------------------------
Comment:
--------------------------------------------------------------
--------------------------------------------------------------
Environment
Activity
The problem can not be reproduced with the new locking api.
Start the Window LockingTest 2 Times (attached project).