Inspect the resources of your android projects and understand which ones are not being used and could potentially be removed.

Overview

Android Resources Checker

Flake8 Black Coverage License

What

This program will inspect the resources of your app and help you understand which ones are not being used and could potentially be removed.

Main features:

  • Identify the unused resources in your android project.
  • Identify the unused resources in your android library (when you have a multi-repo setup)
  • Listing of the unused resources (name, type and size)
  • Deletion of the unused resources

Installing

This program requires Python, supporting from 3.8.x and 3.9.x

In order to install run:

pip install -U android-resources-checker

Using

Inspecting your app resources.

Imagining your app in the project subject-app, you can trigger the resources inspection by running:

android-resources-checker --app /path/to/subject-app

Inspecting your library app resources.

In the case you have two projects in separate repos, where a client-app depends on a lib-app, you can check the unused resources of the library app by running:

android-resources-checker \
  --app /path/to/lib-app \
  --client /path/to/client-app-1 \
  --client /path/to/client-app-2

An example of a run could look like this:

Reports

The default behavior is to generate reports on both the stdout and CSV.

You can specify a single type of report using the --report=(CSV|STDOUT) option.

If using CSV reports, you can specify the directory where to write the reports in the form of CSV files. For that use the --reports-dir option.

For example:

android-resources-checker \
  --app /path/to/app \ 
  --reports-dir /path/to/reports

Validation

There is also the option to run this as a validation tool. In this case, it will fail with an error if any unused resources are found.

To specify the validation use the --check flag (the default behavior is to perform no validation).

Automatic Deletion

You can use this tool to also delete the unused resources by using the --delete option.

License


Copyright (c) 2021 Dotanuki Labs, Fabio Carballo

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
documentation files (the "Software"), to deal in the Software without restriction, including without limitation the
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit
persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the
Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

You might also like...
Graphene Metanode is a locally hosted node for one account and several trading pairs, which uses minimal RAM resources.

Graphene Metanode is a locally hosted node for one account and several trading pairs, which uses minimal RAM resources. It provides the necessary user stream data and order book data for trading in a format one would expect from a centralized exchange API.

ARA Records Ansible and makes it easier to understand and troubleshoot.
ARA Records Ansible and makes it easier to understand and troubleshoot.

ARA Records Ansible ARA Records Ansible and makes it easier to understand and troubleshoot. It's another recursive acronym. What it does Simple to ins

All you need to understand CRUD and MVP in DRF
All you need to understand CRUD and MVP in DRF

Book-Store-API This an API which has been put in place just to make you order for books, upload books with price, image and all, pay and automtically

This repository provides a set of easy to understand and tested Python samples for using Acronis Cyber Platform API.

Base Acronis Cyber Platform API operations with Python !!! info Copyright © 2019-2021 Acronis International GmbH. This is distributed under MIT licens

🎅🏻 Helping santa understand ✨ python ✨

☃️ Advent of code 2021 ☃️ Helping santa understand ✨ python ✨

Users can read others' travel journeys in addition to being able to upload and delete posts detailing their own experiences

Users can read others' travel journeys in addition to being able to upload and delete posts detailing their own experiences! Posts are organized by country and destination within that country.

An open letter in support of Richard Matthew Stallman being reinstated by the Free Software Foundation

An open letter in support of RMS. To sign, click here and name the file username.yaml (replace username with your name) with the following content

Neogex is a human readable parser standard, being implemented in Python

Neogex (New Expressions) Parsing Standard Much like Regex, Neogex allows for string parsing and validation based on a set of requirements. Unlike Rege

Get information about what a Python frame is currently doing, particularly the AST node being executed

executing This mini-package lets you get information about what a frame is currently doing, particularly the AST node being executed. Usage Getting th

