2008-04-22 18:53:53 -04:00
|
|
|
Curl on Symbian OS
|
|
|
|
==================
|
|
|
|
This is a basic port of curl and libcurl to Symbian OS. The port is
|
|
|
|
a straightforward one using Symbian's P.I.P.S. POSIX compatibility
|
|
|
|
layer. A more complete port would involve writing a Symbian C++ binding,
|
|
|
|
or wrapping libcurl as a Symbian application server with a C++ API to
|
|
|
|
handle requests from client applications and creating a GUI application
|
|
|
|
to allow file transfers. The author has no current plans to do so.
|
|
|
|
|
|
|
|
This means that integration with standard Symbian OS programs can be
|
|
|
|
tricky, since libcurl isn't designed with Symbian's native asynchronous
|
|
|
|
message passing idioms in mind. However, it may be possible to use libcurl
|
|
|
|
in an active object-based application through libcurl's multi interface.
|
|
|
|
The port is most easily used when porting POSIX applications to Symbian
|
|
|
|
OS using P.I.P.S.
|
|
|
|
|
|
|
|
libcurl is built as a standard Symbian ordinal-linked DLL, and curl is
|
|
|
|
built as a text mode EXE application. They have not been Symbian
|
|
|
|
Signed, which is required in order to install them on most phones.
|
|
|
|
|
|
|
|
Following are some things to keep in mind when using this port.
|
|
|
|
|
2008-05-14 19:38:21 -04:00
|
|
|
|
2008-04-22 18:53:53 -04:00
|
|
|
curl notes
|
|
|
|
----------
|
|
|
|
When starting curl in the Windows emulator from the Windows command-line,
|
|
|
|
place a double-dash -- before the first curl command-line option.
|
|
|
|
e.g. \epoc32\release\winscw\udeb\curl -- -v http://localhost/
|
|
|
|
Failure to do so may mean that some of your options won't be correctly
|
|
|
|
processed.
|
|
|
|
|
|
|
|
Symbian OS does not provide for redirecting the standard I/O streams, so
|
2008-04-24 19:24:57 -04:00
|
|
|
stdin always comes from the keyboard, stdout always goes to the
|
|
|
|
console, and stderr goes to the epocwind.out file (on the emulator).
|
|
|
|
The standard curl options -o, --stderr and --trace-ascii can be used to
|
|
|
|
redirect output to a file (or stdout) instead.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
2008-05-13 13:50:03 -04:00
|
|
|
P.I.P.S. doesn't inherit the current working directory at startup, so the
|
|
|
|
-O option probably won't work as expected, and giving the complete paths
|
|
|
|
to files will be necessary.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
|
|
|
P.I.P.S. provides no way to disable echoing of characters as they are
|
2008-05-14 19:38:21 -04:00
|
|
|
entered, so passwords typed in on the console will be visible. It also
|
|
|
|
line buffers keyboard input so interactive telnet sessions are not very
|
|
|
|
feasible.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
2008-05-14 19:38:21 -04:00
|
|
|
All screen output disappears after curl exits, so after a command completes,
|
2008-05-13 13:50:03 -04:00
|
|
|
curl waits by default for Enter to be pressed before exiting. This behaviour
|
2008-04-22 18:53:53 -04:00
|
|
|
is suppressed when the -s option is given.
|
|
|
|
|
2008-05-13 13:50:03 -04:00
|
|
|
curl's "home directory" in Symbian is C:\Private\f0206442\. The .curlrc file
|
|
|
|
is read from this directory on startup.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
2008-05-14 19:38:21 -04:00
|
|
|
|
2008-04-22 18:53:53 -04:00
|
|
|
libcurl notes
|
|
|
|
-------------
|
2008-05-13 13:50:03 -04:00
|
|
|
libcurl uses writable static data, so the EPOCALLOWDLLDATA option is
|
2008-04-22 18:53:53 -04:00
|
|
|
used in its MMP file, with the corresponding additional memory usage
|
|
|
|
and limitations on the Windows emulator.
|
|
|
|
|
2008-05-13 13:50:03 -04:00
|
|
|
curl_global_init() *must* be called (either explicitly or implicitly through
|
|
|
|
calling certain other libcurl functions) before any libcurl functions
|
|
|
|
that could allocate memory (like curl_getenv()).
|
2008-04-22 18:53:53 -04:00
|
|
|
|
|
|
|
P.I.P.S. doesn't support signals or the alarm() call, so some timeouts
|
|
|
|
(such as the connect timeout) are not honoured.
|
|
|
|
|
2008-05-13 13:50:03 -04:00
|
|
|
P.I.P.S. causes a USER:87 panic if certain timeouts much longer than
|
|
|
|
half an hour are selected.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
2008-05-13 13:50:03 -04:00
|
|
|
SSL/TLS encryption is not supported, nor are LDAP, SCP or SFTP URLs.
|
2008-04-22 18:53:53 -04:00
|
|
|
|
2008-05-14 19:38:21 -04:00
|
|
|
Debug builds are not supported (i.e. --enable-debug) because they cause
|
|
|
|
additional symbol exports in the library which are not frozen in the .def
|
|
|
|
files.
|
|
|
|
|
2008-04-22 18:53:53 -04:00
|
|
|
|
|
|
|
Dan Fandrich
|
|
|
|
dan@coneharvesters.com
|
2008-05-13 13:50:03 -04:00
|
|
|
May 2008
|