-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
238 lines (162 loc) · 9.51 KB
/
README.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
README
======
About my Zaurus
---------------
Model: SL-C1000
ROM Version: 1.01 JP
Kernel: 2.4.20
Environment: Qtopia 1.5.4 (This is Sharp's closed-source version); Qt 2.3.2.
Some features of Qt are not included in this binary version on Qt. To get the list of available features, take a look at the file /opt/Qtopia/include/qfeatures.h. For example, QInputDialog is not defined. That's why I had to implement PromptDialog. The class has been removed since though.
How to build the application
----------------------------
In order to build the application, it's more convenient to do it on a Linux machine with a faster processor and more memory. Using another machine to compile an application that will work on a different architecture is what we call cross-compiling. It's probably possible to compile the application natively on the Zaurus itself but I have never considered the idea. It already takes 42 seconds on a Core2 Duo E6300 with more than 2 GB of RAM memory, imagine on the Zaurus...
So here is what I did to set up Debian (stable) machine to cross-compile Zaurus application :
The main problem was to find the right documentation... There is a lot of links everywhere but it's not always clear for which configuration and for which environment.
I've made 2 or 3 attempts to setup the cross-compiling environment. The best link I found is this one :
http://www.ossh.com/zaurus/mirrors/docs.zaurus.com/linux_compiler_setup_howto.shtml
where I found all the required packages (see rpm files included in etc/QtopiaDevRPM).
So here is basically what I did :
$ su
$ aptitude install gcc-2.95
$ aptitude install g++-2.95
$ aptitude install alien
$ alien -i gcc-cross-sa1100-2.95.2-0.i386.rpm
$ alien -i binutils-cross-arm-2.11.2-0.i386.rpm
$ alien -i glibc-arm-2.2.2-0.i386.rpm
$ alien -i linux-headers-arm-sa1100-2.4.6-3.i386.rpm
$ alien -i qtopia-free-1.5.0-1.i386.rpm
$ aptitude install qt3-dev-tools qt3-linguist
$ exit
At this moment, my setup is pretty much complete. I can compile and test the example application and it runs either on my Debian machine or my Zaurus. For more details, read the documention in /opt/Qtopia/doc/index.html.
Important! I renamed/changed my $PATH to use the proper gcc/g++ (gcc on /opt/... or gcc-2.95) or manually changed it in the Makefile. But a better approach is rather to use environment variable instead. To do that, add the -e option when using make (e.g.: make -e). Check bin/dev-x86-qpe.sh for details. Using more recent version of gcc/g++ do NOT work!
The same procedure works for Ubuntu.
Common operations
-----------------
To generate/update the translation file (.ts) :
$ lupdate -verbose toMOTko.pro
To compile the string files (.qm) :
$ lrelease -verbose toMOTko.pro
To generate the project file (not needed anymore but just in case):
$ progen -o toMOTko.pro
To build the Makefile :
$ tmake -o Makefile toMOTko.pro
To build the application on Linux :
$ source bin/dev-x86-qpe.sh
$ tmake -o Makefile toMOTko.pro
$ make clean
$ make -e
$ lrelease -verbose toMOTko.pro
$ su
$ source bin/dev-x86-qpe.sh
$ bin/deploy.sh
$ exit
To test the application on linux :
In a separate console :
$ source bin/dev-x86-qpe.sh
$ bin/zaurus.sh
This will launch an emulator where toMOTko application will run.
To launch the application :
In another console :
$ ./toMOTko
(The application should start if the emulator is running properly.)
To build and package the application for the zaurus :
$ source bin/dev-arm-qpe.sh
$ tmake -o Makefile toMOTko.pro
$ make clean
$ make
$ lrelease -verbose toMOTko.pro
$ su
$ source bin/dev-arm-qpe.sh
$ bin/deploy.sh
$ bin/mkipk.sh
$ chown fred.fred toMOTko_x.y.z_arm.ipk
$ exit
$ cd zaurus/toMOTko/trunk
$ scp toMOTko_x.y.z_arm.ipk zaurus@zaurus:Documents/Install_Files/.
And we uninstall and reinstall the new version.
IMPORTANT (for me only!) : To install toMOTko, it is mandatory to use ipkg.old on MY zaurus. The latest version of ipkg that I have installed is buggy. I should remove it but I'm a little bit scared of doing ipkg remove ipkg for obvious reasons. Because of this, I cannot install toMOTko using Sharp's Add/Remove Applications program. For other people, ipkg or the GUI Package Manager should work fine so substitute ipkg.old by ipkg in the following commands:
$ su
$ ipkg.old remove toMOTko
$ ipkg.old install toMOTko_x.y.z_arm.ipk
What to do before a release
---------------------------
- Update version number in the About dialog, control file and preinst script.
- Update online documentation if necessary (screenshots, new features, etc.)
- Remove traces if any.
- Build latest ipk file.
- Test it.
- Update version number in the website (version.txt), Doxygen.
- Update website if necessary (screenshots, new features, download link, etc.)
- Run doxygen to update the documentation.
- Upload latest ipk file: cadaver https://frs.sourceforge.net/f/fb/fbergeron/uploads and then: put toMOTko_x.y.z_arm.ipk
- Update the change log file and its date (changes.log + www/en/history.shtml).
- Create the new release on SourceForge (hide it first, then use preformatted format and insert enter in the text).
- Upload the doxygen doc : cd $TOMOTKO_HOME/doc;rsync -ruv --exclude=.svn * [email protected]:tomotko_html/doc
- Upload the online doc : cd $TOMOTKO_HOME/help;rsync -ruv --exclude=.svn * [email protected]:tomotko_html/help
- Upload the latest screenshots.
- Write release notes and changes.
- Check in all changes.
- Upload new website : cd $TOMOTKO_HOME/www;rsync -ruv --exclude=.svn * [email protected]:tomotko_html
- Post news to announce the release.
- Close bugs in bug tracker if any.
- Do the same thing for Freshmeat, ELSI and http://www.handheld-linux.com (screenshots, release, changes).
- Tag the new version in SVN : svn copy https://tomotko.svn.sourceforge.net/svnroot/tomotko/trunk https://tomotko.svn.sourceforge.net/svnroot/tomotko/tags/release-0.X.0 -m "Tagging the 0.X.0 release."
Learned lessons and/or interesting things to know
=================================================
For a QListView that allows multiple selection, selectedItem() cannot be used. We have to iterate through all the QListItem to find the first selected one even though we know that there is only one selected.
When changing a font of a widget, it's important to call updateGeometry() and ->layout()->invalidate() on the parent panel. Curiously, the call order doesn't seem important...
The compiled version of Qt for Zaurus doesn't support QClipboard->setData() so I cannot use binary data in the clipboard.
Concerning setScaledContents() : It works only for pixmap not for movie (animated gif).
To find the UTF-8 character number for a specific kanji, use this :
http://www.fileformat.info/info/unicode/char/search.htm
Enter the kanji and look for UTF-8 (hex)
To round up a positive float number in C++: uint roundedValue = (uint)( val + 0.5 );
About zlib
----------
I downloaded the source code from the zlib website.
The latest version was zlib-1.2.3. The same version that is already installed on my system.
I think that if I had wanted a different version, that I should have done this procedure :
To build the .so file, as written in the INSTALL file :
cd zaurus/zlib-1.2.1
# I don't know if it's necessary. This is for using gcc-2.95.
source ../tomotko/trunk/bin/dev-x86-qpe.sh
./configure --shared
# make clean;make
To install it at the right place :
# su
# cp libz.so.1.2.1 /opt/Qtopia/lib
# cd /opt/Qtopia/lib
# ln -s libz.so.1.2.1 libz.so
# ln -s libz.so.1.2.1 libz.so.1
I also had to install the header files (zlib.h, zconf.h, etc.).
# su
# cp zlib.h /opt/Qtopia/include
# cp zconf.h /opt/Qtopia/include
To use zlib library in toMOTko, I added in toMOTko.pro a reference to the library : -lz
When I build the application in x86 environment, neither the compiler or the linker complain. It works.
After that, I need to do the same for ARM environment. Instead of building a so file, I found one on Internet. It's a file named : zlib_2.3_arm.ipk. I renamed it to .tgz and extracted the so files that I installed into /opt/Qtopia/sharp/lib :
# su
# cp libz.so.1.2.3 /opt/Qtopia/sharp/lib
# cd /opt/Qtopia/sharp/lib
# ln -s libz.so.1.2.3 libz.so
# ln -s libz.so.1.2.3 libz.so.1
To compile, it may be necessary to put some header files (zlib.h, zconf.h, etc.) into /opt/Qtopia/sharp/include.
For very good information about all this setup, look at the file README.zaurus of the crimson project.
zlib provides minizip (in the contrib directory) that is an implementation of zip and unzip. Unfortunately, according to :
http://forum.winimage.com/viewtopic.php?t=100&highlight=accents+national+chars
http://forum.winimage.com/viewtopic.php?t=2056&highlight=unicode
It doesn't support utf-8 encoded filenames inside the archive. Because of this, I decided to use numeric id for folders and vocabularies inside the archive. It's not ideal but it's good enough.
Just for the record, on toMOTko-0.8.0, my glossary files were taking 2.6 MB and it took 16 seconds for the application to start.
After integrating zlib, the glossary files take 1.0 MB and it takes 12 seconds for the application to start.
It's no big deal but better than nothing. To write all the glossary files in compressed format, it took 95 seconds.
This operation is done the first time we quit toMOTko-0.9.0.
To generate thumbnails for screenshots, we can use a command like this one :
# cd img
> for img in *.png
> do
> convert $img -resize 50% ${img%%.png}_small.png
> done
Miscellaneous
-------------
To connect with ssh on tomotko's website:
ssh -t fbergeron,[email protected] create