projects
/
Mograsim.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Renamed MainMachineLaunchConfigTab in the Wizard
[Mograsim.git]
/
plugins
/
net.mograsim.plugin.core
/
src
/
net
/
mograsim
/
plugin
/
tables
/
mi
/
RowHighlighter.java
diff --git
a/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/tables/mi/RowHighlighter.java
b/plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/tables/mi/RowHighlighter.java
index
17b2cd2
..
e7435a2
100644
(file)
--- a/
plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/tables/mi/RowHighlighter.java
+++ b/
plugins/net.mograsim.plugin.core/src/net/mograsim/plugin/tables/mi/RowHighlighter.java
@@
-1,21
+1,20
@@
package net.mograsim.plugin.tables.mi;
import java.util.Optional;
package net.mograsim.plugin.tables.mi;
import java.util.Optional;
-import java.util.concurrent.atomic.AtomicBoolean;
-import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Table;
import net.mograsim.plugin.tables.LazyTableViewer;
import org.eclipse.swt.widgets.Table;
import net.mograsim.plugin.tables.LazyTableViewer;
+import net.mograsim.plugin.util.SingleSWTRequest;
public class RowHighlighter
{
public class RowHighlighter
{
- private int highlighted = -1
, toHighlight
;
+ private int highlighted = -1;
private LazyTableViewer viewer;
private LazyTableViewer viewer;
- private
AtomicBoolean waiting = new AtomicBoolean()
;
- private
ColorProvider cProv
;
+ private
FontAndColorHelper cProv
;
+ private
SingleSWTRequest requester = new SingleSWTRequest()
;
- public RowHighlighter(LazyTableViewer viewer,
ColorProvid
er cProv)
+ public RowHighlighter(LazyTableViewer viewer,
FontAndColorHelp
er cProv)
{
this.viewer = viewer;
this.cProv = cProv;
{
this.viewer = viewer;
this.cProv = cProv;
@@
-23,23
+22,11
@@
public class RowHighlighter
public void highlight(int row)
{
public void highlight(int row)
{
- synchronized (waiting)
+ requester.request(() ->
{
{
- toHighlight = row;
- if (!waiting.get())
- {
- waiting.set(true);
- Display.getDefault().asyncExec(() ->
- {
- synchronized (waiting)
- {
- waiting.set(false);
- if (!viewer.getTable().isDisposed())
- innerHighlight(toHighlight);
- }
- });
- }
- }
+ if (!viewer.getTable().isDisposed())
+ innerHighlight(row);
+ });
}
private void innerHighlight(int row)
}
private void innerHighlight(int row)
@@
-50,10
+37,10
@@
public class RowHighlighter
{
table.showItem(table.getItem(Math.min(table.getItemCount(), row + 2)));
table.showItem(table.getItem(row));
{
table.showItem(table.getItem(Math.min(table.getItemCount(), row + 2)));
table.showItem(table.getItem(row));
- Optional.of(table.getItem(row).getData()).ifPresent(d -> viewer.update(d, null));
+ Optional.of
Nullable
(table.getItem(row).getData()).ifPresent(d -> viewer.update(d, null));
}
if (highlighted != -1)
}
if (highlighted != -1)
- Optional.of(table.getItem(highlighted).getData()).ifPresent(d -> viewer.update(d, null));
+ Optional.of
Nullable
(table.getItem(highlighted).getData()).ifPresent(d -> viewer.update(d, null));
highlighted = row;
}
}
highlighted = row;
}
}