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)

Q: installing dependency lxml failed with fatal error: ‘libxml/xmlversion.h’ file not found A: There are several ways to fix this listed on stackoverflow [http://stackoverflow.com/questions/19548011/cannot-install-lxml-on-mac-os-x-10-9](http://stackoverflow.com/questions/19548011/cannot-install-lxml-on-mac-os-x-10-9)

## 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-07-27   v0.1.5   Fixes bugs * 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.5 (2015-07-27)

  • Check if the file exists before removing values.

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.5.tar.gz (10.1 kB view details)

Uploaded Source

File details

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

File metadata

File hashes

Hashes for android-resource-remover-0.1.5.tar.gz
Algorithm Hash digest
SHA256 612a01ff406b0eb63829bd4f1cd6603ba292a28c8996c25a18a2d851cf80de54
MD5 3c1fa277b7e62058fec7d9f97d6dfad1
BLAKE2b-256 97774f48e40fb7d49ec90cdf5644148227b35fcdafede09bdae6b00132fe8322

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