Comments
  • Issues with MIT licensing

    Issues with MIT licensing

    First of all, congrats for the good job on this tool. Looks quite great!

    It's quite hard to say that, but it seems that your project is not compliant with MIT license at all.

    The reason for that is simple : your project takes A LOT of inspiration from the open-source work I've been doing at @dotanuki-labs. Particularly it is easy to realise that when comparing this project with bitrise-reports

    I can list a few of them:

    • Same project structure driven by Poetry + Makefile (including some targets using the same names)
    • Same Github Actions Workflows (main.yml and publish.yml), incluing Job's names, Python versions, pipeline steps
    • Very similar file structure (entrypoint.py, reporting.py, app.py, etc)
    • Very similar file contents, as per entrypoint.py (from bitrise-reports) and entrypoint.py (from this project)

    Hell, even some lines of README look the same ... and this init kinda makes crystal clear that inspiration maybe went too far ...

    Open-source is meant to be collaborative and inspirational, yes. For sure I have no issues with people forking, modifying and/or re-distributing my code. Most likely that proves I'm in a good track at all.

    However, licensing is important. Attribution is important. This article does a terrific job elaborating on that

    I love inspiring other people to do awesome stuff based on some of my concepts and thoughts and 
    I’m happy when I could help you with my code. So everybody is free to use my code, but now the 
    important part, under the given license terms. You could also say “credit where credits needed”. 
    
    Open source in the context of software does not mean you can copy the nice stuff and paste 
    it into your project and tell everybody you did a nice job.
    

    I can't recommend enough also checking these two extra resources to understand how MIT license works :

    It's also worth to highlight that deploys on Pypiship the source code exactly as it was written, which means that you've shipped snippets and/or entire pieces of code written by me without proper attribution while re-distributing.

    All of that being said : I'd like to ask you to change your LICENSE.md and README.md files with the following notice

    Copyright (c) 2021 Dotanuki Labs, Fabio Carballo
    
    [rest of the license terms]
    

    so your project becomes compliant with MIT and plays well with open-source. I won't bother about previous releases wrongly copyrighted if you gently commit with this suggestion and deploy a new version of this project, so users can get the proper copyrighted code when installing / updating this tool.

    I'm assuming here this issue eventually comes from some lacking of experience with open-source from your end, and* that is totally fine. Knowing you from our days working together at N26 I'm 100% sure you don't need such copy+pasta over other Engineer's work.

    Thanks in advance

    opened by ubiratansoares 2
  • ERROR: Could not complete analysis.

    ERROR: Could not complete analysis.

    Hi, I'm trying to run this script on my project (muli-module setup) and I am having this problem:

    Processing:
    [14:52:52] rappi - packaged resources processed!                       app.py:31
    ERROR:root:Could not complete analysis.
    Traceback (most recent call last):
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/site-packages/android_resources_checker/entrypoint.py", line 81, in launch
        application.execute(app, client, check, delete)
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/site-packages/android_resources_checker/app.py", line 33, in execute
        usage_references = self.resources_fetcher.fetch_used_resources(app_path)
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/site-packages/android_resources_checker/resources.py", line 73, in fetch_used_resources
        styles_references = self._style_usages_in_xml(filepath)
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/site-packages/android_resources_checker/resources.py", line 113, in _style_usages_in_xml
        for line in self.files_handler.file_content(filepath):
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/site-packages/android_resources_checker/files.py", line 33, in file_content
        return open(filepath).readlines()
      File "/Users/usuario/.pyenv/versions/3.9.7/lib/python3.9/codecs.py", line 322, in decode
        (result, consumed) = self._buffer_decode(data, self.errors, final)
    UnicodeDecodeError: 'utf-8' codec can't decode byte 0xe1 in position 1: invalid continuation byte
    

    Python version: 3.9.7 OS: macOS Monterrey 12.0.1

    opened by GianfrancoMS 0
  • support multiple clients

    support multiple clients

    What

    • Renamed --app-path to --app
    • Renamed --client-path to --client
    • Add ability to provide multiple clients.
      • This is done via the --client flag; you should use one for each of the clients.
    opened by fabiocarballo 0
Releases(v0.0.10)
  • v0.0.10(Apr 8, 2021)

    Version 0.0.10

    2021-05-08

    • Specify automatic deletion of unused resources via the --delete flag.
    • Fixes bugs in deletion that incorrectly deleted entries in file and whole files.
    Source code(tar.gz)
    Source code(zip)
  • v0.0.9(Apr 7, 2021)

    Version 0.0.9

    2021-04-07

    • Fix bug that was not considering resource names with '0' in the name.
    • Fix bug that was not considering all files of the project.
    Source code(tar.gz)
    Source code(zip)
  • v0.0.8(Apr 7, 2021)

    Version 0.0.8

    2021-04-07

    • Add ability to use it as a validation tool using the --check option.
    • Specify the type of report using the --report=(CSV|STDOUT) (the default is to run all).
    • Fixes bug that didn't check for resource usages in the AndroidManifest.xml
    Source code(tar.gz)
    Source code(zip)
  • v0.0.7(Apr 4, 2021)

    Version 0.0.7

    2021.04.05

    • Add inspection to style resources.
    • Update LICENSE.md and README.md with due copyright to Dotanuki Labs given that the structure/base of this project was highly inspired from Bitrise Reports.
    Source code(tar.gz)
    Source code(zip)
  • v0.0.6(Apr 2, 2021)

    Version 0.0.6

    2021-04-02

    • Add CSV reports via the --reports-dir option.
    • Fixes bug that ignored that didn't process resources that are not xml (such as the ones usually placed on raw)
    Source code(tar.gz)
    Source code(zip)
  • v0.0.4(Apr 1, 2021)

    Version 0.0.4

    2021-04-01

    • Add inspection to resources declared as entries (string, color, dimen)
    • Renamed --app-path to --app
    • Renamed --client-path to --client
    • Add ability to provide multiple clients.
      • This is done via the --client flag; you should use one for each of the clients.
    Source code(tar.gz)
    Source code(zip)
  • v0.0.3(Mar 29, 2021)

    Version 0.0.3

    2021-03-29

    Features:

    • Identify the unused resources in your android project.
    • Identify the unused resources in your android library (when you have a multi-repo setup)
    • Listing of the unused resources (name, type and size)
    • Deletion of the unused resources
    Source code(tar.gz)
    Source code(zip)
