Summary: | [PATCH] devel/avrdude: properly handle config file | ||||||
---|---|---|---|---|---|---|---|
Product: | Ports & Packages | Reporter: | Dmitry Marakasov <amdmi3> | ||||
Component: | Individual Port(s) | Assignee: | Joerg Wunsch <joerg> | ||||
Status: | Closed Not Accepted | ||||||
Severity: | Affects Only Me | CC: | amdmi3, joerg | ||||
Priority: | Normal | ||||||
Version: | Latest | ||||||
Hardware: | Any | ||||||
OS: | Any | ||||||
See Also: | https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=205344 | ||||||
Attachments: |
|
Description
Dmitry Marakasov
2014-04-04 18:20:01 UTC
Responsible Changed From-To: freebsd-ports-bugs->joerg Over to maintainer (via the GNATS Auto Assign Tool) As Dmitry Marakasov wrote: > +@unexec if cmp -s %D/etc/avrdude.conf.dist %D/etc/avrdude.conf; then rm -f %D/etc/avrdude.conf; fi > +etc/avrdude.conf.dist > +@exec if [ ! -f %B/avrdude.conf ]; then cp -p %D/%F %B/avrdude.conf; fi I disagree. avrdude.conf is not supposed to have user-servicable parts inside. It is supposed to be in AVRDUDE's domain, so it can be changed whenever the config file parser changes (which e.g. will happen with the upgrade to the next major version, 6.x). The user-extensible part is ~/.avrduderc. If someone wishes to have a site-specific extension file, we could probably arrange that (like, ${prefix}/etc/avrdude.conf.local), but then, please request that to the AVRDUDE project. -- cheers, Joerg .-.-. --... ...-- -.. . DL8DTL http://www.sax.de/~joerg/ Never trust an operating system you don't have sources for. ;-) * Joerg Wunsch (j@uriah.heep.sax.de) wrote: > > +@unexec if cmp -s %D/etc/avrdude.conf.dist %D/etc/avrdude.conf; then rm -f %D/etc/avrdude.conf; fi > > +etc/avrdude.conf.dist > > +@exec if [ ! -f %B/avrdude.conf ]; then cp -p %D/%F %B/avrdude.conf; fi > > I disagree. > > avrdude.conf is not supposed to have user-servicable parts inside. As far as it is installed into etc, we may not and should not expect user to know this. Everything in etc is user-changeable and must be handled appropriately. Also, you are not right: manpage says in clear text that the file can be modified: --- -C config-file Use the specified config file to load configuration data. This file contains all programmer and part definitions that avrdude knows about. If you have a programmer or part that avrdude does not know about, you can add it to the config ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ file (be sure and submit a patch back to the author so that it can be incorporated for the next version). See the con- fig file, located at ${PREFIX}/etc/avrdude.conf, which con- tains a description of the format. --- > it can be changed whenever the config file parser changes True for each and every config file, but not a reason to not have configs or to not preserve user changes. -- Dmitry Marakasov . 55B5 0596 FF1E 8D84 5F56 9510 D35A 80DD F9D2 F77D amdmi3@amdmi3.ru ..: jabber: amdmi3@jabber.ru http://www.amdmi3.ru As Dmitry Marakasov wrote: > As far as it is installed into etc, we may not and should not expect > user to know this. Everything in etc is user-changeable and must be > handled appropriately. Today, I would probably rather install it under ${prefix}/share if I had to decide anew. The fact it resides in ${prefix}/etc is merely historical. I have added a warning at the top of the file to not manually modify it. > Also, you are not right: manpage says in clear text that the file can > be modified: I have changed this. In the next release, this paragraph won't be there anymore. Even if FreeBSD decides it wants to run extra circles to not overwrite it, for everyone else, "make install" in AVRDUDE *will* overwrite that file, so it's certainly never a good idea to have user modifications in it. There's a (relatively new) option to specify an additional config file using -C +filename which should be used for user overrides. -- cheers, Joerg .-.-. --... ...-- -.. . DL8DTL http://www.sax.de/~joerg/ Never trust an operating system you don't have sources for. ;-) * Joerg Wunsch (j@uriah.heep.sax.de) wrote: > > As far as it is installed into etc, we may not and should not expect > > user to know this. Everything in etc is user-changeable and must be > > handled appropriately. >=20 > Today, I would probably rather install it under ${prefix}/share if I > had to decide anew. The fact it resides in ${prefix}/etc is merely > historical. I haven't noticed you're it's developer as well. I'd discourage from this choice: as I've already mentioned, problem changing config format affects all software which uses configs, it's the matter of developer's foresight to chose format extensible enough from beginning, and that's not a reason to not use configs or to pretend that config is some kind of constant data, or to limit user in it's right to change config as he likes. Using .avrduderc won't save user from changed config format either, by the way. The correct choice seem to be a warning encouraging user to use dotfile, but config should still be handled as config. And since you're developer, here's what I've actually needed custom config for: programmer id =3D "five-wires"; desc =3D "\"Five wires\" parallel programmer"; type =3D par; sck =3D 6; mosi =3D 7; reset =3D 9; =20 miso =3D 10; ; That's handmade "=D0=BF=D1=8F=D1=82=D1=8C =D0=BF=D1=80=D0=BE=D0=B2=D0=BE=D0= =B4=D0=BA=D0=BE=D0=B2" ("five wires") AVR programmer popular in Russia: http://www.123avr.com/07.htm http://www.getchip.net/posts/delaem-lpt-programmator-dlya-avr-mikrokontro= llerov/ https://www.google.ru/search?q=3D=D0=BF=D1=8F=D1=82=D1=8C+=D0=BF=D1=80=D0= =BE=D0=B2=D0=BE=D0=B4=D0=BA=D0=BE=D0=B2&tbm=3Disch http://translate.google.com/#ru/en/=D0=BF=D1=8F=D1=82=D1=8C%20=D0=BF=D1=80= =D0=BE=D0=B2=D0=BE=D0=B4=D0=BA=D0=BE=D0=B2 (Russian, but see images) It seems to be similar to stk200, but doesn't use buffer pins. > > Also, you are not right: manpage says in clear text that the file can > > be modified: >=20 > I have changed this. In the next release, this paragraph won't be > there anymore. >=20 > Even if FreeBSD decides it wants to run extra circles to not overwrite > it, for everyone else, "make install" in AVRDUDE *will* overwrite that > file, so it's certainly never a good idea to have user modifications > in it. Actually, it's the opposite: --- Makefile.am install-exec-local: backup-avrdude-conf ... backup-avrdude-conf: @echo "Backing up avrdude.conf in ${DESTDIR}${sysconfdir}" @if test -e ${DESTDIR}${sysconfdir}/avrdude.conf; then \ cp -pR ${DESTDIR}${sysconfdir}/avrdude.conf \ ${DESTDIR}${sysconfdir}/avrdude.conf.bak; \ fi --- --=20 Dmitry Marakasov . 55B5 0596 FF1E 8D84 5F56 9510 D35A 80DD F9D2 F77D amdmi3@amdmi3.ru ..: jabber: amdmi3@jabber.ru http://www.amdmi3.ru |