| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 | // -*- mode:doc; -*-// vim: set syntax=asciidoc:New package~~~~~~~~~~~First of all, create a directory and Makefile under the +package+directory for your software, for example +libfoo+:------------ $ make newpackage PKG=libfoo VER=0.1------------This will create a sample Makefile for you, with a lot of comments andhints.  It describes how the package should be downloaded, configured,built, installed, etc.Depending on the package type, the +Makefile+ must be written in adifferent way, using two different infrastructures:* manual package configuration* automatic package configuration using autotools[[dependencies-target-toolchain-options]]Dependencies on target and toolchain optionsSome packages depend on certain options of the toolchain: mainly thechoice of C library and C++ support.  Some packages can only be built oncertain target architectures or for specific target systems. These dependencies have to be expressed in the Makefile. The given valuesare space separated and can be negated with ! as a prefix.* Target architecture** variable used PKG_ARCH_DEPENDS** allowed values are: arm, mips, .. see target/arch.lst* Target system ** variable used PKG_SYSTEM_DEPENDS** for allowed values see the output of: find target/*/systems -type f* Target C library** variable used PKG_LIBC_DEPENDS** allowed values are: uclibc-ng glibc musl* Host system** variable used PKG_HOST_DEPENDS** allowed values are: linux darwin cygwin freebsd netbsd openbsd* Special support needed (Toolchain with Threads, Realtime or C++ enabled)** variable used PKG_NEEDS** allowed values are: threads rt c++Further formatting details: see xref:writing-rules-mk[the writingrules].
 |