oda extension in Birt

JB4You

Mitglied
Hallo,

ich bin im Augenblick dabei, eine ODA Extension für Birt für eine Datenbank namens Tamino zu schreiben. Ich habe mal etwas mit vorhandenen Sources gespielt, und stehe jetzt vor einer Exception, die mir nicht wirklich was sagt. Meine zwei Eclipse Plug-in Projekte beschreiben zum Einen die Datasource und zum Anderen die dazugehörige UI für Birt. Ich habe beide plugin.xml-Dateien hier angefügt, die für die Datasource heißt plugin.xml und die für die UI pluginUI.xml. Ich arbeite mit Eclipse 3.3.0. Meine Datasource wird auch schon von Birt erkannt, zumindest taucht sie bei der Auswahl auf. Aber erstens wird der "next"-Button nicht freigegeben, wenn ich die Datasource für das erstellen eines Datasets auswähle, und wenn ich auf die Datasource doppelt klicke wird mir folgende Exception ausgegeben:

11.04.2008 10:43:24 org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer getDataSourceId
WARNUNG: Ignoring invalid extension.
org.eclipse.datatools.connectivity.oda.OdaException: The ODA driver plugin.xml is missing a <dataSource> element.
at org.eclipse.datatools.connectivity.oda.util.manifest.ManifestUtil.getNamedElement(ManifestUtil.java:43)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getNamedElement(UIManifestExplorer.java:433)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getDataSourceId(UIManifestExplorer.java:279)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.findExtension(UIManifestExplorer.java:258)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getExtensionManifest(UIManifestExplorer.java:230)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getExtensionManifest(UIManifestExplorer.java:158)
at org.eclipse.datatools.connectivity.oda.design.ui.designsession.DesignSessionUtil.hasValidOdaDesignUIExtension(DesignSessionUtil.java:299)
at org.eclipse.birt.report.designer.data.ui.datasource.DataSourceEditor.<init>(DataSourceEditor.java:67)
at org.eclipse.birt.report.designer.internal.ui.views.data.providers.DataSourceNodeProvider.performEdit(DataSourceNodeProvider.java:84)
at org.eclipse.birt.report.designer.internal.ui.views.DefaultNodeProvider.performRequest(DefaultNodeProvider.java:368)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.birt.report.designer.ui.views.ElementAdapterInvocationHandler.invoke(ElementAdapterInvocationHandler.java:89)
at $Proxy0.performRequest(Unknown Source)
at org.eclipse.birt.report.designer.internal.ui.views.actions.EditAction.doAction(EditAction.java:80)
at org.eclipse.birt.report.designer.internal.ui.views.actions.AbstractElementAction.run(AbstractElementAction.java:64)
at org.eclipse.birt.report.designer.internal.ui.views.RenameListener.doubleClick(RenameListener.java:214)
at org.eclipse.jface.viewers.StructuredViewer$1.run(StructuredViewer.java:799)
at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:37)
at org.eclipse.core.runtime.Platform.run(Platform.java:857)
at org.eclipse.ui.internal.JFaceUtil$1.run(JFaceUtil.java:46)
at org.eclipse.jface.util.SafeRunnable.run(SafeRunnable.java:193)
at org.eclipse.jface.viewers.StructuredViewer.fireDoubleClick(StructuredViewer.java:797)
at org.eclipse.jface.viewers.AbstractTreeViewer.handleDoubleSelect(AbstractTreeViewer.java:1384)
at org.eclipse.jface.viewers.StructuredViewer$4.widgetDefaultSelected(StructuredViewer.java:1173)
at org.eclipse.jface.util.OpenStrategy.fireDefaultSelectionEvent(OpenStrategy.java:237)
at org.eclipse.jface.util.OpenStrategy.access$0(OpenStrategy.java:234)
at org.eclipse.jface.util.OpenStrategy$1.handleEvent(OpenStrategy.java:295)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:938)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3682)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3293)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2389)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2353)
at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2219)
at org.eclipse.ui.internal.Workbench$4.run(Workbench.java:466)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:289)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:461)
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:106)
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:153)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:106)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:76)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:363)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:176)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:504)
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:443)
at org.eclipse.equinox.launcher.Main.run(Main.java:1169)
at org.eclipse.equinox.launcher.Main.main(Main.java:1144)
11.04.2008 10:43:40 org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer getDataSourceId
WARNUNG: Ignoring invalid extension.
org.eclipse.datatools.connectivity.oda.OdaException: The ODA driver plugin.xml is missing a <dataSource> element.
at org.eclipse.datatools.connectivity.oda.util.manifest.ManifestUtil.getNamedElement(ManifestUtil.java:43)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getNamedElement(UIManifestExplorer.java:433)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getDataSourceId(UIManifestExplorer.java:279)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.findExtension(UIManifestExplorer.java:258)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getExtensionManifest(UIManifestExplorer.java:230)
at org.eclipse.datatools.connectivity.oda.design.ui.manifest.UIManifestExplorer.getExtensionManifest(UIManifestExplorer.java:158)
at org.eclipse.datatools.connectivity.oda.design.ui.designsession.DesignSessionUtil.hasValidOdaDesignUIExtension(DesignSessionUtil.java:299)
at org.eclipse.birt.report.designer.data.ui.datasource.DataSourceEditor.<init>(DataSourceEditor.java:67)
at org.eclipse.birt.report.designer.internal.ui.views.data.providers.DataSourceNodeProvider.performEdit(DataSourceNodeProvider.java:84)
at org.eclipse.birt.report.designer.internal.ui.views.DefaultNodeProvider.performRequest(DefaultNodeProvider.java:368)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.birt.report.designer.ui.views.ElementAdapterInvocationHandler.invoke(ElementAdapterInvocationHandler.java:89)
at $Proxy0.performRequest(Unknown Source)
at org.eclipse.birt.report.designer.internal.ui.views.actions.EditAction.doAction(EditAction.java:80)
at org.eclipse.birt.report.designer.internal.ui.views.actions.AbstractElementAction.run(AbstractElementAction.java:64)
at org.eclipse.birt.report.designer.internal.ui.views.RenameListener.doubleClick(RenameListener.java:214)
at org.eclipse.jface.viewers.StructuredViewer$1.run(StructuredViewer.java:799)
at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:37)
at org.eclipse.core.runtime.Platform.run(Platform.java:857)
at org.eclipse.ui.internal.JFaceUtil$1.run(JFaceUtil.java:46)
at org.eclipse.jface.util.SafeRunnable.run(SafeRunnable.java:193)
at org.eclipse.jface.viewers.StructuredViewer.fireDoubleClick(StructuredViewer.java:797)
at org.eclipse.jface.viewers.AbstractTreeViewer.handleDoubleSelect(AbstractTreeViewer.java:1384)
at org.eclipse.jface.viewers.StructuredViewer$4.widgetDefaultSelected(StructuredViewer.java:1173)
at org.eclipse.jface.util.OpenStrategy.fireDefaultSelectionEvent(OpenStrategy.java:237)
at org.eclipse.jface.util.OpenStrategy.access$0(OpenStrategy.java:234)
at org.eclipse.jface.util.OpenStrategy$1.handleEvent(OpenStrategy.java:295)
at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:938)
at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3682)
at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3293)
at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2389)
at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2353)
at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2219)
at org.eclipse.ui.internal.Workbench$4.run(Workbench.java:466)
at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:289)
at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:461)
at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:106)
at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:153)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:106)
at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:76)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:363)
at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:176)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:504)
at org.eclipse.equinox.launcher.Main.basicRun(Main.java:443)
at org.eclipse.equinox.launcher.Main.run(Main.java:1169)
at org.eclipse.equinox.launcher.Main.main(Main.java:1144)

