• Stars
    star
    1,272
  • Rank 36,997 (Top 0.8 %)
  • Language
    Python
  • License
    Apache License 2.0
  • Created almost 11 years ago
  • Updated over 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A simple utility to remove unused resources in your Android app to lower the size of the APK. It's based on the Android lint tool output.

Build Status

resource-remover android-resource-remover

android-resource-remover is utility that removes unused resources reported by Android Lint 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:\Dev\Android SDK\tools\lint

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:\Dev\My_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

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

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.

Licence

Apache version 2.0

More Repositories

1

TapTargetView

An implementation of tap targets from the Material Design guidelines for feature discovery.
Java
5,372
star
2

ReLinker

A robust native library loader for Android.
Java
3,197
star
3

dexcount-gradle-plugin

A Gradle plugin to report the number of method references in your APK on every build.
Java
3,061
star
4

MultiStateAnimation

Android library to create complex multi-state animations.
Java
403
star
5

Switchboard

Switchboard - easy and super light weight A/B testing for your mobile iPhone or android app. This mobile A/B testing framework allows you with minimal servers to run large amounts of mobile users.
287
star
6

ks-email-parser

A command line tool to render HTML and text emails of markdown content.
Python
36
star
7

Cashier

A Better Billing Provider for Android.
Java
26
star
8

genstrings_swift

genstrings commandline tool for Swift
Python
20
star
9

Switchboard-iOS

A/B testing and feature flags for iOS & macOS built on top of Switchboard
Swift
11
star
10

zendesk-helpcenter-cms

Simple CMS to manage Zendesk help-center content with multi language support.
Python
8
star
11

measure

You can't optimize what you don't measure
Clojure
8
star
12

Tracer-iOS

Use traces to validate UX flows, analytics, or event buses
Swift
8
star
13

Switchboard-Android

A/B testing and feature flags for Android built on top of Switchboard
Java
3
star
14

five_most_recent_app

Zendesk app to show the last 5 tickets. This is a modification of Zendesk original version.
JavaScript
1
star
15

content-validator

Content validator looks at text content and preforms different validation tasks.
Python
1
star