I have written earlier about a new concept for chemmacros and about the current development of chemmacros. I really want to go along with e idea of modularity. In fact so much that I already have a draft completed (without manual and probably a number of bugs but still…). The big question is, though: How do I procede without annoying all the users of chemmacros? If I am consequent with the modularity then there need to be breaking changes.
Currently I see three options of how to procede:
Picture: © Thorben Wengert/pixelio
- Make the changes, publish the new chemmacros and live with the fact that users will be annoyed.
- Publish the new version as new package (name?) and deprecate chemmacros. This would mean people would eventually need to change packages if they want new features and bug fixes. chemmacros could issue a warning when loaded that it is deprecated and that there is a successor. Similar changes are not unprecedented: think of glossary and glossaries, or the various unit packages and siunitx.
- Add loads and loads of compatibility code which gently directs users towards the new syntax/option names/… – this is the version I favor the least as it is a lot of work and there is no guarantee that I’ll cover all cases.
Picture: © Thorben Wengert/pixelio
I am in favour of deprecating chemmacros and provide a successor. Would be easier for the support forums as well, because there will be a great amount if the first option would be chosen.
At the moment I also think this would be the cleanest solution. Do you have suggestions for a name? chemistry? chemmacrosx? cnchem? chemhelper? chemsupport? ltxchem? chemltx?
Can’t say i am a person who likes to make decisions. Thinking from a standpoint that tries to ease the access to starters, i think chemsupport might be a good name.
I will go with an alternative package ([cci_latex]chemsupport[/cci_latex], https://github.com/cgnieder/chemsupport) for the time being and will decide on how to procede (and which package name if I chose that alternative) when the new version has reached the stability to be published.
I like [cci_latex]chemcomp[/cci_latex] as package name: could read chemistry comprehensive (which has two meanings already) and chemistry companion.
Nevertheless I am still struggling. Finding a suiting package name is harder than I thought! I definitely don’t like [cci_latex]chemmacros2[/cci_latex] or [cci_latex]chemmacrosx[/cci_latex] (although this would be the easiest solution and probably easiest to understand for users, too)! The [cci_latex]ltx[/cci_latex]-versions imply some intrinsic connection to the LaTeX format. So they’re not well suited! [cci_latex]chemsupport[/cci_latex] is OKish, better than [cci_latex]chemhelper[/cci_latex] or something but for reasons I can’t put my fingers upon I don’t quite like it, either.
There is actually a fourth way: the biblatex way:
[cce_latex]\ifblx@load@version@one
\expandafter\@firstoftwo
\else
\expandafter\@secondoftwo
\fi
{%
% stuff …
\RequirePackage{biblatex1}%
}
{\RequirePackage{biblatex2}}[/cce_latex]
biblatex needs to do that in order to support the older BibTeX-method. Same user-interface with a different implementation, i would say .995 users don’t know about that and don’t care. I think that would be the case here as well. Using the new package as default, and getting the current functionality via option [cci_latex]version=chemmacros[/cci_latex]? I like it somehow, but it will be strange once [cci_latex]chemsupport[/cci_latex] (or whatever it will be called) is far superior.
The point is that you have one package on the surface (biblatex) but two packages underneath. That way I may be able to stay with chemmacros and use the old and the new version underneath… I need to think about this
I finally decided to go a similar way that [cci_latex]biblatex[/cci_latex] does: the package will still be called [cci_latex]chemmacros[/cci_latex] and can be called
[cce_latex]\usepackage[compatibility=4.7,language=german]{chemmacros}[/cce_latex]
to get the old version loaded. Using no [cci_latex]compatibility[/cci_latex] option or [cci_latex]compatibility=5.0[/cci_latex] (or higher for future versions) will load the new package with its modularity features.
[cce_latex]\documentclass{article}
% \usepackage[compatibility=4.7,language=english]{chemmacros}
\usepackage[language=english]{chemmacros}
\IfChemCompatibilityT{>=5.0}
{\usechemmodule{reactions}}
\usepackage{hyperref}
\begin{document}
\begin{reactions}
A + B -> C \\
D + E -> F “\label{bla}”
\end{reactions}
\end{document}[/cce_latex]