Da ich mich noch sehr neu auf diesem Gebiet bewege frage ich nun hier, ob sich jemand damit auskennt und mir vielleicht helfen kann...
Was habe ich da wohl übersehen?

Danke im Voraus

Jonas
 
Hallo,
inzwischen habe ich das Problem mit der Exception hinbekommen. In der pluginUI.xml war der extention point doppelt angelegt, das konnte so garnicht funktionieren.
Das Problem mit den nicht aktivierten "next"-Button besteht leider weiter hin. Kennt sich denn niemand mit sowas aus?

Gruß,
Jonas
 
Hallo Jonas,

ich weiss nicht, ob das Problem noch aktuell ist.

Du musst in Deiner DataSetWizardPage (im UI Projekt) ein
setPageComplete( true );
aufrufen.

Erläuterung:

Die Methode protected boolean canLeave() in DataSetWizardPage (im UI Projekt) entscheidet, ob der Next Button kommt.

Deine DataSetWizardPage wird normalerweise canLeave() überschreiben und den Wert aus isPageComplete() zurueckgeben.
--------schnipp---------
/*
* (non-Javadoc)
* @see org.eclipse.datatools.connectivity.oda.design.ui.wizards.DataSetWizardPage#canLeave()
*/
protected boolean canLeave( )
{
return isPageComplete();
}
--------schnipp---------

isPageComplete() ist im Interface IWizardPage definiert und in der Basisklasse
WizardPage implementiert.
--------schnipp---------
public boolean isPageComplete() {
return isPageComplete;
}
--------schnipp---------

setPageComplete() liegt wieder in der Basisklase WizardPage und setzt den Wert von isPageComplete.
--------schnipp---------
public void setPageComplete(boolean complete) {
isPageComplete = complete;
if (isCurrentPage()) {
getContainer().updateButtons();
}
}
--------schnipp---------

Ich hoffe, das hilft....
Gruß, Lothar
 
Leider ist das Problem nicht mehr aktuell. Ich weis ehrlich gesagt gar nicht mehr, ob ich das Problem damals dann hinbekommen habe oder nicht.
Aber trotzdem vielen Dank für den Tip.

Gruß
JB4You
 

Neue Beiträge

Zurück