Catalog
Catalog copied to clipboard
Generate type-safe, user-friendly extensions to resolve Android resources.
Catalog
Just like View Binding, but for resources.
Catalog is a Gradle plugin that generates type-safe, user-friendly extensions to resolve Android resources.
Let's see how the following string resource gets resolved without and with Catalog:
<string name="good_morning_with_weather">Good morning, %1$s! It’s %2$d°C outside.</string>
Without Catalog:
Android resource resolution is overly verbose. It also uses snake case for resource identifiers, which diverts away from Java/Kotlin naming conventions. In addition, parametrized strings and plurals are not type safe. Android Studio comes with a very loose lint check for argument types, but it treats all arguments as optional and it won't flag if you miss one.
Here's how we resolve string resources without Catalog:
data:image/s3,"s3://crabby-images/4375b/4375be781402b7698be8ac68c1ffb1b4a351163d" alt=""
With Catalog:
data:image/s3,"s3://crabby-images/e796c/e796c9934fe7fb8fd755264017c6ee7b679a6eb5" alt="image"
You can also use Catalog to access the resource id directly:
data:image/s3,"s3://crabby-images/3fc9d/3fc9d4a279be52ab63b7fe2a02cbc4e01f64a59e" alt="image"
Catalog also works with plurals:
<plurals name="unread_messages">
<item quantity="one">You have %1$d unread message</item>
<item quantity="other">You have %1$d unread messages</item>
</plurals>
data:image/s3,"s3://crabby-images/0b30e/0b30e9e3a0cd66aec8aa38928a949b714bedf8d3" alt="image"
string arrays:
<string-array name="seasons">
<item>Spring</item>
<item>Summer</item>
<item>Fall</item>
<item>Winter</item>
</string-array>
data:image/s3,"s3://crabby-images/818c9/818c95ab858bb8c4825cdb7c6c0c83d3335a64aa" alt="image"
and simple color resources:
<color name="red">#FFFF0000</color>
data:image/s3,"s3://crabby-images/b4bc9/b4bc90df83610a384748b1bc21a27c928a6d12f4" alt="image"
In the future, other resource types like integer arrays, dimensions, etc. will also be supported.
Comment support
Resource comments are also carried over to extension properties and methods:
<!-- This string resource is used in the launcher screen. -->
<string name="app_name">Catalog</string>
data:image/s3,"s3://crabby-images/9e353/9e353fee25a57fc97df30a39ff764fe35c048ba9" alt=""
Compose support
If you're using compose, @Composable
extensions will also be generated. In order to avoid
signature clashes, Compose extensions are extension methods of
com.flaviofaria.catalog.runtime.compose.[String, Plurals, StringArray]
whereas standard extensions
are extension methods of com.flaviofaria.catalog.runtime.resources.[String, Plurals, StringArray]
,
so make sure you're importing the right class.
data:image/s3,"s3://crabby-images/e3e77/e3e77ac56b699a7abdc8a9282caac3b8550a508d" alt=""
How it works
Catalog generates Context
and Fragment
extensions using context receivers.
data:image/s3,"s3://crabby-images/5f87b/5f87b26766d0df3181ac13611d4bd63a98791bcb" alt="Screen Shot 2022-09-27 at 11 14 14 PM"
Since these extensions are inline
, there will be no increase in your app method count or any
significant impact on runtime performance.
Setup and configuration
To use Catalog, just apply the plugin to your module:
plugins {
id 'com.flaviofaria.catalog' version '0.2.1'
}
By default, Catalog generates non-Compose extensions only. Compose extensions will also be generated if it detects Compose among your module dependencies. If your project is 100% written in Compose, you can explicitly turn off non-Compose extensions by adding:
catalog {
generateResourcesExtensions = false
}
Similarly, you can also turn off Compose extensions:
catalog {
generateComposeExtensions = false
}