2009-06-22 2 views
1

У меня есть приложение RCP (называемое RCP-APP). Я создал новый плагин (называемый подключаемым модулем A), который обертывает медиа-плеер api (.jar-файл) и папку библиотек C (DLL), с которой пользовательский интерфейс api обращается через JNA. Затем я создал еще один плагин (называемый подключаемым модулем B), который содержит приложение медиаплеера, которое зависит от подключаемого модуля A.Eclipse RCP/Plug-in Question

Когда активирован подключаемый модуль B, я получаю следующие сообщения об ошибках, сообщающие мне, что Plug- в B не может найти медиа-плеер .dlls его ищет:

 
!ENTRY org.eclipse.jface 4 2 2009-06-22 10:05:22.475 
!MESSAGE Problems occurred when invoking code from plug-in: "org.eclipse.jface". 
!STACK 0 
java.lang.UnsatisfiedLinkError: Unable to load library 'libvlc': The specified module could not be found. 

    at com.sun.jna.NativeLibrary.loadLibrary(NativeLibrary.java:114) 
    at com.sun.jna.NativeLibrary.getInstance(NativeLibrary.java:157) 
    at com.sun.jna.Library$Handler.(Library.java:123) 
    at com.sun.jna.Native.loadLibrary(Native.java:260) 
    at com.sun.jna.Native.loadLibrary(Native.java:246) 
    at org.videolan.jvlc.internal.LibVlc.(LibVlc.java:41) 
    at org.videolan.jvlc.JVLC.(JVLC.java:45) 
    at com.bah.gs.arts.jekyll.plugins.videolog.VideoLogDisplay.displayStream(VideoLogDisplay.java:32) 
    at com.bah.gs.arts.jekyll.core.extensionpoints.DisplayStreamFactory.getDisplayStreams(DisplayStreamFactory.java:57) 
    at com.bah.gs.arts.jekyll.core.views.medialist.MediaListView$1.doubleClick(MediaListView.java:91) 
    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:880) 
    at org.eclipse.ui.internal.JFaceUtil$1.run(JFaceUtil.java:48) 
    at org.eclipse.jface.util.SafeRunnable.run(SafeRunnable.java:175) 
    at org.eclipse.jface.viewers.StructuredViewer.fireDoubleClick(StructuredViewer.java:797) 
    at org.eclipse.jface.viewers.AbstractTreeViewer.handleDoubleSelect(AbstractTreeViewer.java:1419) 
    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:84) 
    at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1003) 
    at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3823) 
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3422) 
    at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2384) 
    at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2348) 
    at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2200) 
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:495) 
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:288) 
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:490) 
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149) 
    at com.bah.gs.arts.jekyll.core.Application.start(Application.java:20) 
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:193) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110) 
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:386) 
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:549) 
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:504) 
    at org.eclipse.equinox.launcher.Main.run(Main.java:1236) 
    at org.eclipse.equinox.launcher.Main.main(Main.java:1212) 

Как сообщаю Plug-в B (или RCP-APP), что в библиотеках .dll в определенной папке в Разъемном A?

Похоже, что api ожидает найти DLL через переменную PATH среды.

Как я могу по существу передать «плагин A/Folder-Name»?

Благодарим за помощь.

ответ

1

Чтобы получить доступ к файлам .DLL в плагин-а/папки должны иметь доступ к Bundle экземпляру плагина А. Один из способов реализовать Activator для плагина А, который проходит по крайней мере класса Plugin ("PluginA").

Вызов PluginA.getDefault().getBundle().getEntry("folder/some.dll") возвращает URL-адрес в файл .DLL.

IMHO лучше поместить весь код, который напрямую обращается к файлам .DLL в подключаемый модуль A. Таким образом, вам не нужно подвергать внутреннюю файловую структуру вашего плагина своим пользователям.

+0

