123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- #***************************************************************************
- # _ _ ____ _
- # Project ___| | | | _ \| |
- # / __| | | | |_) | |
- # | (__| |_| | _ <| |___
- # \___|\___/|_| \_\_____|
- #
- # Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.
- #
- # This software is licensed as described in the file COPYING, which
- # you should have received as part of this distribution. The terms
- # are also available at https://curl.se/docs/copyright.html.
- #
- # You may opt to use, copy, modify, merge, publish, distribute and/or sell
- # copies of the Software, and permit persons to whom the Software is
- # furnished to do so, under the terms of the COPYING file.
- #
- # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
- # KIND, either express or implied.
- #
- ###########################################################################
- # Google Android makefile for curl and libcurl
- #
- # This file can be used when building curl using the full Android source
- # release or the NDK. Most users do not want or need to do this; please
- # instead read the Android section in docs/INSTALL for alternate
- # methods.
- #
- # Place the curl source (including this makefile) into external/curl/ in the
- # Android source tree. Then build them with 'make curl' or just 'make libcurl'
- # from the Android root. Tested with Android versions 1.5, 2.1-2.3
- #
- # Note: you must first create a curl_config.h file by running configure in the
- # Android environment. The only way I've found to do this is tricky. Perform a
- # normal Android build with libcurl in the source tree, providing the target
- # "showcommands" to make. The build will eventually fail (because curl_config.h
- # doesn't exist yet), but the compiler commands used to build curl will be
- # shown. Now, from the external/curl/ directory, run curl's normal configure
- # command with flags that match what Android itself uses. This will mean
- # putting the compiler directory into the PATH, putting the -I, -isystem and
- # -D options into CPPFLAGS, putting the -W, -m, -f, -O and -nostdlib options
- # into CFLAGS, and putting the -Wl, -L and -l options into LIBS, along with the
- # path to the files libgcc.a, crtbegin_dynamic.o, and ccrtend_android.o.
- # Remember that the paths must be absolute since you will not be running
- # configure from the same directory as the Android make. The normal
- # cross-compiler options must also be set. Note that the -c, -o, -MD and
- # similar flags must not be set.
- #
- # To see all the LIBS options, you'll need to do the "showcommands" trick on an
- # executable that's already buildable and watch what flags Android uses to link
- # it (dhcpcd is a good choice to watch). You'll also want to add -L options to
- # LIBS that point to the out/.../obj/lib/ and out/.../obj/system/lib/
- # directories so that additional libraries can be found and used by curl.
- #
- # The end result will be a configure command that looks something like this
- # (the environment variable A is set to the Android root path which makes the
- # command shorter):
- #
- # A=`realpath ../..` && \
- # PATH="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/bin:$PATH" \
- # ./configure --host=arm-linux CC=arm-eabi-gcc \
- # CPPFLAGS="-I $A/system/core/include ..." \
- # CFLAGS="-nostdlib -fno-exceptions -Wno-multichar ..." \
- # LIBS="$A/prebuilt/linux-x86/toolchain/arm-eabi-X/lib/gcc/arm-eabi/X\
- # /interwork/libgcc.a ..."
- #
- # Finally, copy the file COPYING to NOTICE so that the curl license gets put
- # into the right place (but see the note about this below).
- #
- # Dan Fandrich
- # November 2011
- LOCAL_PATH:= $(call my-dir)/../..
- common_CFLAGS := -Wpointer-arith -Wwrite-strings -Wunused -Winline -Wnested-externs -Wmissing-declarations -Wmissing-prototypes -Wno-long-long -Wfloat-equal -Wno-multichar -Wsign-compare -Wno-format-nonliteral -Wendif-labels -Wstrict-prototypes -Wdeclaration-after-statement -Wno-system-headers -DHAVE_CONFIG_H
- #########################
- # Build the libcurl library
- include $(CLEAR_VARS)
- include $(LOCAL_PATH)/lib/Makefile.inc
- CURL_HEADERS := \
- curl.h \
- system.h \
- curlver.h \
- easy.h \
- mprintf.h \
- multi.h \
- stdcheaders.h \
- typecheck-gcc.h
- LOCAL_SRC_FILES := $(addprefix lib/,$(CSOURCES))
- LOCAL_C_INCLUDES += $(LOCAL_PATH)/include/
- LOCAL_CFLAGS += $(common_CFLAGS)
- LOCAL_COPY_HEADERS_TO := libcurl/curl
- LOCAL_COPY_HEADERS := $(addprefix include/curl/,$(CURL_HEADERS))
- LOCAL_MODULE:= libcurl
- LOCAL_MODULE_TAGS := optional
- # Copy the licence to a place where Android will find it.
- # Actually, this doesn't quite work because the build system searches
- # for NOTICE files before it gets to this point, so it will only be seen
- # on subsequent builds.
- ALL_PREBUILT += $(LOCAL_PATH)/NOTICE
- $(LOCAL_PATH)/NOTICE: $(LOCAL_PATH)/COPYING | $(ACP)
- $(copy-file-to-target)
- include $(BUILD_STATIC_LIBRARY)
- #########################
- # Build the curl binary
- include $(CLEAR_VARS)
- include $(LOCAL_PATH)/src/Makefile.inc
- LOCAL_SRC_FILES := $(addprefix src/,$(CURL_CFILES))
- LOCAL_MODULE := curl
- LOCAL_MODULE_TAGS := optional
- LOCAL_STATIC_LIBRARIES := libcurl
- LOCAL_SYSTEM_SHARED_LIBRARIES := libc
- LOCAL_C_INCLUDES += $(LOCAL_PATH)/include $(LOCAL_PATH)/lib
- # This may also need to include $(CURLX_CFILES) in order to correctly link
- # if libcurl is changed to be built as a dynamic library
- LOCAL_CFLAGS += $(common_CFLAGS)
- include $(BUILD_EXECUTABLE)
|