-
Notifications
You must be signed in to change notification settings - Fork 237
/
introduction.txt
88 lines (53 loc) · 3.92 KB
/
introduction.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# Rhodes
## Introduction
Rhodes is a framework for building locally executing, device-optimized mobile applications. These applications are optimized for interacting with transactional enterprise application backends. It is also designed to work with synced local data using a local database such as SQLite or HSQLDB and a generic backend synchronization framework such as [RhoSync](../rhosync) (another open source component available from [Rhomobile](http://rhomobile.com)). Rhodes is available for iPhone, Research in Motion (Blackberry), Windows Mobile, and Android phones.
The [Tutorial](tutorial) describes how to install Rhodes and start on building your apps. The rest of this Developer Reference covers all Rhodes features.
## Supported Operating Systems
### BlackBerry
BlackBerry 4.6, 4.7, 5.0, 6.0
NOTE: 4.2 and 4.5 are supported but database access is very slow on this devices.
### Windows Mobile
Windows Mobile 6.1 Professional, 6.0 Standard
### Android
Android 1.6 and greater
### iPhone
All versions of iPhone 3.0 or greater, iPad
## Rhodes Application
Rhodes Application is a web application running locally on the device. It is implement standard MVC architecture:
* Views are set of ERB templates, HTML, CSS, and JavaScript files executed by the WebView control available on the device and served by the local web server. That server is very lightweight web server running on the device. See [User Interface](ui) section for more details on [Layouts](ui#view-layouts), [CSS framework](ui#css-framework), [JavaScrip frameworks](ui#javascript-frameworks), [Menus](ui#menu), and [Native UI elements](ui#native-toolbar-control) you may use in the View.
* Controllers are set of usually very simple Ruby scripts in controller.rb files. You have access to many [native device capabilities](device-caps) from your controllers.
* Models are defined by a Ruby script in model.rb file.
See Rhodes [App Structure](application) topic for more details.
You may generate Rhodes Application using [rhodes](generator) utility.
## Contributing
Want to add features to Rhodes? Found a bug that you want report or fix?
### Report Rhodes Issues
Please report bugs/features/enhancements to the [google group](http://groups.google.com/group/rhomobile).
### Run Rhodes Specs
First run the rhodes specs to make sure your environment is up-to-date for development (currently the specs only run on OSX):
[Fork](http://help.github.com/forking/) the [Rhodes repository](http://github.com/rhomobile/rhodes).
Clone your new repo:
:::term
$ git clone git://github.com/<yourhandle>/rhodes.git
$ cd rhodes
$ bin/rhodes-setup
Run Rhodes framework_spec and phone_spec targets
:::term
$ rake run:allspecs
If everything passes (pending specs are OK), then your environment is ready for development. If you have trouble installing a particular gem or the specs just won't run properly, please feel free to ping the [rhomobile google group](mailto:rhomobile@googlegroups.com) or [hop on IRC](http://webchat.freenode.net/?channels=rhomobile) to chat with other Rhodes developers.
### Contributing your Patch
Now that you're environment is ready, make your changes!
Create a topic branch:
:::term
$ git checkout -b cool_new_feature
Write tests, [for example](http://github.com/rhomobile/rhodes/blob/a905e9c9781bfe6e5003e8c8a11cd5418b08df73/spec/framework_spec/app/spec/rhom_object_spec.rb#L239).
Make changes...
Add relevant documentation (RDoc, update the README if relevant)
Push to your branch:
:::term
$ git push origin cool_new_feature
Send a note to the [google group](http://groups.google.com/group/rhomobile)
That's it! We recommend following [these ruby style guidelines](http://github.com/chneukirchen/styleguide/blob/master/RUBY-STYLE) when coding.
If you are interested us using your patch to Rhodes you will need to submit a [contribution agreement](http://rhomobile.com/community/contributing/) to us.
## Framework Architecture
<img src='/images/rhodes-framework.png'/>