summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--apt/cache.py25
-rw-r--r--debian/changelog5
-rw-r--r--python/progress.cc5
3 files changed, 34 insertions, 1 deletions
diff --git a/apt/cache.py b/apt/cache.py
index cc425ccb..94a77fd8 100644
--- a/apt/cache.py
+++ b/apt/cache.py
@@ -60,8 +60,33 @@ class Cache(object):
apt_pkg.Config.Set("Dir", rootdir)
apt_pkg.Config.Set("Dir::State::status",
rootdir + "/var/lib/dpkg/status")
+ # create required dirs/files when run with special rootdir
+ # automatically
+ self._check_and_create_required_dirs(rootdir)
self.open(progress)
+ def _check_and_create_required_dirs(self, rootdir):
+ """
+ check if the required apt directories/files are there and if
+ not create them
+ """
+ files = ["/var/lib/dpkg/status",
+ "/etc/apt/sources.list",
+ ]
+ dirs = ["/var/lib/dpkg",
+ "/etc/apt/",
+ "/var/cache/apt/archives/partial",
+ "/var/lib/apt/lists/partial",
+ ]
+ for d in dirs:
+ if not os.path.exists(rootdir+d):
+ print "creating: ",rootdir+d
+ os.makedirs(rootdir+d)
+ for f in files:
+ if not os.path.exists(rootdir+f):
+ open(rootdir+f,"w")
+
+
def _runCallbacks(self, name):
""" internal helper to run a callback """
if name in self._callbacks:
diff --git a/debian/changelog b/debian/changelog
index 3bd90bed..316c83bc 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -2,6 +2,11 @@ python-apt (0.7.10.4ubuntu1) karmic; urgency=low
[ Michael Vogt ]
* merged from debian/unstable
+ * apt/cache.py:
+ - when the cache is run with a alternative rootdir, create
+ required dirs/files automatically
+ * python/progress.cc:
+ - fix crash in RunSimpleCallback()
[ Loic Minier ]
* Merge changes below from Michael Casadevall; note that these changes were
diff --git a/python/progress.cc b/python/progress.cc
index c5a1c138..ef114e89 100644
--- a/python/progress.cc
+++ b/python/progress.cc
@@ -25,9 +25,12 @@ bool PyCallbackObj::RunSimpleCallback(const char* method_name,
PyObject *method = PyObject_GetAttrString(callbackInst,(char*) method_name);
if(method == NULL) {
- // FIXME: make this silent
//std::cerr << "Can't find '" << method_name << "' method" << std::endl;
Py_XDECREF(arglist);
+ if (res) {
+ Py_INCREF(Py_None);
+ *res = Py_None;
+ }
return false;
}
PyObject *result = PyEval_CallObject(method, arglist);