Follow Techotopia on Twitter

On-line Guides
All Guides
eBook Store
iOS / Android
Linux for Beginners
Office Productivity
Linux Installation
Linux Security
Linux Utilities
Linux Virtualization
Linux Kernel
System/Network Admin
Programming
Scripting Languages
Development Tools
Web Development
GUI Toolkits/Desktop
Databases
Mail Systems
openSolaris
Eclipse Documentation
Techotopia.com
Virtuatopia.com
Answertopia.com

How To Guides
Virtualization
General System Admin
Linux Security
Linux Filesystems
Web Servers
Graphics & Desktop
PC Hardware
Windows
Problem Solutions
Privacy Policy

  




 

 

Eclipse Plug-in Developer Guide
Previous Page Home Next Page

Platform URLs in Eclipse

Frequently people wonder how to "locate" files in Eclipse. In 80% of the cases, the conversation is about things like IFile and IWorkspace . Sometimes it digresses to files available inside bundles and, rarely, it involves the "state location" of a bundle (see the Plugin.getStateLocation() javadoc for more details). Obviously you can use IResource or java.io.File to work with files in these places. There is another way, though: platform URI.

There are a few ways to work with the "platform" scheme:

platform:/resource It is used to identify a resource located in the workspace. The next path segment after "resource" should be the name of a project, which can be followed by the folder and/or file we want to locate.
platform:/plugin

It is used to locate a resource available in a plug-in/bundle. One really cool thing about this one is that it doesn't really matter if this resource is available in a directory or in a jar file. It also doesn't matter if the bundle is installed in a link folder or in the default directory.

The path segment after "plugin" should be the identifier of the bundle, which can be followed by the path of the resource in the bundle.

platform:/fragment This one is quite similar to "platform:/plugin", being used to locate fragment resources instead of bundle resources. As you are probably guessing, the segment after "fragment" should be the fragment's identifier.
platform:/meta We can use this to access a bundle's stage location. The path segment after "meta" should be the bundle's identifier, followed by the path of the resource we want to refer to.
platform:/config The "config" segment causes the platform URI to refer to the configuration area of the running Eclipse (usually the eclipse/configuration directory). This can be useful to read the config.ini file, for example.
platform:/base This always refers to the directory of the Eclipse being executed.

It is interesting to note that, for example, platform:/base/plugins/org.eclipse.mybundle/plugin.xml and platform:/plugin/org.eclipse.mybundle/plugin.xml don't necessarily refer to the same resource. The former is a "pointer" to a plugin.xml file located in a directory plugins/org.eclipse.mybundle under the directory that Eclipse is installed. The latter points to the plugin.xml of the "org.eclipse.mybundle" bundle regardless of where it is installed and whether it is jarred or not.

So what can we do with platform URIs? For one, read the contents of the resources pointed by them. We may also be able to write to such resources or even delete or create them. URIs can be a good fit for APIs that would normally use "plain" paths. Take as an example the icon attribute of the extension point below. Because its value is handled as a URI, we are allowed to refer to an image located in a different bundle.

<extension point="org.eclipse.ui.editorActions">
  <editorContribution ...>
    <action
          icon="platform:/plugin/com.myplugin/icons/me.gif"
          ...
    />
  </editorContribution>
</extension>

 
 
  Published under the terms of the Eclipse Public License Version 1.0 ("EPL") Design by Interspire