Why you should change your mobile app version format to [year].[week].[iteration]

As a software engineer, I’ve been trained to think that there’s only one way to version software: semantic versioning.

At Photoroom, we used to increment the major version number on big releases to celebrate. Recently, however, we moved our mobile apps to a versioning scheme like like 2025.51.01 (so [year].[weekNumber].[iteration])

The main reason is convenience. At a glance you can know whether a user contacting support is on an old version or not or if a coworker reporting a bug forgot to update.

It’s also quite useful to understand version distribution. You can see below that most users on iOS are on version 2025.50.03 (meaning the third iteration of the 50th week of the year) and are progressively upgrading to 2025.51.01:

Version distribution, with Android on the left and iOS on the right
One convenient thing you can do is deprecate some routes by looking at the version number to know which clients are older than one year/some duration, here’s some pseudocode:

version = request.headers["pr-app-version"]
weeksSinceAppWasReleased = parseWeeksSinceAppRelease(version)
if weeksSinceAppWasReleased >= 52:
   return {error: "APP_OUTDATED", errorMessage: "Your app is outdated, please visit the app store to update"}

The downsides

As App Store version have to be incremental, so once you try this setup, you can’t go back.

When we implemented it, I also worried that such long version numbers would be a bit scary for users on the app store listing page, but it seems they don’t mind.

On my side, I’m still a bit worried when I see Uber’s super long version number
Overall, I’d recommend this setup in a heartbeat if you run a mobile app at scale.

If you find this article useful, go discuss it on Hacker News.

Eliot AndresCo-founder @ Photoroom
Why you should change your mobile app version format to [year].[week].[iteration]

Keep reading

Embracing radical openness: How a “No DM” Slack policy drives impact at Photoroom
Matthieu Rouif
Picking a state management library for a React app used by millions (and why we went with MobX)
Eliot Andres
Packaging your PyTorch project in Docker
Eliot Andres
Photoroom foundation diffusion model: why, how, and where do we go from there?
Benjamin Lefaudeux
Building live collaboration in Rust for millions of users, part 5
Florian Denis
How we measured the CO2 emissions of our AI models at inference time
Matthieu Toulemont
What's new in product: September 2024
Jeanette Sha
How we divided our server latency by 3 by switching from T4 GPUs to A10g
Matthieu Toulemont
Photoroom acquires GenerateBanners and launches Visual Ads Automation—first-to-market GenAI engine for large-scale ad creatives
Lyline Lim
The value of values: What we learned from an afternoon spent drawing Axolotls
Lauren Sudworth

Sell faster with studio‑quality product visuals

Drive sales with professional visuals you can create in minutes, with brand consistency and control.