import java.util.ArrayList;
import org.argeo.ArgeoLogListener;
+import org.argeo.ArgeoLogger;
import org.argeo.security.ui.SecurityUiPlugin;
import org.eclipse.jface.viewers.LabelProvider;
import org.eclipse.jface.viewers.TableViewer;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.ui.part.ViewPart;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceRegistration;
/**
* Display log lines with a virtual table. Register and unregisters a
*/
public class LogView extends ViewPart {
public static String ID = SecurityUiPlugin.PLUGIN_ID + ".logView";
-
+
private TableViewer viewer;
private LogContentProvider logContentProvider;
-
- private ServiceRegistration serviceRegistration;
+ private ArgeoLogger argeoLogger;
@Override
public void createPartControl(Composite parent) {
- viewer = new TableViewer(parent, SWT.VIRTUAL);
+ viewer = new TableViewer(parent, SWT.VIRTUAL | SWT.MULTI | SWT.H_SCROLL
+ | SWT.V_SCROLL | SWT.FULL_SELECTION | SWT.BORDER);
viewer.setLabelProvider(new LabelProvider());
logContentProvider = new LogContentProvider(viewer);
- serviceRegistration = getBundleContext().registerService(
- ArgeoLogListener.class.getName(), logContentProvider, null);
viewer.setContentProvider(logContentProvider);
- viewer.setUseHashlookup(true);
+ // viewer.setUseHashlookup(true);
viewer.setInput(new ArrayList<String>());
+
+ if (argeoLogger != null)
+ argeoLogger.register(logContentProvider, 1000);
}
@Override
@Override
public void dispose() {
- if (serviceRegistration != null)
- serviceRegistration.unregister();
+ if (argeoLogger != null)
+ argeoLogger.unregister(logContentProvider);
}
- private BundleContext getBundleContext() {
- return SecurityUiPlugin.getDefault().getBundle().getBundleContext();
+ public void setArgeoLogger(ArgeoLogger argeoLogger) {
+ this.argeoLogger = argeoLogger;
}
+
}