Details
- Reviewers
- ashish - mat 
- Group Reviewers
- O5: Ports Framework - (Owns No Changed Paths) - portmgr 
- Commits
- rP460701: Flavorize and modernize Emacs ports
 rP460700: Remove Mk/Uses/emacs.mk and japanese/migemo-emacs
 rP460621: Flavorize and modernize Emacs ports
Diff Detail
- Lint
- No Lint Coverage 
- Unit
- No Test Coverage 
- Build Status
- Buildable 14150 - Build 14322: arc lint + arc unit 
Event Timeline
The last TODO on my list is to check PORTREVISIONS to determine which should be bumped.
Side note, USE_EMACS -> USES=emacs ?
| cad/dinotrace/Makefile | ||
|---|---|---|
| 6 | This is most likely wrong. | |
| cad/verilog-mode.el/Makefile | ||
| 6 | Never change PORTVERSION to DISTVERSION if the version does not change. (This goes for the remaining of the patch.) | |
- Revert forced PORTVERSION -> DISTVERSION change
 cad/dinotrace is good example of why this is stupid.
- audio/emms, databases/bbdb: Fix build on 10
- Both ports fail with base texinfo, so depend on print/texinfo.
- Silence portlint warnings.
- Update and simplify audio/emms.
I think the dependencies should have ${EMACS_PKGNAMESUFFIX} and not ${PKGNAMESUFFIX}, a bit like the Python ports do, it makes it more clear what is really happening.
A goal with the flavor names was to introduce consistency with other ports (e.g., like vim, have a -lite variant). But, the vim-lite package was just renamed to vim-console, so I am open to suggestions. Should we stick with -nox11, -lite, match vim and use -console, or use something different?
| editors/emacs/Makefile | ||
|---|---|---|
| 48 | @jrm --- sorry for the late feedback. How about we keep CANNA option, and instead make the canna flavour turn ON that option, that way port will be backward compatible, and for users who are already running emacs with that option, can just continue to build/install emacs that they are already running without changes, in other words, this will be the least distractive path for them ? In other words, lets re-add CANNA option stuff (in Makefile, and pkg-plist), so if user does make config it will continue to see CANNA option. The only nitpicking with this approach is pkg-descr will continue to have CANNA support attribution line, even though user is not running CANNA enabled version, which IMHO is harmless. And ofcourse, we should definitely add a note about this new flavour support in UPDATING, so users who want CANNA support don't have to build the port by themselves, and can just use a editors/emacs@canna package. What do you say ? P.S. Thank you for working on this. | |
I'm not super familiar with ports flavors, and learning as I review stuff, I'll post questions:
- In pre-flavors (or before D13506 gets committed) era, if I use/install emacs-devel port (non-default emacs port) on my computer, and would like to use a port foobar which provides .el files and therefore specifies dependency on emacs port. Which emacs port it needs to depend on was decided by EMACS_PORT_NAME variable which is to be defined by user in make.conf(5), in case they're using non-default emacs port (like emacs-nox11, or emacs-devel as in my case). What is the solution for this situation in post-flavors era ? If I am not a packages user, and I do, make -C foobar install, what will I get, foobar-emacs25, foobar-emacs27, or what ?
- And if I specify FLAVOR=devel on command-line, or in make.conf(5) (to avoid passing flavor explicitly everytime), does that mean I am specifying that I would like to have devel FLAVOR for all ports in the build scope (wherever it's implemented), or devel FLAVOR name will now get reserved for Emacs ports.
- Also do you have some UPDATING note prepared for users to inform about such changes, as that will help me get answer to the some of the questions. If not then maybe time to work on it ?
Thanks!
You will get the default flavor, so probably foobar-emacs25. If you need another one, you run make -C foobar install FLAVOR=xxx.
- And if I specify FLAVOR=devel on command-line, or in make.conf(5) (to avoid passing flavor explicitly everytime), does that mean I am specifying that I would like to have devel FLAVOR for all ports in the build scope (wherever it's implemented), or devel FLAVOR name will now get reserved for Emacs ports.
Setting FLAVOR=devel in your make.conf will break every port that do not have a devel flavor. (And build this flavor for ports that do.)
| editors/emacs/Makefile | ||
|---|---|---|
| 48 | No, adding back the CANNA option is a bad idea. Using flavors is the way to go forward. An UPDATING entry saying how to get the -canna version is a better idea. | |
Thanks for confirmation, that's what I was expecting.
You will get the default flavor, so probably foobar-emacs25. If you need another one, you run make -C foobar install FLAVOR=xxx.
- And if I specify FLAVOR=devel on command-line, or in make.conf(5) (to avoid passing flavor explicitly everytime), does that mean I am specifying that I would like to have devel FLAVOR for all ports in the build scope (wherever it's implemented), or devel FLAVOR name will now get reserved for Emacs ports.
Setting FLAVOR=devel in your make.conf will break every port that do not have a devel flavor. (And build this flavor for ports that do.)
So, this seems inconvenient for one to remember specifying FLAVOR everytime they install an emacs dependent port when they deviate from defaults, and as I proposed in my other comment, I think we can handle this better by letting user specify their preference through make.conf(5).
| Mk/Uses/emacs.mk | ||
|---|---|---|
| 78 | @jrm --- how about we change it to EMACS_FLAVOR?= ${FLAVOR} that way user can override it in make.conf(5), as remember to specifying FLAVOR explicitly for emacs dependent port seems pretty inconvenient for me, and this way it will be similar to older method ? We'll just have to add an UPDATING note that instead of EMACS_PORT_NAME, use EMACS_FLAVOR to specify your desired version of Emacs. | |
| Mk/Uses/emacs.mk | ||
|---|---|---|
| 78 | EMACS_FLAVOR is only for dependencies and does not affect the current port, so EMACS_FLAVOR?= ${FLAVOR} won't give what you are looking for. I will have to give this some thought to see if something can be done to address your point. | |
There may be confusion, because the Emacs flavors describe more than the version. Maybe something like DEFAULT_FLAVORS+=... or DEFAULT_EMACS_FLAVOR?
@ Nobody says that the emacs version must only be , it can be whatever you want, including a combination of versions and flavor, look at what mysql has.
Please, do not invent a new variable for setting some defaults when there is something already here.
Yes, seems to me too, as if we encounter some emacs dependent port which has both python ports as dependencies, then specifying FLAVOR will break either Python, or Emacs dependency.
For me, I think we should restrict flavours only to various editors/emacs* ports, and not to dependencies. And dependencies can instead refer to the Emacs flavour user has opted for in DEFAULT_VERSIONS.
I think that a flavor that is set on the command line should take precedence over whatever is set for a default flavor in make.conf. But, how can we determine if the FLAVOR has been set on the command line and not because it was the default flavor, ${FLAVORS:[1]}? There is .MAKEOVERRIDES:=${.MAKEOVERRIDES:NFLAVOR} so .MAKEOVERRIDES is not an option. Then, again, there is the annoyance that the default flavor will not be supported by all Emacs ports. Is this convenience of allowing the default flavor in make.conf a showstopper now? Could it be added later? I am not aware of any other flavorized ports that support this. Also, my estimate of the overlap in the Venn diagram of users that 1) want to build the port (outside of poudriere), 2) do not want the default flavor, 3) cannot specify FLAVOR=blah on the command line is 3 users. :-P
I also brought this up in IRC and this was @bapt's response,
<bapt> this is exactly to avoir DEFAULT_VERSIONS that flavors do exists
<bapt> the best imho would be to introduce a new thing for make.conf
<bapt> like we do for otions
<bapt> instead of playing badly with DEFAULT_VERSIONS :)
So, maybe we could eventually add DEFAULT_FLAVORS=emacs=lite,vim=console,....
- Permit default Emacs flavor to be specified in make.conf
Example: DEFAULT_VERSIONS=emacs=lite
I broke down and added a way to specify the default Emacs flavor in make.conf using DEFAULT_VERSIONS. Tests are now running to build all ports with all flavors. I will report back and if all is well and everyone is happy, I will add an entry to UPDATING.
The flavor used to build a port does not propagate to dependencies, it is by design, because not all dependencies may need it, and they may need different flavors. If the dependencies need a flavor, you have to make sure the flavor is added to the dependency line.
I also brought this up in IRC and this was @bapt's response,
<bapt> this is exactly to avoir DEFAULT_VERSIONS that flavors do exists
<bapt> the best imho would be to introduce a new thing for make.conf
<bapt> like we do for otions
<bapt> instead of playing badly with DEFAULT_VERSIONS :)So, maybe we could eventually add DEFAULT_FLAVORS=emacs=lite,vim=console,....
Maybe, yes. Though it may work for emacs, it would not work for Python because of the Python 2 vs Python 3 chasm, as if you say DEFAULT_FLAVORS+= python=py27 and the port USES=python:3.4+ then what is the default Python flavor ? Is the port ignored ? Do we say it's py36 ? Right now, it uses PYTHON_DEFAULT, then PYTHON2_DEFAULT, then PYTHON3_DEFAULT.
- editors/emacs-devel: Update to the latest upstream commit
- Rename the lite Emacs flavor to nox [1]
- Do not exclude the ACL option for the nox Emacs flavors
- Remove editors/emacs-nox11
- Turn off unwanted features in configure stage for lite Emacs package flavors
- Minor whitespace changes in the Emacs ports
- Add an UPDATING entry for the Emacs ports framework update
[1] Use a more appropriate name that matches the package name on some other operating systems.
| UPDATING | ||
|---|---|---|
| 28 ↗ | (On Diff #38298) | Maybe also add an explicit note about editors/emacs-nox11 port being removed in favour of nox flavor, and above mentioned command-line can be used to install a non-X11 version of Emacs. Also any idea how upgrade will work ? Like whether folks need to use pkg set -o ... or something, or portmaster -o ... ? | 
| UPDATING | ||
|---|---|---|
| 28 ↗ | (On Diff #38298) | RE: upgrading, based on past changes and older MOVED entries, I assumed this would be transparent for package users. However, on one host that still had the emacs25-25.3_1,3 package installed, a pkg upgrade did not replace it with the new emacs-25.3_2,3. I will have to do some investigation. | 
| Mk/Uses/emacs.mk | ||
|---|---|---|
| 34 | This variable is redundant now. I removed it. | |
Update maintainer to emacs@ in Mk/Uses/emacs.mk, editors/emacs, and editors/emacs-devel
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=225404
The exp-run exposed one issue that has been fixed. Could we get portmgr approval to commit this?
The .include "${PORTSDIR}/Mk/bsd.emacs.mk" has to be removed from Mk/bsd.port.mk too.
- fix confict between emacs/w3m and www/w3m
- do not include Mk/bsd.emacs.mk in Mk/bsd.port.mk
- update dates MOVED and UPDATING
I see two issues after committing.
- I foolishly misinterpreted https://lists.freebsd.org/pipermail/freebsd-git/2015-April/000038.html to also apply to the move of japanese/migemo-emacs23 to japanese/migemo-emacs. The svn history was preserved for the files, but not the directory.
- For some reason the svn history was not preserved with the move of Mk/bsd.emacs.mk to Mk/Uses/emacs.mk. I definitely did do: git mv Mk/bsd.emacs.mk Mk/Uses/emacs.mk.
These git svn dcommit shortcomings are unfortunate. It's quite convenient to commit this way, but if it screws up the svn history, I will avoid it in the future except for simpler situations.
Now, I supposed I will have to back out these changes, patch an svn repository and commit directly with svn commit.
Git does not track file moves at all, also, it does not track directories. This is why in many projects, you have empty files named .gitkeep in empty directories, so that the directory are kept.
Whenever I have a patch in my git repository that has files moves or copies, I always fallback to subversion for the commit itself. I agree that this is a pain.
Does this look right? This is my first revert and it seems like a tricky one.
svn copy svn+ssh://repo.freebsd.org/ports/head/japanese/migemo-emacs23@460620 japanese svn rm japanese/migemo-emacs svn mv japanese/migemo-emacs23 japanese/migemo-emacs copy files under japanese/migemo-emacs from Phab revision svn copy svn+ssh://repo.freebsd.org/ports/head/Mk/bsd.emacs.mk@460620 Mk/ svn rm Mk/Uses/emacs.mk svn mv Mk/bsd.emacs.mk Mk/Uses/emacs.mk copy emacs.mk from Phab revision commit
It looks ok, but it will not work because you cannot replace files in one commit, you have to do it in two steps.
# save japanese/migemo-emacs and Mk/Uses/emacs.mk svn rm japanese/migemo-emacs Mk/Uses/emacs.mk svn commit
svn copy svn+ssh://repo.freebsd.org/ports/head/japanese/migemo-emacs23@460620 japanese/migemo-emacs svn copy svn+ssh://repo.freebsd.org/ports/head/Mk/bsd.emacs.mk@460620 Mk/Uses/emacs.mk # Copy the saved files at step 1 svn commit