Need help with rn-diff-purge?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

react-native-community
928 Stars 49 Forks MIT License 664 Commits 18 Opened issues

Description

Easier React Native upgrades by clearly exposing changes from a version to another. :rocket: And what better way than to purge, init, then diff? Spoiler: there's no better way. 😎

Services available

!
?

Need anything else?

Contributors list

RN diff PURGE

This repository exposes an untouched React Native app generated with the CLI

npx @react-native-community/cli init RnDiffApp
. Each new React Native release 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 release makes changes very easy to watch. For example:

  • https://github.com/react-native-community/rn-diff-purge/compare/release/0.28.0..release/0.29.0 (Change in Android template)
  • https://github.com/react-native-community/rn-diff-purge/compare/release/0.29.0..release/0.29.2 (no change)
  • https://github.com/react-native-community/rn-diff-purge/compare/release/0.30.0..release/0.31.0 (minor change in
    .flowconfig
    )
  • https://github.com/react-native-community/rn-diff-purge/compare/release/0.30.0..release/0.31.0 (minor change in
    .flowconfig
    )

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 :star: this repository if I helped you, and if you upgraded successfully because of

purge
, buy me a pizza :pizza:

Find the diff you need

https://react-native-community.github.io/upgrade-helper/

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 | I | | L | O | V | E | | D | I | F | F | S | | ----------- | --------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | --- | | 0.64.0 | X | - | - | - | - | - | - | - | - | - | - | - | | 0.64.0-rc.3 | ->0.64.0 | X | - | - | - | - | - | - | - | - | - | - | | 0.64.0-rc.2 | ->0.64.0 | ->0.64.0-rc.3 | X | - | - | - | - | - | - | - | - | - | | 0.64.0-rc.1 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | X | - | - | - | - | - | - | - | - | | 0.64.0-rc.0 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | X | - | - | - | - | - | - | - | | 0.63.4 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | X | - | - | - | - | - | - | | 0.63.3 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | X | - | - | - | - | - | | 0.63.2 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | ->0.63.3 | X | - | - | - | - | | 0.63.1 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | ->0.63.3 | ->0.63.2 | X | - | - | - | | 0.63.0 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | ->0.63.3 | ->0.63.2 | ->0.63.1 | X | - | - | | 0.63.0-rc.1 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | ->0.63.3 | ->0.63.2 | ->0.63.1 | ->0.63.0 | X | - | | 0.63.0-rc.0 | ->0.64.0 | ->0.64.0-rc.3 | ->0.64.0-rc.2 | ->0.64.0-rc.1 | ->0.64.0-rc.0 | ->0.63.4 | ->0.63.3 | ->0.63.2 | ->0.63.1 | ->0.63.0 | ->0.63.0-rc.1 | X |

To see the full table containing all releases 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 releases 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 releases, made a table that allows for releases 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 releases branch off from, and each release gets its own branch, for example release/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: - Hooks API Reference - Introducing Hooks - Hooks at a Glance

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 release.

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-release.sh
script manually when I get the email that there is a new release 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 release gets its own branch. So having PRs that change master is great, but for adding a new release, a new branch has to be created, and that is only possible by the contributors of this repo.

Nevertheless, when a new release 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!

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.