diff options
Diffstat (limited to 'plugins/FTPFileYM/curl-7.29.0/docs/INSTALL')
| -rw-r--r-- | plugins/FTPFileYM/curl-7.29.0/docs/INSTALL | 1130 | 
1 files changed, 1130 insertions, 0 deletions
| diff --git a/plugins/FTPFileYM/curl-7.29.0/docs/INSTALL b/plugins/FTPFileYM/curl-7.29.0/docs/INSTALL new file mode 100644 index 0000000000..def3ce81e4 --- /dev/null +++ b/plugins/FTPFileYM/curl-7.29.0/docs/INSTALL @@ -0,0 +1,1130 @@ +                                  _   _ ____  _ +                              ___| | | |  _ \| | +                             / __| | | | |_) | | +                            | (__| |_| |  _ <| |___ +                             \___|\___/|_| \_\_____| + +                                How To Compile + +Installing Binary Packages +========================== + +   Lots of people download binary distributions of curl and libcurl. This +   document does not describe how to install curl or libcurl using such a +   binary package. This document describes how to compile, build and install +   curl and libcurl from source code. + +Building from git +================= + +   If you get your code off a git repository, see the GIT-INFO file in the +   root directory for specific instructions on how to proceed. + +UNIX +==== +   A normal unix installation is made in three or four steps (after you've +   unpacked the source archive): + +        ./configure +        make +        make test (optional) +        make install + +   You probably need to be root when doing the last command. + +   If you have checked out the sources from the git repository, read the +   GIT-INFO on how to proceed. + +   Get a full listing of all available configure options by invoking it like: + +        ./configure --help + +   If you want to install curl in a different file hierarchy than /usr/local, +   you need to specify that already when running configure: + +        ./configure --prefix=/path/to/curl/tree + +   If you happen to have write permission in that directory, you can do 'make +   install' without being root. An example of this would be to make a local +   install in your own home directory: + +        ./configure --prefix=$HOME +        make +        make install + +   The configure script always tries to find a working SSL library unless +   explicitly told not to. If you have OpenSSL installed in the default search +   path for your compiler/linker, you don't need to do anything special. If +   you have OpenSSL installed in /usr/local/ssl, you can run configure like: + +        ./configure --with-ssl + +   If you have OpenSSL installed somewhere else (for example, /opt/OpenSSL) +   and you have pkg-config installed, set the pkg-config path first, like this: + +        env PKG_CONFIG_PATH=/opt/OpenSSL/lib/pkgconfig ./configure --with-ssl + +   Without pkg-config installed, use this: + +        ./configure --with-ssl=/opt/OpenSSL + +   If you insist on forcing a build without SSL support, even though you may +   have OpenSSL installed in your system, you can run configure like this: + +        ./configure --without-ssl + +   If you have OpenSSL installed, but with the libraries in one place and the +   header files somewhere else, you have to set the LDFLAGS and CPPFLAGS +   environment variables prior to running configure.  Something like this +   should work: + +     (with the Bourne shell and its clones): + +        CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \ +           ./configure + +     (with csh, tcsh and their clones): + +        env CPPFLAGS="-I/path/to/ssl/include" LDFLAGS="-L/path/to/ssl/lib" \ +           ./configure + +   If you have shared SSL libs installed in a directory where your run-time +   linker doesn't find them (which usually causes configure failures), you can +   provide the -R option to ld on some operating systems to set a hard-coded +   path to the run-time linker: + +        env LDFLAGS=-R/usr/local/ssl/lib ./configure --with-ssl + +   MORE OPTIONS +   ------------ + +     To force configure to use the standard cc compiler if both cc and gcc are +     present, run configure like + +       CC=cc ./configure +         or +       env CC=cc ./configure + +     To force a static library compile, disable the shared library creation +     by running configure like: + +       ./configure --disable-shared + +     To tell the configure script to skip searching for thread-safe functions, +     add an option like: + +       ./configure --disable-thread + +     To build curl with kerberos4 support enabled, curl requires the krb4 libs +     and headers installed. You can then use a set of options to tell +     configure where those are: + +          --with-krb4-includes[=DIR]   Specify location of kerberos4 headers +          --with-krb4-libs[=DIR]       Specify location of kerberos4 libs +          --with-krb4[=DIR]            where to look for Kerberos4 + +     In most cases, /usr/athena is the install prefix and then it works with + +       ./configure --with-krb4=/usr/athena + +     If you're a curl developer and use gcc, you might want to enable more +     debug options with the --enable-debug option. + +     curl can be built to use a whole range of libraries to provide various +     useful services, and configure will try to auto-detect a decent +     default. But if you want to alter it, you can select how to deal with +     each individual library. + +     To build with GnuTLS for SSL/TLS, use both --without-ssl and +     --with-gnutls. + +     To build with Cyassl for SSL/TLS, use both --without-ssl and +     --with-cyassl. + +     To build with NSS for SSL/TLS, use both --without-ssl and --with-nss. + +     To build with PolarSSL for SSL/TLS, use both --without-ssl and +     --with-polarssl. + +     To build with axTLS for SSL/TLS, use both --without-ssl and --with-axtls. + +     To get GSSAPI support, build with --with-gssapi and have the MIT or +     Heimdal Kerberos 5 packages installed. + +     To get support for SCP and SFTP, build with --with-libssh2 and have +     libssh2 0.16 or later installed. + +     To get Metalink support, build with --with-libmetalink and have the +     libmetalink packages installed. + +   SPECIAL CASES +   ------------- +   Some versions of uClibc require configuring with CPPFLAGS=-D_GNU_SOURCE=1 +   to get correct large file support. + +   The Open Watcom C compiler on Linux requires configuring with the variables: + +       ./configure CC=owcc AR="$WATCOM/binl/wlib" AR_FLAGS=-q \ +           RANLIB=/bin/true STRIP="$WATCOM/binl/wstrip" CFLAGS=-Wextra + + +Win32 +===== + +   Building Windows DLLs and C run-time (CRT) linkage issues +   --------------------------------------------------------- + +   As a general rule, building a DLL with static CRT linkage is highly +   discouraged, and intermixing CRTs in the same app is something to +   avoid at any cost. + +   Reading and comprehension of Microsoft Knowledge Base articles +   KB94248 and KB140584 is a must for any Windows developer. Especially +   important is full understanding if you are not going to follow the +   advice given above. + +   KB94248  - How To Use the C Run-Time +              http://support.microsoft.com/kb/94248/en-us + +   KB140584 - How to link with the correct C Run-Time (CRT) library +              http://support.microsoft.com/kb/140584/en-us + +   KB190799 - Potential Errors Passing CRT Objects Across DLL Boundaries +              http://msdn.microsoft.com/en-us/library/ms235460 + +   If your app is misbehaving in some strange way, or it is suffering +   from memory corruption, before asking for further help, please try +   first to rebuild every single library your app uses as well as your +   app using the debug multithreaded dynamic C runtime. + +   If you get linkage errors read section 5.7 of the FAQ document. + + +   MingW32 +   ------- + +   Make sure that MinGW32's bin dir is in the search path, for example: + +     set PATH=c:\mingw32\bin;%PATH% + +   then run 'mingw32-make mingw32' in the root dir. There are other +   make targets available to build libcurl with more features, use: +   'mingw32-make mingw32-zlib' to build with Zlib support; +   'mingw32-make mingw32-ssl-zlib' to build with SSL and Zlib enabled; +   'mingw32-make mingw32-ssh2-ssl-zlib' to build with SSH2, SSL, Zlib; +   'mingw32-make mingw32-ssh2-ssl-sspi-zlib' to build with SSH2, SSL, Zlib +   and SSPI support. + +   If you have any problems linking libraries or finding header files, be sure +   to verify that the provided "Makefile.m32" files use the proper paths, and +   adjust as necessary. It is also possible to override these paths with +   environment variables, for example: + +     set ZLIB_PATH=c:\zlib-1.2.7 +     set OPENSSL_PATH=c:\openssl-0.9.8x +     set LIBSSH2_PATH=c:\libssh2-1.4.3 + +   ATTENTION: if you want to build with libssh2 support you have to use latest +   version 0.17 - previous versions will NOT work with 7.17.0 and later! +   Use 'mingw32-make mingw32-ssh2-ssl-zlib' to build with SSH2 and SSL enabled. + +   It is now also possible to build with other LDAP SDKs than MS LDAP; +   currently it is possible to build with native Win32 OpenLDAP, or with the +   Novell CLDAP SDK. If you want to use these you need to set these vars: + +     set LDAP_SDK=c:\openldap +     set USE_LDAP_OPENLDAP=1 + +   or for using the Novell SDK: + +     set USE_LDAP_NOVELL=1 + +   If you want to enable LDAPS support then set LDAPS=1. + +   - optional MingW32-built OpenLDAP SDK available from: +     http://www.gknw.net/mirror/openldap/ +   - optional recent Novell CLDAP SDK available from: +     http://developer.novell.com/ndk/cldap.htm + + +   Cygwin +   ------ + +   Almost identical to the unix installation. Run the configure script in the +   curl root with 'sh configure'. Make sure you have the sh executable in +   /bin/ or you'll see the configure fail toward the end. + +   Run 'make' + +   Dev-Cpp +   ------- + +   See the separate INSTALL.devcpp file for details. + +   MSVC 6 caveats +   -------------- + +   If you use MSVC 6 it is required that you use the February 2003 edition PSDK: +   http://www.microsoft.com/msdownload/platformsdk/sdkupdate/psdk-full.htm + +   Building any software with MSVC 6 without having PSDK installed is just +   asking for trouble down the road once you have released it, you might notice +   the problems in the first corner or ten miles ahead, depending mostly on your +   choice of static vs dynamic runtime and third party libraries. Anyone using +   software built in such way will at some point regret having done so. + +   When someone uses MSVC 6 without PSDK he is using a compiler back from 1998. + +   If the compiler has been updated with the installation of a service pack as +   those mentioned in http://support.microsoft.com/kb/194022 the compiler can be +   safely used to read source code, translate and make it object code. + +   But, even with the service packs mentioned above installed, the resulting +   software generated in such an environment will be using outdated system +   header files and libraries with bugs and security issues which have already +   been addressed and fixed long time ago. + +   In order to make use of the updated system headers and fixed libraries +   for MSVC 6, it is required that 'Platform SDK', PSDK from now onwards, +   is installed. The specific PSDK that must be installed for MSVC 6 is the +   February 2003 edition, which is the latest one supporting the MSVC 6 compiler, +   this PSDK is also known as 'Windows Server 2003 PSDK' and can be downloaded +   from http://www.microsoft.com/msdownload/platformsdk/sdkupdate/psdk-full.htm + +   So, building curl and libcurl with MSVC 6 without PSDK is absolutely +   discouraged for the benefit of anyone using software built in such +   environment. And it will not be supported in any way, as we could just +   be hunting bugs which have already been fixed way back in 2003. + +   When building with MSVC 6 we attempt to detect if PSDK is not being used, +   and if this is the case the build process will fail hard with an error +   message stating that the February 2003 PSDK is required. This is done to +   protect the unsuspecting and avoid PEBKAC issues. + +   Additionally it might happen that a die hard MSVC hacker still wants to +   build curl and libcurl with MSVC 6 without PSDK installed, even knowing +   that this is a highly discouraged and unsupported build environment. In +   this case the brave of heart will be able to build in such an environment +   with the requisite of defining preprocessor symbol ALLOW_MSVC6_WITHOUT_PSDK +   in lib/config-win32.h and knowing that LDAP and IPv6 support will be missing. + +   MSVC from command line +   ---------------------- + +   Run the 'vcvars32.bat' file to get a proper environment. The +   vcvars32.bat file is part of the Microsoft development environment and +   you may find it in 'C:\Program Files\Microsoft Visual Studio\vc98\bin' +   provided that you installed Visual C/C++ 6 in the default directory. + +   Then run 'nmake vc' in curl's root directory. + +   If you want to compile with zlib support, you will need to build +   zlib (http://www.gzip.org/zlib/) as well. Please read the zlib +   documentation on how to compile zlib. Define the ZLIB_PATH environment +   variable to the location of zlib.h and zlib.lib, for example: + +     set ZLIB_PATH=c:\zlib-1.2.7 + +   Then run 'nmake vc-zlib' in curl's root directory. + +   If you want to compile with SSL support you need the OpenSSL package. +   Please read the OpenSSL documentation on how to compile and install +   the OpenSSL libraries.  The build process of OpenSSL generates the +   libeay32.dll and ssleay32.dll files in the out32dll subdirectory in +   the OpenSSL home directory.  OpenSSL static libraries (libeay32.lib, +   ssleay32.lib, RSAglue.lib) are created in the out32 subdirectory. + +   Before running nmake define the OPENSSL_PATH environment variable with +   the root/base directory of OpenSSL, for example: + +     set OPENSSL_PATH=c:\openssl-0.9.8x + +   Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root +   directory.  'nmake vc-ssl' will create a libcurl static and dynamic +   libraries in the lib subdirectory, as well as a statically linked +   version of curl.exe in the src subdirectory.  This statically linked +   version is a standalone executable not requiring any DLL at +   runtime. This make method requires that you have the static OpenSSL +   libraries available in OpenSSL's out32 subdirectory. +   'nmake vc-ssl-dll' creates the libcurl dynamic library and +   links curl.exe against libcurl and OpenSSL dynamically. +   This executable requires libcurl.dll and the OpenSSL DLLs +   at runtime. +   Run 'nmake vc-ssl-zlib' to build with both ssl and zlib support. + +   MSVC 6 IDE +   ---------- + +   A minimal VC++ 6.0 reference workspace (vc6curl.dsw) is available with the +   source distribution archive to allow proper building of the two included +   projects, the libcurl library and the curl tool. + +   1) Open the vc6curl.dsw workspace with MSVC6's IDE. +   2) Select 'Build' from top menu. +   3) Select 'Batch Build' from dropdown menu. +   4) Make sure that the eight project configurations are 'checked'. +   5) Click on the 'Build' button. +   6) Once the eight project configurations are built you are done. + +   Dynamic and static libcurl libraries are built in debug and release flavours, +   and can be located each one in its own subdirectory, DLL-Debug, DLL-Release, +   LIB-Debug and LIB-Release, all of them below the 'lib' subdirectory. + +   In the same way four curl executables are created, each using its respective +   library. The resulting curl executables are located in its own subdirectory, +   DLL-Debug, DLL-Release, LIB-Debug and LIB-Release, below the 'src' subdir. + +   These reference VC++ 6.0 configurations are generated using the dynamic CRT. + +   Intentionally, these reference VC++ 6.0 projects and configurations don't use +   third party libraries, such as OpenSSL or Zlib, to allow proper compilation +   and configuration for all new users without further requirements. + +   If you need something more 'involved' you might adjust them for your own use, +   or explore the world of makefiles described above 'MSVC from command line'. + +   Borland C++ compiler +   --------------------- + +   Ensure that your build environment is properly set up to use the compiler +   and associated tools. PATH environment variable must include the path to +   bin subdirectory of your compiler installation, eg: c:\Borland\BCC55\bin + +   It is advisable to set environment variable BCCDIR to the base path of +   the compiler installation. + +     set BCCDIR=c:\Borland\BCC55 + +   In order to build a plain vanilla version of curl and libcurl run the +   following command from curl's root directory: + +     make borland + +   To build curl and libcurl with zlib and OpenSSL support set environment +   variables ZLIB_PATH and OPENSSL_PATH to the base subdirectories of the +   already built zlib and OpenSSL libraries and from curl's root directory +   run command: + +     make borland-ssl-zlib + +   libcurl library will be built in 'lib' subdirectory while curl tool +   is built in 'src' subdirectory. In order to use libcurl library it is +   advisable to modify compiler's configuration file bcc32.cfg located +   in c:\Borland\BCC55\bin to reflect the location of libraries include +   paths for example the '-I' line could result in something like: + +     -I"c:\Borland\BCC55\include;c:\curl\include;c:\openssl\inc32" + +   bcc3.cfg '-L' line could also be modified to reflect the location of +   of libcurl library resulting for example: + +     -L"c:\Borland\BCC55\lib;c:\curl\lib;c:\openssl\out32" + +   In order to build sample program 'simple.c' from the docs\examples +   subdirectory run following command from mentioned subdirectory: + +     bcc32 simple.c libcurl.lib cw32mt.lib + +   In order to build sample program simplessl.c an SSL enabled libcurl +   is required, as well as the OpenSSL libeay32.lib and ssleay32.lib +   libraries. + + +   OTHER MSVC IDEs +   --------------- + +   If you use VC++, Borland or similar compilers. Include all lib source +   files in a static lib "project" (all .c and .h files that is). +   (you should name it libcurl or similar) + +   Make the sources in the src/ drawer be a "win32 console application" +   project. Name it curl. + + +   Disabling Specific Protocols in Win32 builds +   -------------------------------------------- + +   The configure utility, unfortunately, is not available for the Windows +   environment, therefore, you cannot use the various disable-protocol +   options of the configure utility on this platform. + +   However, you can use the following defines to disable specific +   protocols: + +   HTTP_ONLY             disables all protocols except HTTP +   CURL_DISABLE_FTP      disables FTP +   CURL_DISABLE_LDAP     disables LDAP +   CURL_DISABLE_TELNET   disables TELNET +   CURL_DISABLE_DICT     disables DICT +   CURL_DISABLE_FILE     disables FILE +   CURL_DISABLE_TFTP     disables TFTP +   CURL_DISABLE_HTTP     disables HTTP + +   If you want to set any of these defines you have the following +   possibilities: + +   - Modify lib/config-win32.h +   - Modify lib/curl_setup.h +   - Modify lib/Makefile.vc6 +   - Add defines to Project/Settings/C/C++/General/Preprocessor Definitions +     in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project. + + +   Using BSD-style lwIP instead of Winsock TCP/IP stack in Win32 builds +   -------------------------------------------------------------------- + +   In order to compile libcurl and curl using BSD-style lwIP TCP/IP stack +   it is necessary to make definition of preprocessor symbol USE_LWIPSOCK +   visible to libcurl and curl compilation processes. To set this definition +   you have the following alternatives: + +   - Modify lib/config-win32.h and src/config-win32.h +   - Modify lib/Makefile.vc6 +   - Add definition to Project/Settings/C/C++/General/Preprocessor Definitions +     in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project. + +   Once that libcurl has been built with BSD-style lwIP TCP/IP stack support, +   in order to use it with your program it is mandatory that your program +   includes lwIP header file <lwip/opt.h> (or another lwIP header that includes +   this) before including any libcurl header. Your program does not need the +   USE_LWIPSOCK preprocessor definition which is for libcurl internals only. + +   Compilation has been verified with lwIP 1.4.0 and contrib-1.4.0 from: + +   http://download.savannah.gnu.org/releases/lwip/lwip-1.4.0.zip +   http://download.savannah.gnu.org/releases/lwip/contrib-1.4.0.zip + +   This BSD-style lwIP TCP/IP stack support must be considered experimental +   given that it has been verified that lwIP 1.4.0 still needs some polish, +   and libcurl might yet need some additional adjustment, caveat emptor. + +   Important static libcurl usage note +   ----------------------------------- + +   When building an application that uses the static libcurl library, you must +   add '-DCURL_STATICLIB' to your CFLAGS.  Otherwise the linker will look for +   dynamic import symbols. + + +Apple iOS and Mac OS X +====================== +   On recent Apple operating systems, curl can be built to use Apple's +   SSL/TLS implementation, Secure Transport, instead of OpenSSL. To build with +   Secure Transport for SSL/TLS, use the configure option --with-darwinssl. (It +   is not necessary to use the option --without-ssl.) This feature requires iOS +   5.0 or later, or OS X 10.5 ("Leopard") or later. + +   When Secure Transport is in use, the curl options --cacert and --capath and +   their libcurl equivalents, will be ignored, because Secure Transport uses +   the certificates stored in the Keychain to evaluate whether or not to trust +   the server. This, of course, includes the root certificates that ship with +   the OS. The --cert and --engine options, and their libcurl equivalents, are +   currently unimplemented in curl with Secure Transport. + +   For OS X users: In OS X 10.8 ("Mountain Lion"), Apple made a major +   overhaul to the Secure Transport API that, among other things, added +   support for the newer TLS 1.1 and 1.2 protocols. To get curl to support +   TLS 1.1 and 1.2, you must build curl on Mountain Lion or later, or by +   using the equivalent SDK. If you set the MACOSX_DEPLOYMENT_TARGET +   environmental variable to an earlier version of OS X prior to building curl, +   then curl will use the new Secure Transport API on Mountain Lion and later, +   and fall back on the older API when the same curl binary is executed on +   older cats. For example, running these commands in curl's directory in the +   shell will build the code such that it will run on cats as old as OS X 10.6 +   ("Snow Leopard") (using bash): + +      export MACOSX_DEPLOYMENT_TARGET="10.6" +      ./configure --with-darwinssl +      make + + +IBM OS/2 +======== +   Building under OS/2 is not much different from building under unix. +   You need: + +      - emx 0.9d +      - GNU make +      - GNU patch +      - ksh +      - GNU bison +      - GNU file utilities +      - GNU sed +      - autoconf 2.13 + +   If you want to build with OpenSSL or OpenLDAP support, you'll need to +   download those libraries, too. Dirk Ohme has done some work to port SSL +   libraries under OS/2, but it looks like he doesn't care about emx.  You'll +   find his patches on: http://come.to/Dirk_Ohme + +   If during the linking you get an error about _errno being an undefined +   symbol referenced from the text segment, you need to add -D__ST_MT_ERRNO__ +   in your definitions. + +   If everything seems to work fine but there's no curl.exe, you need to add +   -Zexe to your linker flags. + +   If you're getting huge binaries, probably your makefiles have the -g in +   CFLAGS. + + +VMS +=== +   (The VMS section is in whole contributed by the friendly Nico Baggus) + +   Curl seems to work with FTP & HTTP other protocols are not tested.  (the +   perl http/ftp testing server supplied as testing too cannot work on VMS +   because vms has no concept of fork(). [ I tried to give it a whack, but +   that's of no use. + +   SSL stuff has not been ported. + +   Telnet has about the same issues as for Win32. When the changes for Win32 +   are clear maybe they'll work for VMS too. The basic problem is that select +   ONLY works for sockets. + +   Marked instances of fopen/[f]stat that might become a problem, especially +   for non stream files. In this regard, the files opened for writing will be +   created stream/lf and will thus be safe. Just keep in mind that non-binary +   read/wring from/to files will have a records size limit of 32767 bytes +   imposed. + +   Stat to get the size of the files is again only safe for stream files & +   fixed record files without implied CC. + +   -- My guess is that only allowing access to stream files is the quickest +   way to get around the most issues. Therefore all files need to to be +   checked to be sure they will be stream/lf before processing them.  This is +   the easiest way out, I know. The reason for this is that code that needs to +   report the filesize will become a pain in the ass otherwise. + +   Exit status.... Well we needed something done here, + +   VMS has a structured exist status: +   | 3  |       2    |     1       |  0| +   |1098|765432109876|5432109876543|210| +   +----+------------+-------------+---+ +   |Ctrl|  Facility  | Error code  |sev| +   +----+------------+-------------+---+ + +   With the Ctrl-bits an application can tell if part or the whole message has +   already been printed from the program, DCL doesn't need to print it again. + +   Facility - basically the program ID. A code assigned to the program +   the name can be fetched from external or internal message libraries +   Error code - the err codes assigned by the application +   Sev. - severity: Even = error, off = non error +      0 = Warning +      1 = Success +      2 = Error +      3 = Information +      4 = Fatal +      <5-7> reserved. + +   This all presents itself with: +   %<FACILITY>-<Sev>-<Errorname>, <Error message> + +   See also the src/curlmsg.msg file, it has the source for the messages In +   src/main.c a section is devoted to message status values, the globalvalues +   create symbols with certain values, referenced from a compiled message +   file. Have all exit function use a exit status derived from a translation +   table with the compiled message codes. + +   This was all compiled with: + +      Compaq C V6.2-003 on OpenVMS Alpha V7.1-1H2 + +   So far for porting notes as of: +   13-jul-2001 +   N. Baggus + + +QNX +=== +   (This section was graciously brought to us by David Bentham) + +   As QNX is targeted for resource constrained environments, the QNX headers +   set conservative limits. This includes the FD_SETSIZE macro, set by default +   to 32. Socket descriptors returned within the CURL library may exceed this, +   resulting in memory faults/SIGSEGV crashes when passed into select(..) +   calls using fd_set macros. + +   A good all-round solution to this is to override the default when building +   libcurl, by overriding CFLAGS during configure, example +   #  configure CFLAGS='-DFD_SETSIZE=64 -g -O2' + + +RISC OS +======= +   The library can be cross-compiled using gccsdk as follows: + +        CC=riscos-gcc AR=riscos-ar RANLIB='riscos-ar -s' ./configure \ +             --host=arm-riscos-aof --without-random --disable-shared +        make + +   where riscos-gcc and riscos-ar are links to the gccsdk tools. +   You can then link your program with curl/lib/.libs/libcurl.a + + +AmigaOS +======= +   (This section was graciously brought to us by Diego Casorran) + +   To build cURL/libcurl on AmigaOS just type 'make amiga' ... + +   What you need is:    (not tested with others versions) + +        GeekGadgets / gcc 2.95.3 (http://www.geekgadgets.org/) + +        AmiTCP SDK v4.3 (http://www.aminet.net/comm/tcp/AmiTCP-SDK-4.3.lha) + +        Native Developer Kit (http://www.amiga.com/3.9/download/NDK3.9.lha) + +   As no ixemul.library is required you will be able to build it for +   WarpOS/PowerPC (not tested by me), as well a MorphOS version should be +   possible with no problems. + +   To enable SSL support, you need a OpenSSL native version (without ixemul), +   you can find a precompiled package at http://amiga.sourceforge.net/OpenSSL/ + + +NetWare +======= +   To compile curl.nlm / libcurl.nlm you need: +   - either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later. +   - gnu make and awk running on the platform you compile on; +     native Win32 versions can be downloaded from: +     http://www.gknw.net/development/prgtools/ +   - recent Novell LibC SDK available from: +     http://developer.novell.com/ndk/libc.htm +   - or recent Novell CLib SDK available from: +     http://developer.novell.com/ndk/clib.htm +   - optional recent Novell CLDAP SDK available from: +     http://developer.novell.com/ndk/cldap.htm +   - optional zlib sources (static or dynamic linking with zlib.imp); +     sources with NetWare Makefile can be obtained from: +     http://www.gknw.net/mirror/zlib/ +   - optional OpenSSL sources (version 0.9.8 or later build with BSD sockets); +     you can find precompiled packages at: +     http://www.gknw.net/development/ossl/netware/ +     for CLIB-based builds OpenSSL 0.9.8h or later is required  - earlier versions +     don't support building with CLIB BSD sockets. +   - optional SSH2 sources (version 0.17 or later); + +   Set a search path to your compiler, linker and tools; on Linux make +   sure that the var OSTYPE contains the string 'linux'; set the var +   NDKBASE to point to the base of your Novell NDK; and then type +   'make netware' from the top source directory; other targets available +   are 'netware-ssl', 'netware-ssl-zlib', 'netware-zlib' and 'netware-ares'; +   if you need other combinations you can control the build with the +   environment variables WITH_SSL, WITH_ZLIB, WITH_ARES, WITH_SSH2, and +   ENABLE_IPV6; you can set LINK_STATIC=1 to link curl.nlm statically. +   By default LDAP support is enabled, however currently you will need a patch +   in order to use the CLDAP NDK with BSD sockets (Novell Bug 300237): +   http://www.gknw.net/test/curl/cldap_ndk/ldap_ndk.diff +   I found on some Linux systems (RH9) that OS detection didn't work although +   a 'set | grep OSTYPE' shows the var present and set; I simply overwrote it +   with 'OSTYPE=linux-rh9-gnu' and the detection in the Makefile worked... +   Any help in testing appreciated! +   Builds automatically created 8 times a day from current git are here: +   http://www.gknw.net/mirror/curl/autobuilds/ +   the status of these builds can be viewed at the autobuild table: +   http://curl.haxx.se/dev/builds.html + + +eCos +==== +   curl does not use the eCos build system, so you must first build eCos +   separately, then link curl to the resulting eCos library.  Here's a sample +   configure line to do so on an x86 Linux box targeting x86: + +   GCCLIB=`gcc -print-libgcc-file-name` && \ +   CFLAGS="-D__ECOS=1 -nostdinc -I$ECOS_INSTALL/include \ +    -I`dirname $GCCLIB`/include" \ +   LDFLAGS="-nostdlib -Wl,--gc-sections -Wl,-static \ +    -L$ECOS_INSTALL/lib -Ttarget.ld -ltarget" \ +   ./configure --host=i386 --disable-shared \ +    --without-ssl --without-zlib --disable-manual --disable-ldap + +   In most cases, eCos users will be using libcurl from within a custom +   embedded application.  Using the standard 'curl' executable from +   within eCos means facing the limitation of the standard eCos C +   startup code which does not allow passing arguments in main().  To +   run 'curl' from eCos and have it do something useful, you will need +   to either modify the eCos startup code to pass in some arguments, or +   modify the curl application itself to retrieve its arguments from +   some location set by the bootloader or hard-code them. + +   Something like the following patch could be used to hard-code some +   arguments.  The MTAB_ENTRY line mounts a RAM disk as the root filesystem +   (without mounting some kind of filesystem, eCos errors out all file +   operations which curl does not take to well).  The next section synthesizes +   some command-line arguments for curl to use, in this case to direct curl +   to read further arguments from a file.  It then creates that file on the +   RAM disk and places within it a URL to download: a file: URL that +   just happens to point to the configuration file itself.  The results +   of running curl in this way is the contents of the configuration file +   printed to the console. + +--- src/main.c  19 Jul 2006 19:09:56 -0000    1.363 ++++ src/main.c  24 Jul 2006 21:37:23 -0000 +@@ -4286,11 +4286,31 @@ + } + + ++#ifdef __ECOS ++#include <cyg/fileio/fileio.h> ++MTAB_ENTRY( testfs_mte1, ++                   "/", ++                   "ramfs", ++                   "", ++                   0); ++#endif + + int main(int argc, char *argv[]) + { +   int res; +   struct Configurable config; ++#ifdef __ECOS ++  char *args[] = {"ecos-curl", "-K", "curlconf.txt"}; ++  FILE *f; ++  argc = sizeof(args)/sizeof(args[0]); ++  argv = args; ++ ++  f = fopen("curlconf.txt", "w"); ++  if (f) { ++    fprintf(f, "--url file:curlconf.txt"); ++    fclose(f); ++  } ++#endif +   memset(&config, 0, sizeof(struct Configurable)); + +   config.errors = stderr; /* default errors to stderr */ + + +Minix +===== +   curl can be compiled on Minix 3 using gcc or ACK (starting with +   ver. 3.1.3).  Ensure that GNU gawk and bash are both installed and +   available in the PATH. + +   ACK +   --- +   Increase the heap sizes of the compiler with the command: + +     binsizes xxl + +   then configure and compile curl with: + +     ./configure CC=cc LD=cc AR=/usr/bin/aal GREP=grep \ +      CPPFLAGS='-D_POSIX_SOURCE=1 -I/usr/local/include' +     make +     chmem =256000 src/curl + +   GCC +   --- +   Make sure gcc is in your PATH with the command: + +     export PATH=/usr/gnu/bin:$PATH + +   then configure and compile curl with: + +     ./configure CC=gcc AR=/usr/gnu/bin/gar GREP=grep +     make +     chmem =256000 src/curl + + +Symbian OS +========== +   The Symbian OS port uses the Symbian build system to compile.  From the +   packages/Symbian/group/ directory, run: + +      bldmake bldfiles +      abld build + +   to compile and install curl and libcurl using SBSv1. If your Symbian +   SDK doesn't include support for P.I.P.S., you will need to contact +   your SDK vendor to obtain that first. + + +VxWorks +======== +   Build for VxWorks is performed using cross compilation. +   That means you build on Windows machine using VxWorks tools and +   run the built image on the VxWorks device. + +   To build libcurl for VxWorks you need: + +      - CYGWIN (free, http://cygwin.com/) +      - Wind River Workbench (commercial) + +   If you have CYGWIN and Workbench installed on you machine +   follow after next steps: + +    1. Open the Command Prompt window and change directory ('cd') +       to the libcurl 'lib' folder. +    2. Add CYGWIN 'bin' folder to the PATH environment variable. +       For example, type 'set PATH=C:/embedded/cygwin/bin;%PATH%'. +    3. Adjust environment variables defined in 'Environment' section +       of the Makefile.vxworks file to point to your software folders. +    4. Build the libcurl by typing 'make -f ./Makefile.vxworks' + +   As a result the libcurl.a library should be created in the 'lib' folder. +   To clean the build results type 'make -f ./Makefile.vxworks clean'. + + +Android +======= +   Method using the static makefile: +      - see the build notes in the Android.mk file. + +   Method using a configure cross-compile (tested with Android NDK r7c, r8): +      - prepare the toolchain of the Android NDK for standalone use; this can +        be done by invoking the script: +        ./build/tools/make-standalone-toolchain.sh +        which creates a usual cross-compile toolchain. Lets assume that you put +        this toolchain below /opt then invoke configure with something like: +        export PATH=/opt/arm-linux-androideabi-4.4.3/bin:$PATH +        ./configure --host=arm-linux-androideabi [more configure options] +        make +      - if you want to compile directly from our GIT repo you might run into +        this issue with older automake stuff: +        checking host system type... +        Invalid configuration `arm-linux-androideabi': +        system `androideabi' not recognized +        configure: error: /bin/sh ./config.sub arm-linux-androideabi failed +        this issue can be fixed with using more recent versions of config.sub +        and config.guess which can be obtained here: +        http://git.savannah.gnu.org/gitweb/?p=config.git;a=tree +        you need to replace your system-own versions which usually can be +        found in your automake folder: +        find /usr -name config.sub + +   Wrapper for pkg-config +      - In order to make proper use of pkg-config so that configure is able to +        find all dependencies you should create a wrapper script for pkg-config; +        file /opt/arm-linux-androideabi-4.4.3/bin/arm-linux-androideabi-pkg-config: + +        #!/bin/sh +        SYSROOT=$(dirname ${0%/*})/sysroot +        export PKG_CONFIG_DIR= +        export PKG_CONFIG_LIBDIR=${SYSROOT}/usr/local/lib/pkgconfig:${SYSROOT}/usr/share/pkgconfig +        export PKG_CONFIG_SYSROOT_DIR=${SYSROOT} +        exec pkg-config "$@" + +        also create a copy or symlink with name arm-unknown-linux-androideabi-pkg-config. + + +CROSS COMPILE +============= +   (This section was graciously brought to us by Jim Duey, with additions by +   Dan Fandrich) + +   Download and unpack the cURL package. + +   'cd' to the new directory. (e.g. cd curl-7.12.3) + +   Set environment variables to point to the cross-compile toolchain and call +   configure with any options you need.  Be sure and specify the '--host' and +   '--build' parameters at configuration time.  The following script is an +   example of cross-compiling for the IBM 405GP PowerPC processor using the +   toolchain from MonteVista for Hardhat Linux. + +   (begin script) + +   #! /bin/sh + +   export PATH=$PATH:/opt/hardhat/devkit/ppc/405/bin +   export CPPFLAGS="-I/opt/hardhat/devkit/ppc/405/target/usr/include" +   export AR=ppc_405-ar +   export AS=ppc_405-as +   export LD=ppc_405-ld +   export RANLIB=ppc_405-ranlib +   export CC=ppc_405-gcc +   export NM=ppc_405-nm + +   ./configure --target=powerpc-hardhat-linux \ +        --host=powerpc-hardhat-linux \ +        --build=i586-pc-linux-gnu \ +        --prefix=/opt/hardhat/devkit/ppc/405/target/usr/local \ +        --exec-prefix=/usr/local + +   (end script) + +   You may also need to provide a parameter like '--with-random=/dev/urandom' +   to configure as it cannot detect the presence of a random number +   generating device for a target system.  The '--prefix' parameter +   specifies where cURL will be installed.  If 'configure' completes +   successfully, do 'make' and 'make install' as usual. + +   In some cases, you may be able to simplify the above commands to as +   little as: + +       ./configure --host=ARCH-OS + + +REDUCING SIZE +============= +   There are a number of configure options that can be used to reduce the +   size of libcurl for embedded applications where binary size is an +   important factor.  First, be sure to set the CFLAGS variable when +   configuring with any relevant compiler optimization flags to reduce the +   size of the binary.  For gcc, this would mean at minimum the -Os option, +   and potentially the -march=X and -mdynamic-no-pic options as well, e.g. + +      ./configure CFLAGS='-Os' ... + +   Note that newer compilers often produce smaller code than older versions +   due to improved optimization. + +   Be sure to specify as many --disable- and --without- flags on the configure +   command-line as you can to disable all the libcurl features that you +   know your application is not going to need.  Besides specifying the +   --disable-PROTOCOL flags for all the types of URLs your application +   will not use, here are some other flags that can reduce the size of the +   library: + +     --disable-ares (disables support for the C-ARES DNS library) +     --disable-cookies (disables support for HTTP cookies) +     --disable-crypto-auth (disables HTTP cryptographic authentication) +     --disable-ipv6 (disables support for IPv6) +     --disable-manual (disables support for the built-in documentation) +     --disable-proxy (disables support for HTTP and SOCKS proxies) +     --disable-verbose (eliminates debugging strings and error code strings) +     --enable-hidden-symbols (eliminates unneeded symbols in the shared library) +     --without-libidn (disables support for the libidn DNS library) +     --without-ssl (disables support for SSL/TLS) +     --without-zlib (disables support for on-the-fly decompression) + +   The GNU compiler and linker have a number of options that can reduce the +   size of the libcurl dynamic libraries on some platforms even further. +   Specify them by providing appropriate CFLAGS and LDFLAGS variables on the +   configure command-line, e.g. +     CFLAGS="-Os -ffunction-sections -fdata-sections \ +             -fno-unwind-tables -fno-asynchronous-unwind-tables" \ +     LDFLAGS="-Wl,-s -Wl,-Bsymbolic -Wl,--gc-sections" + +   Be sure also to strip debugging symbols from your binaries after +   compiling using 'strip' (or the appropriate variant if cross-compiling). +   If space is really tight, you may be able to remove some unneeded +   sections of the shared library using the -R option to objcopy (e.g. the +   .comment section). + +   Using these techniques it is possible to create a basic HTTP-only shared +   libcurl library for i386 Linux platforms that is only 106 KiB in size, and +   an FTP-only library that is 108 KiB in size (as of libcurl version 7.27.0, +   using gcc 4.6.3). + +   You may find that statically linking libcurl to your application will +   result in a lower total size than dynamically linking. + +   Note that the curl test harness can detect the use of some, but not all, of +   the --disable statements suggested above. Use will cause tests relying on +   those features to fail.  The test harness can be manually forced to skip +   the relevant tests by specifying certain key words on the runtests.pl +   command line.  Following is a list of appropriate key words: + +     --disable-cookies          !cookies +     --disable-crypto-auth      !HTTP\ Digest\ auth !HTTP\ proxy\ Digest\ auth +     --disable-manual           !--manual +     --disable-proxy            !HTTP\ proxy !proxytunnel !SOCKS4 !SOCKS5 + + +PORTS +===== +   This is a probably incomplete list of known hardware and operating systems +   that curl has been compiled for. If you know a system curl compiles and +   runs on, that isn't listed, please let us know! + +        - Alpha DEC OSF 4 +        - Alpha Digital UNIX v3.2 +        - Alpha FreeBSD 4.1, 4.5 +        - Alpha Linux 2.2, 2.4 +        - Alpha NetBSD 1.5.2 +        - Alpha OpenBSD 3.0 +        - Alpha OpenVMS V7.1-1H2 +        - Alpha Tru64 v5.0 5.1 +        - AVR32 Linux +        - ARM Android 1.5, 2.1 +        - ARM INTEGRITY +        - ARM iOS +        - Cell Linux +        - Cell Cell OS +        - HP-PA HP-UX 9.X 10.X 11.X +        - HP-PA Linux +        - HP3000 MPE/iX +        - MicroBlaze uClinux +        - MIPS IRIX 6.2, 6.5 +        - MIPS Linux +        - OS/400 +        - Pocket PC/Win CE 3.0 +        - Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1, 5.2 +        - PowerPC Darwin 1.0 +        - PowerPC INTEGRITY +        - PowerPC Linux +        - PowerPC Mac OS 9 +        - PowerPC Mac OS X +        - SH4 Linux 2.6.X +        - SH4 OS21 +        - SINIX-Z v5 +        - Sparc Linux +        - Sparc Solaris 2.4, 2.5, 2.5.1, 2.6, 7, 8, 9, 10 +        - Sparc SunOS 4.1.X +        - StrongARM (and other ARM) RISC OS 3.1, 4.02 +        - StrongARM/ARM7/ARM9 Linux 2.4, 2.6 +        - StrongARM NetBSD 1.4.1 +        - Symbian OS (P.I.P.S.) 9.x +        - TPF +        - Ultrix 4.3a +        - UNICOS 9.0 +        - i386 BeOS +        - i386 DOS +        - i386 eCos 1.3.1 +        - i386 Esix 4.1 +        - i386 FreeBSD +        - i386 HURD +        - i386 Haiku OS +        - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 +        - i386 Mac OS X +        - i386 MINIX 3.1 +        - i386 NetBSD +        - i386 Novell NetWare +        - i386 OS/2 +        - i386 OpenBSD +        - i386 QNX 6 +        - i386 SCO unix +        - i386 Solaris 2.7 +        - i386 Windows 95, 98, ME, NT, 2000, XP, 2003 +        - i486 ncr-sysv4.3.03 (NCR MP-RAS) +        - ia64 Linux 2.3.99 +        - m68k AmigaOS 3 +        - m68k Linux +        - m68k uClinux +        - m68k OpenBSD +        - m88k dg-dgux5.4R3.00 +        - s390 Linux +        - x86_64 Linux +        - XScale/PXA250 Linux 2.4 +        - Nios II uClinux + +Useful URLs +=========== + +axTLS        http://axtls.sourceforge.net/ +c-ares       http://c-ares.haxx.se/ +GNU GSS      http://www.gnu.org/software/gss/ +GnuTLS       http://www.gnu.org/software/gnutls/ +Heimdal      http://www.pdc.kth.se/heimdal/ +libidn       http://www.gnu.org/software/libidn/ +libssh2      http://www.libssh2.org/ +MIT Kerberos http://web.mit.edu/kerberos/www/dist/ +NSS          http://www.mozilla.org/projects/security/pki/nss/ +OpenLDAP     http://www.openldap.org/ +OpenSSL      http://www.openssl.org/ +PolarSSL     http://polarssl.org/ +yassl        http://www.yassl.com/ +Zlib         http://www.zlib.net/ + +MingW        http://www.mingw.org/ +MinGW-w64    http://mingw-w64.sourceforge.net/ +OpenWatcom   http://www.openwatcom.org/ | 