Owner
Fábio Carballo
Fábio Carballo
🔵Open many google dorks in a fasted way

Dorkinho 🔵 The author is not responsible for misuse of the tool, use it in good practices like Pentest and CTF OSINT challenges. Dorkinho is a script

SidHawks 2 May 02, 2022
Very Simple 2 Message Spammer!

Very Simple 2 Message Spammer!

Syntax. 4 Dec 06, 2022
Feapder的管道扩展

FEAPDER 管道扩展 简介 此模块为feapder的pipelines扩展,感谢广大开发者对feapder的贡献 随着feapder支持的pipelines越来越多,为减少feapder的体积,特将pipelines提出,使用者可按需安装 管道 PostgreSQL 贡献者:沈瑞祥 联系方式:r

boris 9 Dec 07, 2022
NFT generator for Solana!

Solseum NFT Generator for Solana! Check this guide here! Creating your randomized uniques NFTs, getting rarity information and displaying it on a webp

Solseum™ VR NFTs 145 Dec 30, 2022
tg-nearby Trilateration of nearby Telegram users as described in my corresponding article.

tg-nearby Trilateration of nearby Telegram users as described in my corresponding article. Setup If you want to toy with the code in this repository

Maximilian Jugl 75 Dec 26, 2022
A Python version of Canvacord

A copy of canvacord made in python! Installation Run any of these commands in terminal: Mac / Linux pip install canvacord Windows python -m pip insta

10 Mar 28, 2022
Project5 Data processing system

Project5-Data-processing-system User just needed to copy both these file to a folder and open Project5.py using cmd or using any python ide. It is to

1 Nov 23, 2021
Sentiment Based Product Recommendation System

Sentiment Based Product Recommendation System The e-commerce business is quite p

Sumit Sahay 2 Jan 15, 2022
Mini-calculadora escrita como exemplo para uma palestra relâmpago sobre `git bisect`

Calculadora Mini-calculadora criada para uma palestra relâmpado sobre git bisect. Tem até uma colinha! Exemplo de uso Modo interativo $ python -m calc

Eduardo Cuducos 3 Dec 14, 2021
RecurrentArchitectures - See the accompanying blog post

Why this? What is the goal? The goal of this repository is to write all the recurrent architectures from scratch in tensorflow for learning purposes.

Debajyoti Datta 9 Feb 06, 2022
一个Graia-Saya的插件仓库

一个Graia-Saya的插件仓库 这是一个存储基于 Graia-Saya 的插件的仓库 如果您有这类项目

ZAPHAKIEL 111 Oct 24, 2022
A Python software implementation of the Intel 4004 processor

Pyntel4004 A Python software implementation of the Intel 4004 processor. General Information Two pass assembler using the original mnemonics, directiv

alshapton 5 Oct 01, 2022
Program to send ROM files to Turbo Everdrive; reverse-engineered and designed to be platform-independent

PCE_TurboEverdrive_USB What is this "TurboEverdrive USB" thing ? For those who have a TurboEverdrive v2.x from krikzz.com, there was originally an opt

David Shadoff 10 Sep 18, 2022
Med to csv - A simple way to parse MedAssociate output file in tidy data

MedAssociates to CSV file A simple way to parse MedAssociate output file in tidy

Jean-Emmanuel Longueville 5 Sep 09, 2022
An Airflow operator to call the main function from the dbt-core Python package

airflow-dbt-python An Airflow operator to call the main function from the dbt-core Python package Motivation Airflow running in a managed environment

Tomás Farías Santana 93 Jan 08, 2023
The program converts Swiss notes into American notes

Informatik-Programmieren Einleitung: Das Programm rechnet Schweizer Noten in das Amerikanische Noten um. Der Benutzer kann seine Note eingeben und der

2 Dec 16, 2021
This script can be used to get unlimited Gb for WARP.

Warp-Unlimited-GB This script can be used to get unlimited Gb for WARP. How to use Change the value of the 'referrer' to warp id of yours You can down

Anix Sam Saji 1 Feb 14, 2022
TrackGen - The simplest tropical cyclone track map generator

TrackGen - The simplest tropical cyclone track map generator Usage Each line is a point to be plotted on the map Each field gives information about th

TrackGen 6 Jul 20, 2022
Doom o’clock is a website/project that features a countdown of “when will the earth end” and a greenhouse gas effect emission prediction that’s predicted

Doom o’clock is a website/project that features a countdown of “when will the earth end” and a greenhouse gas effect emission prediction that’s predicted

shironeko(Hazel) 4 Jan 01, 2022
Skip spotify ads by automatically restarting application when ad comes

SpotiByeAds No one likes interruptions! Don't you hate it when you're listening to your favorite jazz track or your EDM playlist and an ad for Old Spi

Partho 287 Dec 29, 2022