- 追加された行はこの色です。
- 削除された行はこの色です。
// 一覧用テンプレート
#topicpath
----
#contents
プラグインからEclipseのワークスペース上のリソースを操作する方法をまとめます。
**全体の構成 [#s9356f95]
Eclipseのワークスペース関連のAPIは
-ワークスペース全体を表すorg.eclipse.core.resources.IWorkspaceRoot
-その下の各プロジェクトorg.eclipse.core.resources.IProject
-プロジェクト内のリソースorg.eclipse.core.resources.IResource
のような構成となっています。これらへの参照を取得して、そのオブジェクトのメソッドを呼び出してワークスペースを操作するわけですね。
あ、これらのAPIを使用するには
org.eclipse.core.resources
を依存関係に追加してください。
**ワークスペースの参照を取得する [#k467344b]
IWorkspace workspace = ResourcesPlugin.getWorkspace();
IWorkspaceRoot root = workspace.getRoot();
これでワークスペースへの参照を取得することができます。このIWorkspaceRoot から各プロジェクトへの参照を取得することができます。
**プロジェクトへの参照を取得する [#t157b35f]
IWorkspaceRoot root = workspace.getRoot();
IProject[] projects = root.getProjects();
これで現在起動しているワークスペース内のプロジェクトを配列で取得することできました。また、
IProject project = root.getProject([プロジェクト名の文字列]);
などとしてプロジェクト名指定で参照を取得することもできます。
**プロジェクトを作成する [#t157b35f]
先のメソッドでプロジェクトを取得することができましたが、プロジェクトを作成するには以下のようにします。
IWorkspaceRoot root = ResourcesPlugin.getWorkspace().getRoot();
IProject project = root.getProject("hogehoge");
if (!project.exists()) {
try {
project.create(null);
} catch (CoreException e1) {
// TODO 自動生成された catch ブロック
e1.printStackTrace();
}
}
プロジェクトが存在するときにcreateを実行すると
org.eclipse.core.internal.resources.ResourceException: リソース /hogehoge はすでに存在します。
のように例外が発生するため、存在チェックをしています。またプロジェクトを作成する
IProject#create(IProgressMonitor monitor)
メソッドは時間がかかる場合があるため、引数にIProgressMonitorを取ります。ここではとりあえずnullを渡してますが、
メソッドは時間がかかる場合があるため、引数にIProgressMonitorを取ります。ここではとりあえずnullを渡してますが。
**プロジェクト内の各リソース [#ea1f2338]
プロジェクト内のリソースはすべて
org.eclipse.core.resources.IResource
というインタフェース(とそのサブインタフェース)を実装しています。以下のような構成ですね。
#ref(IResource.png)
プロジェクト内のリソースは
↓projectはIProjectのインスタンス
project.accept(new IResourceVisitor() {
public boolean visit(IResource resource) throws CoreException {
switch (resource.getType()) {
case IResource.FILE:
logger.debug("飛んできたVisitor: " + resource + " ファイルだ");
// IJavaElement file = JavaCore.create(resource);
// if (file instanceof ICompilationUnit) {
// logger.debug("さらにICompilationUnitだ");
// } else {
// logger.debug("でもICompilationUnitじゃない");
// }
break;
case IResource.FOLDER:
logger.debug("飛んできたVisitor: " + resource + " フォルダだ");
break;
case IResource.PROJECT:
logger.debug("飛んできたVisitor: " + resource + " プロジェクトだ");
break;
case IResource.ROOT:
logger.debug("飛んできたVisitor: " + resource + " ROOTだ");
break;
default:
logger.debug("飛んできたVisitor: " + resource + " その他だ");
break;
}
return true;
}
});
などとすることで取得できます。これはVisitorパタンになっていて、プロジェクト内のツリーを走査していきます。走査したときにvisitメソッドが呼ばれるので、引数のresourceから情報を取り出せばよいわけですね。またこのIResource#getType()を使って型のタイプを取得することができます。タイプは
public static final int FILE = 0x1;
public static final int FOLDER = 0x2;
public static final int PROJECT = 0x4;
public static final int ROOT = 0x8;
などがあるみたいですね。ROOTってのはようわからんのですが。
上のコードではたとえば以下のような結果が得られます。
飛んできたVisitor: P/Samples プロジェクトだ
飛んできたVisitor: F/Samples/source フォルダだ
飛んできたVisitor: F/Samples/source/nu フォルダだ
飛んできたVisitor: F/Samples/source/nu/mine フォルダだ
飛んできたVisitor: F/Samples/source/nu/mine/kino フォルダだ
飛んできたVisitor: L/Samples/source/nu/mine/kino/BL.java ファイルだ
飛んできたVisitor: F/Samples/classes フォルダだ
飛んできたVisitor: F/Samples/classes/nu フォルダだ
飛んできたVisitor: F/Samples/classes/nu/mine フォルダだ
飛んできたVisitor: F/Samples/classes/nu/mine/kino フォルダだ
飛んできたVisitor: L/Samples/classes/nu/mine/kino/BL.class ファイルだ
飛んできたVisitor: L/Samples/build.properties ファイルだ
飛んできたVisitor: F/Samples/META-INF フォルダだ
飛んできたVisitor: L/Samples/META-INF/MANIFEST.MF ファイルだ
飛んできたVisitor: L/Samples/.project ファイルだ
飛んできたVisitor: L/Samples/.classpath ファイルだ
***Visitor以外の方法 [#kd5c3cea]
IResourceのサブインタフェースIContainerに定義されている
public IResource[] members() throws CoreException;
を使用して、
IResource[] resources = project.members();
for (IResource resource : resources) {
System.out.println(resource);
}
などとして子要素を取得することもできます。結果は
L/Samples/.classpath
L/Samples/.project
F/Samples/META-INF
L/Samples/build.properties
F/Samples/classes
F/Samples/source
です。でもこれだと一階層下のリソースしか取得できないですね。
**ディレクトリを作成する [#s73ab009]
**Javaソースコードから、対応するリソースを取得する [#v783dbb5]
***コンテンツ一覧 [#f5b87e5a]
#ls2
***関連リンク [#ee033052]
-[[プラグインでリソースを扱う>http://www13.plala.or.jp/observe/PDE/PDEResources.html]]
----
この記事は
#vote(おもしろかった,そうでもない)
#comment
#topicpath
SIZE(10){現在のアクセス:&counter;}