commit | 5c2870f2620a7a7840d1e57a2a306ddaa67832af | [log] [tgz] |
---|---|---|
author | Mike Frysinger <vapier@google.com> | Fri Mar 18 16:49:05 2016 -0400 |
committer | Mike Frysinger <vapier@google.com> | Thu Mar 24 16:18:17 2016 +0000 |
tree | 069c5e2fc0f55d6a70558a552646096d6b3ab536 | |
parent | 3e4d883e3addbe43b656328e64bd0a88f6d9165d [diff] |
libevhtp: build checked out copy Now that libevhtp is part of the manifest, build it directly and store the results in out/. This also deletes references to third_party/{include,lib} as they're no longer needed. BUG=b/27820899 TEST+`make` still works, as does the unittests Change-Id: I6b1dd91cea0f152f8e79527e842add6a9d797a3c Reviewed-on: https://weave-review.googlesource.com/3001 Reviewed-by: Alex Vakulenko <avakulenko@google.com>
libWeave is the library with device side implementation of Weave protocol.
Sources are located in git repository at https://weave.googlesource.com/weave/libweave/
Make sure you have a bin/ directory in your home directory and that it is included in your path:
mkdir ~/bin PATH=~/bin:$PATH
Download the Repo tool and ensure that it is executable:
curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo chmod a+x ~/bin/repo
repo init -u https://weave.googlesource.com/weave/manifest repo sync
Path | Description |
---|---|
include/ | Includes to be used by device code |
src/ | Implementation sources |
examples/ | Example of device code |
third_party/ | Dependencies |
Makefile, *.mk files | Build files |
sudo apt-get update sudo apt-get install \ autoconf \ automake \ binutils \ g++ \ hostapd \ libavahi-client-dev \ libcurl4-openssl-dev \ libevent-dev \ libexpat1-dev \ libnl-3-dev \ libnl-route-3-dev \ libssl-dev \ libtool
The make --jobs/-j
flag is encouraged, to speed up build time. For example
make -j
which happens to be the same as
make all -j
make out/Debug/libweave.so
make all-examples
See the examples README for details.
The build supports transparently downloading & using a few cross-compilers. Just add cross-<arch>
to the command line in addition to the target you want to actually build.
This will cross-compile for an armv7 (hard float) target:
make cross-arm all-libs
This will cross-compile for a mips (little endian) target:
make cross-mipsel all-libs
make test make export-test
or
make testall
The build supports using qemu to run non-native tests.
This will run armv7 tests through qemu:
make cross-arm testall
The Android Developing site has a lot of good tips for working with git and repo in general. The tips below are meant as a quick cheat sheet rather than diving deep into relevant topics.
Make sure to have correct user in local or global config e.g.:
git config --local user.name "User Name" git config --local user.email user.name@example.com
repo start <branch name> .
git commit -a -v
repo upload .
Go to the url from the output of repo upload
and add reviewers.