Presentation is loading. Please wait.

Presentation is loading. Please wait.

Eclipse resource management. Outline Introduction Basic resource management Further resource management.

Similar presentations


Presentation on theme: "Eclipse resource management. Outline Introduction Basic resource management Further resource management."— Presentation transcript:

1 Eclipse resource management

2 Outline Introduction Basic resource management Further resource management

3 Introduction Package org.eclipse.core.resources Define the notions of workspaces and resources Provides basic support for managing a workspace and its resources for resource plug- in Resource retrieve, create, delete, move..Etc. Tracking resource lifecycle changes Similar to a file system

4 Basic resource management Resource and the workspace Resource and the local file system Resource properties

5 Resource and the workspace Workspace : central hub of user ’ s file Plug-in use resource API to create, navigate, manipulate resource in the workspace Three kinds of resource Project Folder file

6 Resources (I) Project Collection of folders and files Organize resources related to specific projects Interface IProject Folder Contains other folder and files Like directory in file system Interface IFolder

7 Resource (II) File Arbitrary sequence of bytes Interface IFile Interface Iworkspace Interface IResource

8 Resource organization Tree structure Project at top Folder and file underneath Workspace root

9 Resource and file system When resource plug-in is activate, the workspace is represented by an instance of IWorkspace The IWorkspace instance represent all files and directories in file system Get the IWorkspace instance : ResourcePlugin.getWorkspace();

10 Manipulate resource First get the IWorkspaceRoot instance, which represents the root of the resource tree in the workspace Access projects in the workspace Access folders and files in projects Access files in folders Similar to java.io.File

11 Get and open project IWorkspaceRoot myWorkspaceRoot = ResourcesPlugin.getWorkspace().getRoot(); IProject myWebProject = myWorkspaceRoot.getProject("MyWeb"); // open if necessary if (myWebProject.exists() && !myWebProject.isOpen()) myWebProject.open(null);

