1
0
mirror of https://github.com/stucki/docker-lineageos synced 2024-12-19 17:12:29 -05:00
Go to file
2018-11-19 23:45:49 +01:00
.dockerignore Update .dockerignore 2016-01-22 14:07:29 +01:00
.gitignore Add ccache to .gitignore 2014-07-19 13:40:24 +02:00
CHANGELOG.md Update ChangeLog (for the previous version 0.7.0) 2018-11-19 23:45:49 +01:00
Dockerfile Merge branch 'master' into misc-improvements 2017-08-05 22:59:08 +02:00
LICENSE Add MIT license 2017-01-30 14:56:24 +01:00
README.md Docs: Use a table for available switches 2018-10-16 14:09:42 +02:00
run.sh Merge branch 'master' into misc-improvements 2017-08-05 22:59:08 +02:00
startup.sh fix user permission specific problems and add comments 2017-06-01 01:03:23 +02:00

docker-lineageos

Create a Docker based environment to build LineageOS.

This Dockerfile will create a docker container which is based on Ubuntu 16.04. It will install the "repo" utility and any other build dependencies which are required to compile LineageOS (formerly known as CyanogenMod).

The main working directory is a shared folder on the host system, so the Docker container can be removed at any time.

NOTE: Remember that LineageOS is a huge project. It will consume a large amount of disk space (~80 GB) and it can easily take hours to build.

How to run/build

NOTES:

  • You will need to install Docker to proceed!
  • If an image does not exist, docker build is executed first
git clone https://github.com/stucki/docker-lineageos.git
cd docker-lineageos
./run.sh

The run.sh script accepts the following switches:

Switch Alternative Description
-u --enable-usb Runs the container in privileged mode (this way you can use adb right from the container)
-r --rebuild Force rebuild the image from scratch
-ws --with-su Sets the WITH_SU environment variable to true (your builds will include the su binary)

The container uses "screen" to run the shell. This means that you will be able to open additional shells using screen keyboard shortcuts.

ADB in the container

If you're on Linux and want to use adb from within the container running with -u might not be enough. Make sure you have the Android udev rules installed on your host system so you can access your device without needing superuser permissions.

How to build LineageOS for your device

repo init -u git://github.com/lineageos/android.git -b cm-14.1
repo sync -c -j 16
source build/envsetup.sh
breakfast <device codename>   # example: breakfast grouper
brunch <device codename>      # example: brunch grouper

For further information, check the following links:

More information

==================