-
Notifications
You must be signed in to change notification settings - Fork 663
How to create an overlay?
This guide is made for devices providing Treble with stock vendor. For devices with only unofficial implementation, cooperate directly with the unofficial vendor provider.
Set up a Linux machine – it may be the newest Ubuntu or Mint. If you aren't planning to run it alongside Windows, use a virtual machine, for example VirtualBox, or build with Jenkins.
You can install all needed deps with this command sudo apt install git xmlstarlet aapt apktool
Install apktool by following its guide.
If there's a framework-res__auto_generated_rro.apk
, FrameworksResCommon.apk
(or something like that) overlay on your device in /vendor/overlay
directory, copy it to your PC. If there's nothing like that (try searching for everything with framework and .apk in the name), install your stock system (or extract it on PC) and copy the system/framework/framework-res.apk
file.
Whatever you found, decompile it by apktool.
Install git if you don't have it by:
sudo apt install git
On your desktop, open up the terminal, write:
git clone https://github.com/phhusson/vendor_hardware_overlay.git
Find your brand or create its directory, create a directory with your device's official name inside it. Copy some other device's Android.mk
and replace in it:
LOCAL_PACKAGE_NAME := treble-overlay-brand-device
On your device, in adb or Termux app use this command:
getprop ro.vendor.build.fingerprint
On PC, copy AndroidManifest.xml
and replace in it:
package="me.phh.treble.overlay.brand.device"
android:requiredSystemPropertyValue="+brand/device*"
Where brand and device for property value is what you got from that getprop
command.
Then inside your device's directory, create a res
folder and copy inside the xml
folder (if exists) from apk decompiled by apktool. Then inside the res
, also copy the values
folder. Inside it, delete every file which isn't called arrays
, bools
, integers
, strings
(.xml).
Then you need to merge all .xml into config.xml (copy all file content within <resources></resources>
).
Install xmlstarlet if you don't have it by:
sudo apt install xmlstarlet
Then go into vendor_hardware_overlay/tests
, open terminal and run:
bash tests.sh
If you see lines like this defines a non-existing attribute APKTOOL_DUMMY_36
after test you need to delete this attribute from config.xml
As a result, you'll get a recommended priority level which you should replace in your AndroidManifest.xml
.
Inside the overlay.mk
of main directory add your LOCAL_PACKAGE_NAME
, in the alphabetic order.
Then if you want (but you should), go into vendor_hardware_overlay/build/
and run:
bash build.sh
It'll build you an overlay which you should put in /system/product/overlay/
on your device.
(if you see errors like this when you build overlays Error: No resource found that matches the given name (at 'storageDescription' with value '@string/storage_usb').
you need to remove this attributes from files)
Before building, you should push your commit into Github first.
Install xmlstarlet on your remote server if you don't have it by:
sudo apt install xmlstarlet
Set a new job in Jenkins (Freestyle project is OK)
Navigate to General
section, click ADVANCED...
, then make Use custom workspace
checked.
Then set a path (what you like, e.g: /tmp/overlay
) into Directory
field.
Navigate to Build
section, click ADD BUILD STEP
, then select Execute shell
.
Copy following codes into Command
field:
#!/bin/bash
git clone https://github.com/yourusername/vendor_hardware_overlay.git
cd vendor_hardware_overlay
git checkout master
cd build
chmod u+x ./build.sh
./build.sh
cd ../tests
chmod u+x tests.sh
./tests.sh
After that, navigate to Post-build Actions
, click ADD POST-BUILD ACTION
, then select Archive the artifacts
.
Input vendor_hardware_overlay/build/*.apk
into Files to archive
field.
Click ADD POST-BUILD ACTION
again, then select Delete workspace when build is done
.
Finally, Click Save
, and click Build Now
.
(Don't forget to view Console Output
, it will show errors here.)
If build succeeded, you can see there's a link named Last Successful Artifacts
.
Then click (all files in zip)
to download your overlay files.
On GitHub, create an account and fork the original repo by phhusson.
Open up terminal in vendor_hardware_overlay
, then type:
git add --all
git commit -m "Add overlay for yourdevicenamehere"
git remote add myrepo https://github.com/yourusername/vendor_hardware_overlay.git
git push myrepo master
Then use pull request function on GitHub and apply to tips and guidance by people commenting :)
If you do extra changes, repeat:
git commit -m "Your change description"
git push myrepo master
If you create a messy pile of commits or your git "stops working", copy your changes somewhere else, clone original (phhusson) repo again, paste your changes into the newly downloaded one and force push them by:
git add --all
git commit -m "Add overlay for yourdevicenamehere"
git remote add myrepo https://github.com/yourusername/vendor_hardware_overlay.git
and: git push -f myrepo master