«IMHO лучше разместить весь код, который напрямую обращается к файлам .DLL в подключаемый модуль A. Таким образом, вам не нужно подвергать внутреннюю файловую структуру вашего плагина своим пользователям.« Это правда, но это касается каждого подключаемого модуля, который я создаю, который использует медиаплеер. Api будет иметь копию DLL и файла .jar. Этого я пытался избежать, разместив файл .jar и. dlls в своем собственном подключаемом модуле. –

+0

В любом случае ..... Я api пытаюсь найти .dlls через переменную PAT. Я ошибался в возможности передать местоположение в качестве параметра api. –

+5

Итак, у вас есть различные плагины, которые вызывают функциональность из .DLL? Вы можете реализовать фасад для этой функции в «подключаемом модуле А», который обрабатывает доступ к .DLL и управляет переменной PATH. Таким образом, вам не нужно делать все это возится в других плагинах. – ftl

1

Возможно, вы захотите посмотреть фрагменты плагина; это обеспечивает механизм, позволяющий публике сталкиваться с API Java отдельно от файлов (dll/so), специфичных для конкретной платформы.

Упаковка SWT будет хорошим местом, чтобы начать изучать подобные проблемы.

0

Вы можете создать плагин «двоичные файлы», поместить dll в подпапку/его содержимое, а затем убедиться в манифесте * вы добавите свойство активатора + singleton. * Вы проверяете бен/в разделе «Построить», «исполнительную Построить»

В функции, которая включает в себя исполняемые файлы плагина, не забудьте проверить «Распаковать архив плагинов после установки»

В активатор исполняемых файлов плагин, добавить что-то вроде этого:

public enum Tool {reach, ctl, ltl}; 
private static URI toolUri [] = new URI [3]; 

public static URI getProgramURI(Tool tool) throws IOException { 
    if (toolUri[tool.ordinal()] == null) { 
     String relativePath = "bin/its-"+ tool.toString() ; 
     URL toolff = getDefault().getBundle().getResource(relativePath); 
     if (toolff == null) { 
      log.severe("unable to find an executable [" + tool + "] in path " + relativePath); 
      Enumeration<URL> e = getDefault().getBundle().findEntries("bin/", "*", true); 
      log.fine("Lising URL available in bin/"); 
      while (e.hasMoreElements()) { 
       log.finer(e.nextElement().toString()); 
      } 
      throw new IOException("unable to find the tool binary"); 
     } 
     URL tmpURL = FileLocator.toFileURL(toolff); 

     // use of the multi-argument constructor for URI in order to escape appropriately illegal characters 
     URI uri; 
     try { 
      uri = new URI(tmpURL.getProtocol(), tmpURL.getPath(), null); 
     } catch (URISyntaxException e) { 
      throw new IOException("Could not create a URI to access the binary tool :", e); 
     } 
     toolUri[tool.ordinal()] = uri; 
     log.fine("Location of the binary : " + toolUri); 

     File crocExec = new File(uri); 
     if (!crocExec.setExecutable(true)) { 
      log.severe("unable to make the command-line tool executable [" + toolUri + "]"); 
      throw new IOException("unable to make the command-line tool executable"); 
     }  

    } 
    return toolUri[tool.ordinal()]; 
} 

я копия вставленный из некоторого кода моих, так жаль, что не вполне соответствует вашему примеру DLL, я получаю исполняемые пути из ограниченного списка (см enum Tool). Последний шаг (установка флага + x в файле), вероятно, бесполезен в вашем случае. С другой стороны, вы получаете код обработки исключений и кеш бесплатно :) И его тестирование довольно тщательно.

Он выполняет задание, которое вы пытаетесь сделать, передает URL-адрес двоичному файлу в нижестоящий плагин.

+0

После того, как у вас есть информация, вы можете программно обновить PATH среды, чтобы включить эту папку. С проверкой «unzip» и URI, используемым в моем коде, вы получаете материал, совместимый с plai n java.io.File api. –