]> git.saurik.com Git - apt.git/blame - apt-pkg/update.cc
apt-key: change to / before find to satisfy its CWD needs
[apt.git] / apt-pkg / update.cc
CommitLineData
d428d131
MV
1// Include Files /*{{{*/
2#include <config.h>
3
d428d131 4#include <apt-pkg/acquire-item.h>
453b82a3
DK
5#include <apt-pkg/configuration.h>
6#include <apt-pkg/error.h>
d428d131 7#include <apt-pkg/fileutl.h>
453b82a3
DK
8#include <apt-pkg/sourcelist.h>
9#include <apt-pkg/acquire.h>
10#include <apt-pkg/strutl.h>
ac7f8f79 11#include <apt-pkg/update.h>
d428d131 12
453b82a3 13#include <string>
d428d131
MV
14
15#include <apti18n.h>
16 /*}}}*/
17
18using namespace std;
19
20// ListUpdate - construct Fetcher and update the cache files /*{{{*/
21// ---------------------------------------------------------------------
22/* This is a simple wrapper to update the cache. it will fetch stuff
23 * from the network (or any other sources defined in sources.list)
24 */
25bool ListUpdate(pkgAcquireStatus &Stat,
26 pkgSourceList &List,
27 int PulseInterval)
28{
04a54261
DK
29 pkgAcquire Fetcher(&Stat);
30 if (Fetcher.GetLock(_config->FindDir("Dir::State::Lists")) == false)
d428d131
MV
31 return false;
32
33 // Populate it with the source selection
34 if (List.GetIndexes(&Fetcher) == false)
35 return false;
36
37 return AcquireUpdate(Fetcher, PulseInterval, true);
38}
39 /*}}}*/
40// AcquireUpdate - take Fetcher and update the cache files /*{{{*/
41// ---------------------------------------------------------------------
42/* This is a simple wrapper to update the cache with a provided acquire
43 * If you only need control over Status and the used SourcesList use
44 * ListUpdate method instead.
45 */
46bool AcquireUpdate(pkgAcquire &Fetcher, int const PulseInterval,
47 bool const RunUpdateScripts, bool const ListCleanup)
48{
49 // Run scripts
50 if (RunUpdateScripts == true)
51 RunScripts("APT::Update::Pre-Invoke");
52
53 pkgAcquire::RunResult res;
54 if(PulseInterval > 0)
55 res = Fetcher.Run(PulseInterval);
56 else
57 res = Fetcher.Run();
58
59 if (res == pkgAcquire::Failed)
60 return false;
61
62 bool Failed = false;
63 bool TransientNetworkFailure = false;
35664152 64 bool AllFailed = true;
d428d131
MV
65 for (pkgAcquire::ItemIterator I = Fetcher.ItemsBegin();
66 I != Fetcher.ItemsEnd(); ++I)
67 {
35664152
JAK
68 if ((*I)->Status == pkgAcquire::Item::StatDone) {
69 AllFailed = false;
d428d131 70 continue;
35664152 71 }
d428d131
MV
72
73 (*I)->Finished();
74
75 ::URI uri((*I)->DescURI());
76 uri.User.clear();
77 uri.Password.clear();
78 string descUri = string(uri);
f695e761
JAK
79 // Show an error for non-transient failures, otherwise only warn
80 if ((*I)->Status == pkgAcquire::Item::StatTransientNetworkError)
81 _error->Warning(_("Failed to fetch %s %s"), descUri.c_str(),
82 (*I)->ErrorText.c_str());
83 else
84 _error->Error(_("Failed to fetch %s %s"), descUri.c_str(),
85 (*I)->ErrorText.c_str());
d428d131
MV
86 if ((*I)->Status == pkgAcquire::Item::StatTransientNetworkError)
87 {
88 TransientNetworkFailure = true;
89 continue;
90 }
91
92 Failed = true;
93 }
94
95 // Clean out any old list files
96 // Keep "APT::Get::List-Cleanup" name for compatibility, but
97 // this is really a global option for the APT library now
98 if (!TransientNetworkFailure && !Failed && ListCleanup == true &&
99 (_config->FindB("APT::Get::List-Cleanup",true) == true &&
100 _config->FindB("APT::List-Cleanup",true) == true))
101 {
102 if (Fetcher.Clean(_config->FindDir("Dir::State::lists")) == false ||
103 Fetcher.Clean(_config->FindDir("Dir::State::lists") + "partial/") == false)
104 // something went wrong with the clean
105 return false;
106 }
35664152
JAK
107
108 bool Res = true;
d428d131
MV
109
110 if (TransientNetworkFailure == true)
35664152 111 Res = _error->Warning(_("Some index files failed to download. They have been ignored, or old ones used instead."));
d428d131 112 else if (Failed == true)
35664152 113 Res = _error->Error(_("Some index files failed to download. They have been ignored, or old ones used instead."));
d428d131
MV
114
115
116 // Run the success scripts if all was fine
117 if (RunUpdateScripts == true)
118 {
35664152 119 if(AllFailed == false)
d428d131
MV
120 RunScripts("APT::Update::Post-Invoke-Success");
121
122 // Run the other scripts
123 RunScripts("APT::Update::Post-Invoke");
124 }
35664152 125 return Res;
d428d131
MV
126}
127 /*}}}*/