Ticket #1263 (new defect)
Get rid of /usr/athena
Reported by: | jdreed | Owned by: | |
---|---|---|---|
Priority: | normal | Milestone: | Current Semester |
Component: | -- | Keywords: | |
Cc: | Fixed in version: | ||
Upstream bug: |
Description
I would like to finally kill off /usr/athena. We can do this in stages, first by shipping a compatibility layer telling people that they're wrong.
Discussion related to #1261 suggests that we will never ever be able to change or repoint the /usr/athena symlink, but experimentation suggests that it has no effect on running programs. People should post actual evidence for when it will break, if there are any screw cases. If there aren't, I would love to, for example ship /usr/lib/athena-compat/{bin,lib,include,sbin,share}, and repoint /usr/athena to /usr/lib/athena-compat. /usr/lib/athena-compat/{bin,sbin} can then be filled with symlink targets for things like Perl, Python, etc, which print a message to stderr, and either do the right thing anyway, or error out. Then we can eventually pull the symlink. We can populate include/lib/share/whatever with README files saying "Go away."
Change History
comment:2 Changed 11 years ago by jdreed
I'm told that there's a thread on debian-devel and way to fix this in the preinst. We should do this.
comment:3 Changed 11 years ago by jdreed
- Milestone changed from Raring Ringtail to Summer 2013
OK, let's do this this summer. Proposal:
- Release a new debathena-base without the symlinks, and instead with actual directories that existed in /usr/athena and /bin/athena as of Athena 9.4.
-- Anything not a bin directory has a single README file in it telling people to go away.
-- The bin directory contains symlinks for all targets that existed under Athena 9.4, which will print a message to stderr telling people to fix their code. Optionally, they could run the real program anyway.
-- We should ensure we don't break login shells, so /bin/athena/{tcsh, bash} should just be "real" symlinks.
- The preinst of the aforementioned debathena-base nukes the existing symlinks so that dpkg won't fail to unpack the replacement directories.
Pros:
- This makes it easier to completely nuke /usr/athena in a year. (/bin/athena will require some cleverness with passwd entries, and I'll file a separate ticket).
- This makes it _actually_ compatible with Athena 9.4, as opposed to the current hack, which permits people to do stupid things like /usr/athena/bin/dpkg, which was never a real thing.
Cons:
- This will break binaries with incredibly broken rpaths (we don't care, I think).
- There's probably a small race condition between the preinst running and the unpack. I don't think we are obliged to care.
Thoughts? Screw cases I've missed?
I can't remember if we determined that there are screw cases, or what. If not, I'd love to use Ringtail as an excuse to build a debathena-base without the damn symlink.