uf:application
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
uf:application [2008/09/05 11:52] – tvcutsem | uf:application [2009/11/18 14:41] (current) – adding elisag | ||
---|---|---|---|
Line 1: | Line 1: | ||
===== Applications ===== | ===== Applications ===== | ||
- | The most important property of an application in Urbiflock is that it should be easy to share it with your friends. | + | Applications |
- | Applications can: | + | In addition, Urbiflock applications have access to the user's flocks and the flockrs who have installed the same application on their devices. Every application has two different interfaces which allows it to interact with the framework: a local and a remote one. This distinction between local and remote interfaces has been introduced for reasons of security: methods defined in the local interface can only be called by local objects or the flockr, while other flockr' |
- | * Access a user's profile (but not change it?) | + | |
- | * Access a user's flocks | + | ===== Programmers Perspective ===== |
- | * Create new flocks (and thus new proximities) | + | Applications are simply containers for some named pieces of code that can make use of the features of the framework, that can be easily launched from the UrbiFlock application launcher, and that can be shared over the network. |
- | * Add actions (" | + | |
- | * Store their settings persistently | + | The most important property of an application in Urbiflock is that it should be easy to share it with your friends. Applications should thus be mobile entities that can be passed to your friends and received from your friends. This is still TODO. |
- | * Be installed at runtime | + | |
- | * Be copied to another flockr at runtime | + | |
- | * Be minimized, stopped, paused, restarted? | + | |
The mobility requirement needs some thought in how we are going to structure applications: | The mobility requirement needs some thought in how we are going to structure applications: | ||
Line 18: | Line 15: | ||
< | < | ||
+ | |||
+ | Every application should implement at least a start() method. This method should launch the application. It is called by the application launcher when the application button is clicked. | ||
+ | |||
+ | ===== Local API ===== | ||
+ | * name() | ||
+ | * owner() | ||
+ | * registerApplicationListener(type, | ||
+ | * start(): does nothing if not overridden. Is called by the launcher. | ||
+ | * pause(): does nothing if not overridden. | ||
+ | * unpause(): does nothing if not overridden. | ||
+ | * stop(): takes offline the application. Is called when the application is closed. | ||
+ | * export(asType): | ||
+ | |||
+ | ===== Remote API ===== | ||
+ | * name() | ||
+ | * getOwnerAndProfile(): | ||
+ | |
uf/application.1220608321.txt.gz · Last modified: 2009/02/27 16:13 (external edit)