data:image/s3,"s3://crabby-images/22677/22677e2f3f1fa30f7c5077d3dfbf13ac7aaa9974" alt="Alfresco Developer Guide"
Setting up the SDK in Eclipse
Nothing about Alfresco requires you to use Eclipse or any other IDE. But Eclipse is very widely used and the Alfresco SDK distribution includes Eclipse projects that can easily be imported into Eclipse, so that's what these instructions will cover.
In addition to the Alfresco JARs, dependent JARs, Javadocs, and source code, the SDK bundle has several Eclipse projects. Most of the Eclipse projects are sample projects showing how to write code for a particular area of Alfresco. Two are special, however. The SDK AlfrescoEmbedded project and the SDK AlfrescoRemote project reference all of the JARs needed for the Java API and the Web Services API respectively. The easiest way to make sure your own Eclipse project has everything it needs to compile is to import the projects bundled with the SDK into your Eclipse workspace, and then add the appropriate SDK projects to your project's build path.
Step-by-Step: Importing the SDK into Eclipse
Every developer has his or her own favorite way of configuring tools. If you are going to work with multiple versions of Alfresco, you should use version-specific Eclipse workspaces. For example, you might want to have a workspace-alfresco-2.2
workspace as well as a workspace-alfresco-3.0
workspace, each with the corresponding Alfresco SDK projects imported. Then, if you need to test customizations against a different version of the Alfresco SDK, all you have to do is switch your workspace, import your customization project if it isn't in the workspace already, and build it. Let's go ahead and set this up. Follow these steps:
- In Eclipse, select File|Switch Workspace or specify a new workspace location. This will be your workspace for a specific version of the Alfresco SDK so use a name such as
workspace-alfresco-3.0
. Eclipse will restart with an empty workspace. - Make sure the Java compiler compliance level preference is set to 5.0 (Window|Preferences|Java|Compiler). If you forget to do that, Eclipse won't be able to build the projects after they are imported.
- Select File|Import|Existing Projects into Workspace. For the root directory, specify the directory where the SDK was uncompressed.
- Select all of the projects that are listed and click Import.
After the import, Eclipse should be able to build all projects cleanly. If not, double-check the compiler compliance level. If that is set but there are still errors, make sure you imported all SDK projects including SDK AlfrescoEmbedded and SDK AlfrescoRemote.
Now that the files are in the workspace, take a look at the Embedded project. That's quite a list of dependent JAR files! The Alfresco-specific JARs all start with alfresco-
. It depends on what you are doing, of course, but the JAR that is referenced most often is likely to be alfresco-repository.jar
because that's where the bulk of the API resides.
The SDK comes with zipped source code and Javadocs, which are both useful references (although the Javadocs are pretty sparse). It's a good idea to tell Eclipse where those files are, so you can drill in to the Alfresco source when debugging. To do that, right-click on the Alfresco JAR, and then select Properties. You'll see panels for Java Source Attachment and Javadoc Location that you can use to associate the JAR with the appropriate source and Javadoc archives.
The following image shows the Java Source Attachment for alfresco-repository.jar
:
data:image/s3,"s3://crabby-images/05305/05305a9556dcec27a91c6401bd90a81bcc9540df" alt="Step-by-Step: Importing the SDK into Eclipse"
The following image shows the Javadoc Location panel for alfresco-repository.jar
.
data:image/s3,"s3://crabby-images/32447/3244771be6512934339c7c589f82fef8ad591fc3" alt="Step-by-Step: Importing the SDK into Eclipse"
Source and Javadoc are provided for each of the Alfresco JARs, as shown in the following table. Note that source and Javadoc for everything is available. This is open source software after all, not just all bundled with the SDK:
data:image/s3,"s3://crabby-images/0b6ad/0b6ad269f5777ce53a2bbef7cd72c8720006e595" alt=""