12 Get folder, create file IFolder imagesFolder = myWebProject.getFolder("images"); if (imagesFolder.exists()) { // create a new file IFile newLogo = imagesFolder.getFile("newLogo.gif"); FileInputStream fileStream = new FileInputStream( "c:/MyOtherData/newLogo.gif"); newLogo.create(fileStream, false, null); // create closes the file stream, so no worries. }

13 File copy IFile logo = imagesFolder.getFile("logo.gif"); if (logo.exists()) { IPath newLogoPath = new Path("newLogo.gif"); logo.copy(newLogoPath, false, null); IFile newLogo = imagesFolder.getFile("newLogo.gif");... }

14 File move IFolder newImagesFolder = myWebProject.getFolder("newimages"); newImagesFolder.create(false, true, null); IPath renamedPath = newImagesFolder.getFullPath().append("renamedLogo.gif"); newLogo.move(renamedPath, false, null); IFile renamedLogo = newImagesFolder.getFile("renamedLogo.gif");

15 Resource and real file location Use IResource.getLocation() to get the full system path of a resource Use IProjectDescription.setLocation() to change a project location Get a resource via a file system path IWorkspaceRoot.getFileForLocation() IWorkspaceRoot.getContainerForLocation()

16 Resource properties Session properties Cache information in key-value pair in memory Lost when a resource is deleted or the project or workspace is closed Persistent properties Store resource-specific information on disk Store with system metadata and maintained across platform shutdown and restart

17 Used Interface and class Class ResourcePlugin The plug-in run-time class The start point for resource manipulation Interface IWorkspace Represent the workspace in the platform Interface IResource The resource in the workspace Superinterface of IFile, IFolder, IProject, IWorkspaceRoot

18 Used interface and class Interface IFile, IFolder, IProject, IWorkspaceRoot System resource instance Provide manipulation methods of resources Interface IProjectDescription Contain the metadata require to define a project Contain the information in file.project with all projects

19 Further resource management Resource markers Tracking resource changes Incremental project builders Workspace save participation Project natures Derived resource Resource modification hooks

20 Marker a general mechanism for associating notes and meta-data with resources. Like a small tag to a resource Record information about a problem or a task, or simply record a location as bookmark User can jump to the marked location within a resource Platform defined five standard markers (marker, taskmarker, problemmark,bookmark,textmark)

21 Properties of a marker type : String id : long // unique in its resource + additional attributes depending on specific type of the parker.

22 Predefined Marker types org.eclipse.core.resource.marker (IMarker.MARKER) o.e.c.r.taskmarker (IMarker.TASK) o.e.c.r.problemmarker (IMarker.PROBLEM) o.e.c.r.bookmark (IMarker.BOOKMARK) o.e.c.r.textmarker(IMarker.TEXT) additional markers can be defined by using the extention point: o.e.c.r.markers

23 Marker type declaration id= “ type ” is the unique name (type) of the marker type * super types of this marker types. * attributes which may be present on this type of markers ? whether markers of this type should be persisted by the platform Instances can be transient if TRANSIENT attr is set to true.

24 <extension id="problemmarker “ point="org.eclipse.core.resources.markers “ name="%problemName"> <extension id="taskmarker" point="org.eclipse.core.resources.markers “ name="%taskName">

25 IMarker.BOOKMARK

26 the text marker TextMarker (IMarker.TEXT) IMarker.CHAR_START : int // (0-based) IMarker.CHAR_END : int // exclusive IMarker.LINE_NUMBER:int // 1-based IMARK.TRANSIENT: boolen // inherited used with other markers in editor framework.

27 the Bookmark and taskmarker IMareker.BOOKMARK IMarker.MESSAGE :String IMarker.LOCATION:String IMarker.TASK IMarker.PRIORITY: int IMarker.PRIORITY_HIGH, _NORMAL, _LOW IMarker.MESSAGE IMarker.DONE :boolean // completed

28 Problem Marker (o.e.c.rproblemmarker) IMarker.PROBLEM IMarker.SEVERITY :int IMarker.SEVERITY_ERROR, _WARNING, _INFO (2) (1) (0) IMarker.MESSAGE:String IMarker.LOCATION :String

29 Resource API defines methods for creating, setting value, extending the platform with new marker type Platform manage markers, it will throw away markers attached to resource that are deleted Plug-in control marker ’ s creation, removal and attribute value. It also removes markers that no longer apply to a resource Interface IMarker IMarker

30 Marker operation IResource.createMarker(type) Marker creation Using factory method IResource.createMarker() Ex: IMarker marker = file.createMarker(IMarker.TASK); // file is now the resource of marker. Marker deletion Ex: try { marker.delete(); } catch (CoreException e) { // Something went wrong }

31 Marker attributes access getAttribute(String name, T defValue ) possible : boolean, int, String. setAttribute(String name, value) possible : String, int, boolean,

32 Batch delete int depth = IResource.DEPTH_INFINITE; // others: _ZERO, _ONEIResource try { resource.deleteMarkers(IMarker.PROBLEM, true/*subType*/, depth);.deleteMarkers } catch (CoreException e) { // something went wrong } Attribute setting if (marker.exists()) { try { marker.setAttribute(IMarker.MESSAGE, "A sample marker message"); marker.setAttribute(IMarker.PRIORITY, IMarker.PRIORITY_HIGH); } catch (CoreException e) { // You need to handle the case where the marker no longer exists } }

33 Querying markers Resource can be queried for their markers and the markers of their children IMarker[] problems = null; int depth = IResource.DEPTH_INFINITE; boolean subtype = true ; try { problems = resource.findMarkers(IMarker.PROBLEM, subtype, depth); } catch (CoreException e) { // something went wrong }

34 Extend the platform with new marker type New marker type are derived from existing ones using multiple inheritance, it will inherit all of the attribute from supertypes Plug-ins must declare new marker type in plugin.xml before using it Persistent Markers saved when workspace is saved.

35 Marker extension point="org.eclipse.core.resources.markers" />

36 public IMarker createMyMarker(IResource resource){ try { Imarker marker= resource.createMarker("com.example.markers.myproblem "); // marker id marker.setAttribute("myAttribute", "MYVALUE"); return marker; } catch (CoreException e) { // You need to handle the cases where attribute value is rejected } }

37 Tracking resource changes The resource API include a event mechanism for resource changes Use IResourceChangeListener and IResourceChangeEvent to track resource change Method that create, delete or change a resource typically trigger a resource change event

38 Must register a resource change listener with the workspace IResourceChangeListener listener = new MyResourceChangeReporter(); ResourcesPlugin.getWorkspace().addResourceChangeListener( liste ner, IResourceChangeEvent.POST_CHANGE); Use IWorkspace.run(runnable,monitor) can batch the change operation, resource change event will be triggered once when the runnable is completed

39 Resource deltas Resource change event contains a resource delta that describes the net effect of change Structured as a tree rooted at the workspace root Describe four type of resource change Created, deleted, or changed Moved or renamed via IResource.move() Marker that has been added, removed, or changed Files that has been modified

40 To traverse a resource tree, implement the interface IResourceDeltaVisitor or using IResourceDelta.getAffectedChildren()

41 Resource change event PRE_CLOSE PRE_DELETE PRE_AUTOBUILD POST_AUTOBUILE POST_CHANGE

42 Implementing a resource change listener IResourceChangeListener listener = new MyResourceChangeReporter(); ResourcesPlugin.getWorkspace().addResourceChangeListener(listener, IResourceChangeEvent.PRE_CLOSE | IResourceChangeEvent.PRE_DELETE | IResourceChangeEvent.PRE_AUTO_BUILD| IResourceChangeEvent.POST_AUTO_BUILD | IResourceChangeEvent.POST_CHANGE);

43 public class MyResourceChangeReporter implements IResourceChangeListener { public void resourceChanged(IResourceChangeEvent event) { IResource res = event.getResource(); switch (event.getType()) { case IResourceChangeEvent.PRE_CLOSE: System.out.print("Project "); System.out.print(res.getFullPath()); System.out.println(" is about to close."); break; case IResourceChangeEvent.PRE_DELETE: System.out.print("Project "); System.out.print(res.getFullPath()); System.out.println(" is about to be deleted."); break; case IResourceChangeEvent.POST_CHANGE: System.out.println("Resources have changed."); event.getDelta().accept(new DeltaPrinter()); break; } } }

44 Incremental project builder Manipulate the resource in a project in a fashion defined by the builder itself Often used to apply a transformation on a resource to produce a resource or other kind Platform define two kind of builds Full build Incremental build

45 Incremental builds are seeded with a resource change delta to reflect the net effect of all resource change

46 Invoke a build A build can be invoked in two ways IProject.build() for the reciving project IWorkspace.build() for all open project in the workspace An incremental project builders are also invoked implicitly by the platform during an auto-build

47 Defining an incremental project builder <builder

48 public class BuilderExample extends IncrementalProjectBuilder{ IProject[] build(int kind, Map args, IProgressMonitor monitor) throws CoreException { // add your build logic here return null; } Protected void startupOnInitialize() { // add builder init logic here } }

49 Builder implementation protected IProject[] build(int kind, Map args, IProgressMonitor monitor throws CoreException { if (kind == IncrementalProjectBuilder.FULL_BUILD) { fullBuild(monitor); } //full build else { IResourceDelta delta = getDelta(getProject()); if (delta == null) { fullBuild(monitor); } // auto build else { incrementalBuild(delta, monitor); } } return null; }

50 protected void fullBuild(final IProgressMonitor monitor) throws CoreException { try { getProject().accept(new MyBuildVisitor()); } catch (CoreException e) { } } class MyBuildVisitor implements IResourceVisitor { public boolean visit(IResource res) { //build the specified resource. //return true to continue visiting children. return true; }

51 protected void incrementalBuild(IResourceDelta delta, IProgressMonitor monitor) throws CoreException { // the visitor does the work. delta.accept(new MyBuildDeltaVisitor()); }

52 Association an incremental project builder with a project IProjectDescription desc = project.getDescription(); ICommand[] commands = desc.getBuildSpec(); boolean found = false; for (int i = 0; i < commands.length; ++i) { if (commands[i].getBuilderName().equals(BUILDER_ID)) { found = true; break; } } if (!found) { //add builder to project ICommand command = desc.newCommand(); command.setBuilderName(BUILDER_ID); ICommand[] newCommands = new ICommand[commands.length + 1];

53 // Add it before other builders. System.arraycopy(commands, 0, newCommands, 1, commands.length); newCommands[0] = command; desc.setBuildSpec(newCommands); project.setDescription(desc, null); }

54 Workspace save participation Plug-in can participate in workspace save process to save plug-in data To participate in saving, add a save participation to the workspace in plug-in startup() method ResourcesPlugin.getWorkspace().addSaveParticipa nt(this, saveParticipant);

55 Save participation implementation Interface ISaveParticipant defines the protocol for a workspace save participation Provide behavior for different stages of the save process Implement method for each stage

56 Saving steps prepareToSave Notify the participant the workspace is about to be saved, it should suspend normal operation saving Tell the participant to save its important state

57 doneSaving Notifies the participant that the workspace has been saved and the participant can continue normal operation rollback Tells the participant to rollback the important state because the save operation has failed

58 Project natures Allow a plug-in to tag a project as a specific kink of project A project can have more then one nature Special constrains for the nature One-of-nature Requires-nature Interface IProjectNature

59 Defining a nature <extension point="org.eclipse.core.resources.natures" id="myNature" name="My Nature">

60 Implement a nature public class MyNature implements IProjectNature { private IProject project; public void configure() throws CoreException { // Add nature-specific information // for the project, such as adding a builder // to a project's build spec. } public void deconfigure() throws CoreException { // Remove the nature-specific information here. } public IProject getProject() { return project; } public void setProject(IProject value) { project = value; } }

61 Associate a nature to a project try { IProjectDescription description = project.getDescription(); String[] natures = description.getNatureIds(); String[] newNatures = new String[natures.length + 1]; System.arraycopy(natures, 0, newNatures, 0, natures.length); newNatures[natures.length] = "com.example.natures.myNature"; description.setNatureIds(newNatures); project.setDescription(description, null); } catch (CoreException e) { // Something went wrong }

62 Derived resources Resources that are not original data, and can be recreated from their source files Use IResource.setDerived(boolean) to indicate that a resource is derived Use IResource.isDerived() to determine a resource is derived

63 Resource modification hooks Enable the team support plug-in


Download ppt "Eclipse resource management. Outline Introduction Basic resource management Further resource management."

Similar presentations


Ads by Google