Difference between revisions of "Teams Winter 2011/team4/lab2"
(→Implement the Service Consumer) |
(→Implement the Service Provider) |
||
Line 27: | Line 27: | ||
* Essentially, the strating steps to creating the service provider are almost identical to the starting steps of creating the service interface | * Essentially, the strating steps to creating the service provider are almost identical to the starting steps of creating the service interface | ||
* The only difference here is after creating your plugin project (refer to previous steps for how-to) before clicking finish this time you '''MUST''' make sure generate an activator is checked, as we will need it this time. | * The only difference here is after creating your plugin project (refer to previous steps for how-to) before clicking finish this time you '''MUST''' make sure generate an activator is checked, as we will need it this time. | ||
+ | ===Define the MANIFEST.MF for the service provider bundle=== | ||
* By selecting generate activator, when Eclipse creates your plugin, it also creates an activator class which is used to handle the lifecycle of the plug-in and provides access to both the underlying OSGi system and the content of the plug-in. | * By selecting generate activator, when Eclipse creates your plugin, it also creates an activator class which is used to handle the lifecycle of the plug-in and provides access to both the underlying OSGi system and the content of the plug-in. | ||
+ | [[File:T4L2-6.png]] | ||
* In the previous step we exported our package for later use, it is now time to import this package. To do so, click on your MANIFEST.MF file, select the dependencies tab, and under the the right heading Imported Packages, select the add button (refer to picture below) | * In the previous step we exported our package for later use, it is now time to import this package. To do so, click on your MANIFEST.MF file, select the dependencies tab, and under the the right heading Imported Packages, select the add button (refer to picture below) | ||
+ | [[File:T4L2-7.png]] | ||
* Like before, enter the name of your package and select ok. | * Like before, enter the name of your package and select ok. | ||
− | === | + | ===Install and run the Service Provider Bundle=== |
* It is now time to run the service provider bundle we have created | * It is now time to run the service provider bundle we have created | ||
* Right click on your MANIFEST.MF and select Run As->Run Configuration | * Right click on your MANIFEST.MF and select Run As->Run Configuration | ||
* Now RIght click OSGi Framework and select New | * Now RIght click OSGi Framework and select New | ||
* Your workspace should now be populated with numerous options | * Your workspace should now be populated with numerous options | ||
+ | [[File:T4L2-8.png]] | ||
* Uncheck target platform (by default it is selected) then click Add required bundles, and then click the checkbox Only show selected | * Uncheck target platform (by default it is selected) then click Add required bundles, and then click the checkbox Only show selected | ||
* Your workspace should look similar to this: | * Your workspace should look similar to this: | ||
* Now click Run in the bottom right of your workspace, if everything went correctly, you will see a message saying '''osgi> TimeZones System Registered !''' | * Now click Run in the bottom right of your workspace, if everything went correctly, you will see a message saying '''osgi> TimeZones System Registered !''' |
Revision as of 22:35, 16 February 2011
Lab 2
Tutorial
Create the Service Interface
Define the service interface
- First download Eclipse Classic from here
Create the Interface Bundle
- We now need to create a new plugin project, to do so do the following: File->New->Plug-in Project
- After selecting Plug-in Project from the options, give the Project a name according to the lab structure defined in the previous tutorial (cs.ecl.lab.<name here>
- After doing so, click next, where you will be presented with a screen that provides you with the project ID, version, name, ect. There will be an options section at the bottom of the window, be sure to unclick generate an activator, as it is not needed for the lab as the bundel is just interfaces and it is not run
- You will now be presented with a screen that looks like the following:
Creating the Interface
- We will now add a package to the src folder of our project. Once you have done this you will add a class TimeZones and an Interface name Times to your package.
- Enter code in both TimeZones and Times according to the following:
- If we want to use our package, we must export it in the interface bundle. First select MANIFEST.MF, then click on the runtime tab, and select "Add", then select your package. (Refer to Image below)
- Congratulations! You have successfully exported your package and we are ready to move onto step 2, implementing the Service Provider.
Implement the Service Provider
Create the Provider Bundle
- Essentially, the strating steps to creating the service provider are almost identical to the starting steps of creating the service interface
- The only difference here is after creating your plugin project (refer to previous steps for how-to) before clicking finish this time you MUST make sure generate an activator is checked, as we will need it this time.
Define the MANIFEST.MF for the service provider bundle
- By selecting generate activator, when Eclipse creates your plugin, it also creates an activator class which is used to handle the lifecycle of the plug-in and provides access to both the underlying OSGi system and the content of the plug-in.
- In the previous step we exported our package for later use, it is now time to import this package. To do so, click on your MANIFEST.MF file, select the dependencies tab, and under the the right heading Imported Packages, select the add button (refer to picture below)
- Like before, enter the name of your package and select ok.
Install and run the Service Provider Bundle
- It is now time to run the service provider bundle we have created
- Right click on your MANIFEST.MF and select Run As->Run Configuration
- Now RIght click OSGi Framework and select New
- Your workspace should now be populated with numerous options
- Uncheck target platform (by default it is selected) then click Add required bundles, and then click the checkbox Only show selected
- Your workspace should look similar to this:
- Now click Run in the bottom right of your workspace, if everything went correctly, you will see a message saying osgi> TimeZones System Registered !