Skip to content
Easier React Native upgrades by clearly exposing changes from a version to another. πŸš€ And what better way than to purge, init, then diff? Spoiler: there's no better way. 😎
Branch: master
Clone or download
Pull request Compare This branch is 287 commits ahead, 246 commits behind react-native-community:master.
Latest commit 4df9620 Mar 22, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.config
.github
diffs Removing versions before 0.23.1 Mar 19, 2019
docs remove them from the big table too Mar 19, 2019
.eslintignore init Feb 26, 2019
.eslintrc.js init Feb 26, 2019
.gitignore update gitignore Mar 17, 2019
AUTHORS
README.md Merge pull request #25 from joebernard/patch-1 Mar 17, 2019
README_MAINTAINERS.md updates Mar 5, 2019
USAGE.md init Feb 26, 2019
VERSIONS Removing versions before 0.23.1 Mar 19, 2019
generate-table.js update index Mar 11, 2019
multiple-versions-diffs.sh use β€”binary flag for diffs Mar 17, 2019
multiple-versions.sh
new-version.sh
package.json Bump eslint from 5.15.1 to 5.15.3 Mar 19, 2019
yarn.lock

README.md

RN diff PURGE

(Pavlos' playground repo to make PURGE even better!)

THIS REPO HAS MOVED TO THE OFFICIAL REACT-NATIVE-COMMUNITY ORGANIZATION. 😍

FIND IT HERE:

πŸ’ͺ react-native-community/rn-diff-purge πŸŽ‰

Huge thanks to everyone involved, and everyone using and praising this repo! No, you are the best!

This repository exposes an untouched React Native app generated with the CLI react-native init RnDiffApp. Each new React Native version causes a new project to be created, removing the old one, and getting a diff between them. This way, the diff is always clean, always in sync with the changes of the init template.

A dedicated branch per version makes changes very easy to watch. For example:

See table below for the complete list.

For some more info about the benefits of this repo's way versus the default way and rn-diff's way, read some of the conversation around here.

Please ⭐️ this repository if I helped you, and if you upgraded successfully because of purge, buy me a pizza πŸ•

Find the diff you need

https://pvinis.github.io/purge-web/

Help us

Help us make this full table pretty and more useful.

Probably having some nice alternating row color, having the leftest column stay on top and always visible, and having a nice width for the content of each cell to fit in one line would be some ideas, but you are welcome to try other things!

Diff table (full table HERE)

From->To D I F F S = = F U N
0.59.1 X - - - - - - - - - - -
0.59.0 ->0.59.1 X - - - - - - - - - -
0.59.0-rc.3 ->0.59.1 ->0.59.0 X - - - - - - - - -
0.59.0-rc.2 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 X - - - - - - - -
0.59.0-rc.1 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 X - - - - - - -
0.59.0-rc.0 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 X - - - - - -
0.58.6 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 X - - - - -
0.58.5 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 ->0.58.6 X - - - -
0.58.4 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 ->0.58.6 ->0.58.5 X - - -
0.58.3 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 ->0.58.6 ->0.58.5 ->0.58.4 X - -
0.58.2 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 ->0.58.6 ->0.58.5 ->0.58.4 ->0.58.3 X -
0.58.1 ->0.59.1 ->0.59.0 ->0.59.0-rc.3 ->0.59.0-rc.2 ->0.59.0-rc.1 ->0.59.0-rc.0 ->0.58.6 ->0.58.5 ->0.58.4 ->0.58.3 ->0.58.2 X

To see the full table containing all versions click HERE

Notes

History of this repo

Once upon a time there was react-native. Lots of people used it and loved it. And there were often updates. As many as one per 2 weeks. People loved the new versions with all the new cool APIs and components and bugfixes. But how did they upgrade?

Many people tried to upgrade and automate the process, and many failed. One succeded.

Nicolas Cuillery (github, twitter) made a great script and kept it in the rn-diff repo. It basically consisted of a project branch, which had a react-native project initialized and upgraded using react-native-git-upgrade, which he also created. That worked great until it didn't. Nicolas added a few people including me to help with the repo, and we did update it, adding new upgrade diffs. At some point, the upgrades didn't work anymore, the react-native-git-upgrade way got too hard to maintain and make work.

I saw that it was easier to just remove the old project and react-native init a new one, and then generate the diff. This way I could see the changes in the template as well, helping my projects follow along with the evolution of the RN project templates. That way, an upgrade was never a big undertaking. I forked rn-diff and created rn-diff-purge. The script changed, to remove and recreate the project. This helped me and others by not having to wait for a diff to be generated, they could generate it themselves!

Lastly, the rn-diff-purge repo got transfered to the react-native-community organization, in the repo with the same name, rn-diff-purge. Since then I have made the new way to generate and keep track of versions, made a table that allows for releaes to always be diff-able no matter the order. I have kept the old master branch and old project branch for maintaining history, but I have created the new master branch and the app-base that all versions branch off from, and each release gets its own branch, for example version/0.58.6. We are already working with react-native-cli to help people upgrade as easily as possible, and we will continue to do our best.

Many thanks to you for using this repo, many thanks to Nicolas for starting this, and many thanks to the React Native Core team and React Native Contributors team for helping make this repo and RN project upgrading awesome.

Hooks

React Native 0.59.0-rc.0 gets hooks! πŸŽ‰πŸ₯³
Here are some docs:

Thanks to the RN team!

Why this repository?

react-native-git-upgrade is painful. A simple diff by recreating the project is a much much simpler way to get a diff on every new React Native version.

FAQ

Why starting from 0.22.0?

Because I couldn't run react-native init with an older version than that without the cli throwing errors. I hope people are not using still 0.22.0 anymore (Jan 2019).

How did you do this?

I made a script. Then I ran a helper script to make the rest of the versions. Now I just ran the new-version.sh script manually when I get the email that there is a new version published on npm, and I am making a bot to do that for me.

How can I contribute?

Unfortunately it's a bit weird. The master branch is the keeping-track one. Then there is the app-base branch that is the starting point of every other branch. Every react-native verison gets its own branch. So having PRs that change master is great, but for adding a new version, a new branch has to be created, and that is only possible by the contributors of this repo.

Nevertheless, when a new version of React Native is released, we'll have to be prompt to provide the new diff. Having more collaborators on this project will help in the future. If you're interested, please open an issue to discuss.

One thing that could get some love is the docs/index.html file, which produces a very basic html table. I would like to make it prettier and easier to navigation, but my css-fu is level 0. I would love to see what you can do to make it so! <3

Down here!

If you have:

  • questions
  • suggestions
  • ideas to make this even better
  • the urge to just to say hello to me :)

feel free to make an issue or contact me. I'm pretty easy to find!

You can’t perform that action at this time.