PATCH: detect.py: repos_URI referenced before assignment
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
EasyUbuntu |
New
|
Undecided
|
Unassigned |
Bug Description
Upon trying to install EasyUbuntu, first package install repeatedly failed. Below is description of symptoms, analysis of bug, and patch.
DESCRIPTION
Debug shows:
[snip a bunch of yada-yada-yada and apt-get stuff ]
Setting up libqt-perl (3.008-1.4) ...
Traceback (most recent call last):
File "/usr/lib/
replace_
File "/usr/lib/
baselist = makeRepos(repolist, repoxml)
File "/usr/lib/
(localrepos
File "/usr/lib/
return localrepos,
UnboundLocalError: local variable 'repos_URI' referenced before assignment
ANALYSIS
I read detect.py ante line 207 and saw that it wanted to fiddle with the repository list. (For those of you who don't speak Texan, "to fiddle with" means approximately "to make changes to".) The variable 'repos_URI' is defined inside an "if" statement. The condition is never true in my repository list because I look to a local repository that already has "main restricted universe multiverse" for each source. Consequently, 'repos_URI' never gets defined.
PATCH
Insert immediately after line 192:
repos_URI = ''
(That is two single quotes, not a double quote.)
Then when I ran EasyUbuntu like usual, it downloaded and installed the right packages from my local repository, just like it should.
After inserting the line, the function looks like this:
<code>
def getLocalRepos(
"""
Get the list of repositories already enabled on the computer
"""
localrepos = []
default = repoxml.
defreposlist = default.
distroident = default.
defrepo_URI = default.
repos_URI = ''
sourcelist = open('/
for line in sourcelist:
"""
deb http://
"""
if not "cdrom" in line and line.startswith
# This is the official ubuntu repository, get the additional components enabled
for component in line.split()[3:]:
sourcelist.
return localrepos,
</code>
RELATED SUGGESTIONS:
1. I note that "dapper" is hard-coded in the function. Perhaps it would be fruitful to create a variable that would load the appropriate release (dapper, edgy, feisty, etc.) and use a "for" statement to cycle through myRelease, myRelease-updates, myRelease-
2. I also note that ubuntu's US repository is migrating to http://
myRelease main restricted
and append "universe multiverse" to the end. (Of course, you'd also have to make sure that they weren't already there.)
Happy Trails,
Loye Young
www.IYCC.net
Laredo, Texas
Hack only seems to work if the repository list is selected. It's easy enough to check the box, but it's not intuitive to check the box when you've already added the repositories by hand. I don't have time at the moment to figure out how to add the right logic to the script, but I am posting this bug so it doesn't get forgotten.
I'm wondering if that selection should even be an option. If the user wants the packages installed, they have to come from somewhere. The whole point of EasyUbuntu is to install the software that isn't in the out-of-the-box distribution.
Happy Trails,
Loye Young
www.IYCC.net
Laredo, Texas