This should be what it feels like to bump the major version of your software:

For me, the main reason for package versioning is to indicate the (slight or significant) differences among different versions of the same package, otherwise we can keep on releasing the version 1.0.
That seems to be a very obvious fact, so here are my own versioning rules, with some ideas borrowed from Semantic Versioning:
- a version number is of the form
major.minor.patch(x.y.z), e.g.,0.1.7 - only the version
x.yis released to CRAN x.y.zis always the development version, and each time a new feature or a bug fix or a change is introduced, bump the patch version, e.g., from0.1.3to0.1.4- when one feels it is time to release to CRAN, bump the minor version,
e.g., from
0.1to0.2 - when a change is crazy enough that many users are presumably going to
yell at you (see the illustration above), it is time to bump the major
version, e.g., from
0.18to1.0 - the version
1.0does not imply maturity; it is just because it is potentially very different from0.x(such as API changes); same thing applies to2.0vs1.0
I learned the rule #3 from Michael Lawrence (author of RGtk2) and I
think it is a good idea. In particular, it is important for brave users who
dare install the development versions. When you ask them for their
sessionInfo(), you will be aware of which stage they are at.
Rule #2 saves us a little bit energy in the sense that we do not need to write or talk about the foo package 1.3.548, which is boring to type or speak. Normally we say foo 1.3. As a person whose first language is not English, speaking the patch version does consume my brain memory and slows down my thinking while I’m talking. When I say it in Chinese, I feel boring and unnecessarily geeky. Yes, I know I always have weird opinions.
Donate
As a freelancer (currently working as a contractor) and a dad of three kids, I truly appreciate your donation to support my writing and open-source software development! Your contribution helps me cope with financial uncertainty better, so I can spend more time on producing high-quality content and software. You can make a donation through methods below.
-
Venmo:
@yihui_xie, or Zelle:xie@yihui.name -
Paypal
-
If you have a Paypal account, you can follow the link https://paypal.me/YihuiXie or find me on Paypal via my email
xie@yihui.name. Please choose the payment type as “Family and Friends” (instead of “Goods and Services”) to avoid extra fees. -
If you don’t have Paypal, you may donate through this link via your debit or credit card. Paypal will charge a fee on my side.
-
-
Other ways:
WeChat Pay (微信支付:谢益辉) Alipay (支付宝:谢益辉) 

When sending money, please be sure to add a note “gift” or “donation” if possible, so it won’t be treated as my taxable income but a genuine gift. Needless to say, donation is completely voluntary and I appreciate any amount you can give.
Please feel free to email me if you prefer a different way to give. Thank you very much!
I’ll give back a significant portion of the donations to the open-source community and charities. For the record, I received about $30,000 in total (before tax) in 2024-25, and gave back about $15,000 (after tax).