]> git.saurik.com Git - cydia.git/commitdiff
Fixed package holds on Changes.
authorJay Freeman (saurik) <saurik@saurk.com>
Sun, 21 Dec 2008 09:40:45 +0000 (09:40 +0000)
committerJay Freeman (saurik) <saurik@saurik.com>
Thu, 30 Sep 2010 07:09:21 +0000 (07:09 +0000)
Cydia.mm

index 7a5a33d130aaf5e2f0dac2a48c909c4ae4c744c7..15e167aedd7d9d3943da4424e798273e4a8d65b2 100644 (file)
--- a/Cydia.mm
+++ b/Cydia.mm
@@ -262,7 +262,7 @@ extern NSString * const kCAFilterNearest;
 
 #define lprintf(args...) fprintf(stderr, args)
 
 
 #define lprintf(args...) fprintf(stderr, args)
 
-#define ForRelease 0
+#define ForRelease 1
 #define ForSaurik (1 && !ForRelease)
 #define IgnoreInstall (0 && !ForRelease)
 #define RecycleWebViews 0
 #define ForSaurik (1 && !ForRelease)
 #define IgnoreInstall (0 && !ForRelease)
 #define RecycleWebViews 0
@@ -1582,10 +1582,12 @@ class Progress :
 - (BOOL) upgradableAndEssential:(BOOL)essential {
     pkgCache::VerIterator current = iterator_.CurrentVer();
 
 - (BOOL) upgradableAndEssential:(BOOL)essential {
     pkgCache::VerIterator current = iterator_.CurrentVer();
 
+    bool value;
     if (current.end())
     if (current.end())
-        return essential && [self essential];
+        value = essential && [self essential];
     else
     else
-        return !version_.end() && version_ != current;
+        value = !version_.end() && version_ != current && (!essential || ![database_ cache][iterator_].Keep());
+    return value;
 }
 
 - (BOOL) essential {
 }
 
 - (BOOL) essential {
@@ -1921,9 +1923,10 @@ class Progress :
         } bits;
     } value;
 
         } bits;
     } value;
 
-    value.bits.upgradable = [self upgradableAndEssential:YES] ? 1 : 0;
+    bool upgradable([self upgradableAndEssential:YES]);
+    value.bits.upgradable = upgradable ? 1 : 0;
 
 
-    if ([self upgradableAndEssential:YES]) {
+    if (upgradable) {
         value.bits.timestamp = 0;
         value.bits.ignored = [self ignored] ? 0 : 1;
         value.bits.upgradable = 1;
         value.bits.timestamp = 0;
         value.bits.ignored = [self ignored] ? 0 : 1;
         value.bits.upgradable = 1;