Skip to main content

Android resource remover

Project description

[![Build Status](https://travis-ci.org/KeepSafe/android-resource-remover.svg?branch=master)](https://travis-ci.org/KeepSafe/android-resource-remover)

android-resource-remover

android-resource-remover is utility that removes unused resources reported by [Android Lint](http://developer.android.com/tools/help/lint.html) from your project. The goal is to reduce your APK size and keep the app clean from unused stuff.

## Getting started Requirements:

  • Python >= 2.7.*

  • ADT >= 16

To install run:

pip install android-resource-remover

## Usage - general Open the directory where your app is located and run

` android-resource-remover `

Android resources have dependencies to each other. This means that after running resource-remover the first time, it will clean up unused resources file that hold a reference to other resources. You can run this resource remover multiple times until there is no more unused resources to be removed. We’ve been running it up to 4 times in a row.

### Use with gradle android-resource-remover is build on top of android lint. If you have a gradle project you have to run lint within your gradle build scripts and then use the lint-result.xml as the input file for android-resource-remover

e.g.

./gradlew clean build :lint && android-resource-remover –xml build/outputs/lint-results.xml

### Options

#### –help Prints help message.

#### –lint Full path to the lint tool like: d:DevAndroid SDKtoolslint

This will be executed as the lint command. If not provided it assumes the lint command in available and runs: lint

#### –app Full path to the android app like: d:DevMy_Android_App

If not provided it assumes the current directory is the app’s root directory.

#### –xml

Use existing lint result. If provided lint won’t be run.

#### –ignore-layouts

Ignore layout directory

## Expected behavior ### Resource ID in code not found

If you have references to elements in an old layout that you’re not using anymore, you will get a compile error that the ID (R.id.<something>) can not be found. The reason is that the resource file that contained R.id.<something> has been removed as it was not used any more. Time to clean up your code.

## FAQ

Q: installing dependency lxml failed with clang: error: unknown argument: ‘-mno-fused-madd’ [-Wunused-command-line-argument-hard-error-in-future] A: [http://stackoverflow.com/a/22322645](http://stackoverflow.com/a/22322645)

## Issues and PR

When opening an issue please include as much info as possible. pip.log, python varsion/info, os version/info might all be help us understanding what’s the problem.

In PR please keep the formatting.

## Release History * 2015-05-21   v0.1.4   Fixes bugs * 2015-03-31   v0.1.3   Fixes bugs * 2015-03-25   v0.1.2   Fixes bugs * 2014-09-11   v0.1.1   Fixes bugs * 2014-02-14   v0.1.0   Initial release

## Licence Apache version 2.0

CHANGES

0.1.4 (2015-05-21)

  • Includes data files for pip.

0.1.3 (2015-03-31)

  • Executes subprocess in a safe way.

0.1.2 (2015-03-25)

  • Fixes #9. Supports new missing resource message pattern.

0.1.1 (2014-09-11)

  • Fixes #5. Checks if the file exists before trying to remove it.

0.1.0 (2014-02-14)

  • Initial release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

android-resource-remover-0.1.4.tar.gz (9.9 kB view details)

Uploaded Source

File details

Details for the file android-resource-remover-0.1.4.tar.gz.

File metadata

File hashes

Hashes for android-resource-remover-0.1.4.tar.gz
Algorithm Hash digest
SHA256 f7633218c37dda4b8ae017a94129a35b4b143dbd7fa5131a75b5a5832920a9c8
MD5 60bcf1ea5d5dc6ccae422c8a75674b57
BLAKE2b-256 02a9f2dde5be6452edfd27be5502334fa7770401e32a902824127ba11549facc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page