From 5ec44e34139dc2c93a0b417c87f5f7233f48b657 Mon Sep 17 00:00:00 2001 From: "Jay Freeman (saurik)" Date: Fri, 30 Apr 2010 18:51:21 +0000 Subject: [PATCH] Added tokens, cydia::obsolete, faster search, header parsing, long descriptions on iPad, wide tables, abstracted dropBar, singleton keyboard, lazy panels, GraphicsServices capabilities, portrait-only, and ISOLatin1 fallback. --- Cydia.app/Info.plist | 4 +- Cydia.app/Sources/ispaziorepo.com.png | Bin 10712 -> 0 bytes Cydia.app/Sources/repo.neolinus.org.png | 1 - Cydia.mm | 250 ++++++++++++++++++------ Library/firmware.sh | 39 +++- control | 4 +- 6 files changed, 224 insertions(+), 74 deletions(-) delete mode 100644 Cydia.app/Sources/ispaziorepo.com.png delete mode 120000 Cydia.app/Sources/repo.neolinus.org.png diff --git a/Cydia.app/Info.plist b/Cydia.app/Info.plist index 05d10f1e..14be9bbe 100644 --- a/Cydia.app/Info.plist +++ b/Cydia.app/Info.plist @@ -60,9 +60,9 @@ UISupportedInterfaceOrientations UIInterfaceOrientationPortrait - UIInterfaceOrientationPortraitUpsideDown + diff --git a/Cydia.app/Sources/ispaziorepo.com.png b/Cydia.app/Sources/ispaziorepo.com.png deleted file mode 100644 index d6b1a3918e63b6b02acecf5b9057e3e2bc62cd04..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10712 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, size_, kCFStringEncodingUTF8, NO, kCFAllocatorNull); + if (cache_ == NULL) + cache_ = CFStringCreateWithBytesNoCopy(kCFAllocatorDefault, reinterpret_cast(data_), size_, kCFStringEncodingISOLatin1, NO, kCFAllocatorNull); } return cache_; } @@ -1042,6 +1044,7 @@ static const char *Machine_ = NULL; static const NSString *System_ = NULL; static const NSString *SerialNumber_ = nil; static const NSString *ChipID_ = nil; +static const NSString *Token_ = nil; static const NSString *UniqueID_ = nil; static const NSString *Build_ = nil; static const NSString *Product_ = nil; @@ -1063,6 +1066,8 @@ static _transient NSMutableDictionary *Sources_; static bool Changed_; static NSDate *now_; +static bool IsWildcat_; + #if RecycleWebViews static NSMutableArray *Documents_; #endif @@ -1728,6 +1733,7 @@ typedef std::map< unsigned long, _H > SourceMap; bool essential_; bool required_; bool visible_; + bool obsolete_; NSString *latest_; CYString installed_; @@ -1837,6 +1843,7 @@ typedef std::map< unsigned long, _H > SourceMap; - (void) remove; - (bool) isUnfilteredAndSearchedForBy:(NSString *)search; +- (bool) isUnfilteredAndSelectedForBy:(NSString *)search; - (bool) isInstalledAndVisible:(NSNumber *)number; - (bool) isVisibleInSection:(NSString *)section; - (bool) isVisibleInSource:(Source *)source; @@ -2189,13 +2196,12 @@ struct PackageNameOrdering : if (version == nil) { [metadata_ setObject:latest_ forKey:@"LastVersion"]; changed = true; - } else { - if (![version isEqualToString:latest_]) { + } else if (![version isEqualToString:latest_]) { [metadata_ setObject:latest_ forKey:@"LastVersion"]; lastSeen_ = now_; [metadata_ setObject:lastSeen_ forKey:@"LastSeen"]; changed = true; - } } + } } metadata_ = [metadata_ retain]; @@ -2210,6 +2216,7 @@ struct PackageNameOrdering : section_.set(pool_, iterator_.Section()); _end + obsolete_ = [self hasTag:@"cydia::obsolete"]; essential_ = ((iterator_->Flags & pkgCache::Flag::Essential) == 0 ? NO : YES) || [self hasTag:@"cydia::essential"]; [self setVisible]; } _end } return self; @@ -2391,7 +2398,7 @@ struct PackageNameOrdering : - (BOOL) unfiltered { NSString *section([self section]); - return section == nil || isSectionVisible(section); + return !obsolete_ && (section == nil || isSectionVisible(section)); } - (BOOL) visible { @@ -2643,9 +2650,9 @@ struct PackageNameOrdering : if (range.location != NSNotFound) return YES; - /* range = [[self shortDescription] rangeOfString:text options:MatchCompareOptions_]; + range = [[self shortDescription] rangeOfString:text options:MatchCompareOptions_]; if (range.location != NSNotFound) - return YES; */ + return YES; return NO; } @@ -2773,6 +2780,22 @@ struct PackageNameOrdering : _end } +- (bool) isUnfilteredAndSelectedForBy:(NSString *)search { + _profile(Package$isUnfilteredAndSelectedForBy) + bool value(true); + + _profile(Package$isUnfilteredAndSelectedForBy$Unfiltered) + value &= [self unfiltered]; + _end + + _profile(Package$isUnfilteredAndSelectedForBy$Match) + value &= [[self name] compare:search options:MatchCompareOptions_ range:NSMakeRange(0, [search length])] == NSOrderedSame; + _end + + return value; + _end +} + - (bool) isInstalledAndVisible:(NSNumber *)number { return (![number boolValue] || [self visible]) && ![self uninstalled]; } @@ -3815,8 +3838,27 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [super dealloc]; } +- (void) setHeaders:(NSDictionary *)headers forHost:(NSString *)host { +} + - (void) webView:(WebView *)sender didClearWindowObject:(WebScriptObject *)window forFrame:(WebFrame *)frame { [super webView:sender didClearWindowObject:window forFrame:frame]; + + WebDataSource *source([frame dataSource]); + NSURLResponse *response([source response]); + NSURL *url([response URL]); + NSString *scheme([url scheme]); + + NSHTTPURLResponse *http; + if (scheme != nil && ([scheme isEqualToString:@"http"] || [scheme isEqualToString:@"https"])) + http = (NSHTTPURLResponse *) response; + else + http = nil; + + NSDictionary *headers([http allHeaderFields]); + NSString *host([url host]); + [self setHeaders:headers forHost:host]; + [window setValue:cydia_ forKey:@"cydia"]; } @@ -3825,8 +3867,8 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [request setValue:System_ forHTTPHeaderField:@"X-System"]; if (Machine_ != NULL) [request setValue:[NSString stringWithUTF8String:Machine_] forHTTPHeaderField:@"X-Machine"]; - if (UniqueID_ != nil) - [request setValue:UniqueID_ forHTTPHeaderField:@"X-Unique-ID"]; + if (Token_ != nil) + [request setValue:Token_ forHTTPHeaderField:@"X-Cydia-Token"]; if (Role_ != nil) [request setValue:Role_ forHTTPHeaderField:@"X-Role"]; } @@ -4676,7 +4718,7 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { icon_ = [[package icon] retain]; name_ = [[package name] retain]; - description_ = [[package shortDescription] retain]; + description_ = [IsWildcat_ ? [package shortDescription] : [package longDescription] retain]; commercial_ = [package isCommercial]; package_ = [package retain]; @@ -4717,6 +4759,7 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { - (void) drawContentRect:(CGRect)rect { bool selected([self isSelected]); + float width(rect.size.width); #if 0 CGContextRef context(UIGraphicsGetCurrentContext()); @@ -4751,15 +4794,15 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { if (!selected) UISetColor(commercial_ ? Purple_ : Black_); - [name_ drawAtPoint:CGPointMake(48, 8) forWidth:(placard_ == nil ? 240 : 214) withFont:Font18Bold_ ellipsis:2]; - [source_ drawAtPoint:CGPointMake(58, 29) forWidth:225 withFont:Font12_ ellipsis:2]; + [name_ drawAtPoint:CGPointMake(48, 8) forWidth:(width - (placard_ == nil ? 80 : 106)) withFont:Font18Bold_ ellipsis:2]; + [source_ drawAtPoint:CGPointMake(58, 29) forWidth:(width - 95) withFont:Font12_ ellipsis:2]; if (!selected) UISetColor(commercial_ ? Purplish_ : Gray_); - [description_ drawAtPoint:CGPointMake(12, 46) forWidth:274 withFont:Font14_ ellipsis:2]; + [description_ drawAtPoint:CGPointMake(12, 46) forWidth:(width - 46) withFont:Font14_ ellipsis:2]; if (placard_ != nil) - [placard_ drawAtPoint:CGPointMake(268, 9)]; + [placard_ drawAtPoint:CGPointMake(width - 52, 9)]; } - (void) setSelected:(BOOL)selected animated:(BOOL)fade { @@ -4884,7 +4927,7 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { if (editing_) width -= 86; - [name_ drawAtPoint:CGPointMake(48, 9) forWidth:(width - 170) withFont:Font22Bold_ ellipsis:2]; + [name_ drawAtPoint:CGPointMake(48, 9) forWidth:(width - 70) withFont:Font22Bold_ ellipsis:2]; CGSize size = [count_ sizeWithFont:Font14_]; @@ -5428,6 +5471,7 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { } - (void) setObject:(id)object; +- (void) setObject:(id)object forFilter:(SEL)filter; - (id) initWithBook:(RVBook *)book database:(Database *)database title:(NSString *)title filter:(SEL)filter with:(id)object; @@ -5441,6 +5485,16 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [super dealloc]; } +- (void) setFilter:(SEL)filter { + filter_ = filter; + + /* XXX: this is an unsafe optimization of doomy hell */ + Method method(class_getInstanceMethod([Package class], filter)); + _assert(method != NULL); + imp_ = method_getImplementation(method); + _assert(imp_ != NULL); +} + - (void) setObject:(id)object { if (object_ != nil) [object_ release]; @@ -5450,6 +5504,12 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { object_ = [object retain]; } +- (void) setObject:(id)object forFilter:(SEL)filter { + [self setFilter:filter]; + [self setObject:object]; + +} + - (bool) hasPackage:(Package *)package { _profile(FilteredPackageTable$hasPackage) return [package valid] && (*reinterpret_cast(imp_))(package, filter_, object_); @@ -5458,15 +5518,8 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { - (id) initWithBook:(RVBook *)book database:(Database *)database title:(NSString *)title filter:(SEL)filter with:(id)object { if ((self = [super initWithBook:book database:database title:title]) != nil) { - filter_ = filter; + [self setFilter:filter]; object_ = object == nil ? nil : [object retain]; - - /* XXX: this is an unsafe optimization of doomy hell */ - Method method(class_getInstanceMethod([Package class], filter)); - _assert(method != NULL); - imp_ = method_getImplementation(method); - _assert(imp_ != NULL); - [self reloadData]; } return self; } @@ -5532,6 +5585,8 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { } - (void) drawContentInRect:(CGRect)rect selected:(BOOL)selected { + float width(rect.size.width); + if (icon_ != nil) [icon_ drawInRect:CGRectMake(10, 10, 30, 30)]; @@ -5540,15 +5595,15 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { if (!selected) UISetColor(Black_); - [origin_ drawAtPoint:CGPointMake(48, 8) forWidth:240 withFont:Font18Bold_ ellipsis:2]; + [origin_ drawAtPoint:CGPointMake(48, 8) forWidth:(width - 80) withFont:Font18Bold_ ellipsis:2]; if (!selected) UISetColor(Blue_); - [label_ drawAtPoint:CGPointMake(58, 29) forWidth:225 withFont:Font12_ ellipsis:2]; + [label_ drawAtPoint:CGPointMake(58, 29) forWidth:(width - 95) withFont:Font12_ ellipsis:2]; if (!selected) UISetColor(Gray_); - [description_ drawAtPoint:CGPointMake(12, 46) forWidth:280 withFont:Font14_ ellipsis:2]; + [description_ drawAtPoint:CGPointMake(12, 46) forWidth:(width - 40) withFont:Font14_ ellipsis:2]; [super drawContentInRect:rect selected:selected]; } @@ -5830,9 +5885,8 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { if (Machine_ != NULL) [request setValue:[NSString stringWithUTF8String:Machine_] forHTTPHeaderField:@"X-Machine"]; - if (UniqueID_ != nil) - [request setValue:UniqueID_ forHTTPHeaderField:@"X-Unique-ID"]; - + if (Token_ != nil) + [request setValue:Token_ forHTTPHeaderField:@"X-Cydia-Token"]; if (Role_ != nil) [request setValue:Role_ forHTTPHeaderField:@"X-Role"]; @@ -6089,6 +6143,14 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { @implementation HomeView +- (void) setHeaders:(NSDictionary *)headers forHost:(NSString *)host { + if (NSString *token = [headers objectForKey:@"X-Cydia-Token"]) { + if (Token_ != nil) + [Token_ release]; + Token_ = [token retain]; + } +} + - (void) alertSheet:(UIActionSheet *)sheet buttonClicked:(int)button { NSString *context([sheet context]); @@ -6102,6 +6164,8 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [super _setMoreHeaders:request]; if (ChipID_ != nil) [request setValue:ChipID_ forHTTPHeaderField:@"X-Chip-ID"]; + if (UniqueID_ != nil) + [request setValue:UniqueID_ forHTTPHeaderField:@"X-Unique-ID"]; } - (void) _leftButtonClicked { @@ -6191,11 +6255,13 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { UIProgressBar *progress_; UINavigationButton *cancel_; bool updating_; + bool dropped_; } - (id) initWithFrame:(CGRect)frame database:(Database *)database; - (void) update; - (BOOL) updating; +- (void) setUpdate:(NSDate *)date; @end @@ -6218,7 +6284,11 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { return updating_; } -- (void) update { +- (void) dropBar { + if (dropped_) + return; + dropped_ = true; + [UIView beginAnimations:nil context:NULL]; CGRect ovrframe = [overlay_ frame]; @@ -6235,6 +6305,37 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [transition_ setFrame:trnframe]; [UIView endAnimations]; +} + +- (void) raiseBar { + if (!dropped_) + return; + dropped_ = false; + + [UIView beginAnimations:nil context:NULL]; + + CGRect ovrframe = [overlay_ frame]; + ovrframe.origin.y = -ovrframe.size.height; + [overlay_ setFrame:ovrframe]; + + CGRect barframe = [navbar_ frame]; + barframe.origin.y -= ovrframe.size.height; + [navbar_ setFrame:barframe]; + + CGRect trnframe = [transition_ frame]; + trnframe.origin.y -= ovrframe.size.height; + trnframe.size.height += ovrframe.size.height; + [transition_ setFrame:trnframe]; + + [UIView commitAnimations]; +} + +- (void) setUpdate:(NSDate *)date { + [self update]; +} + +- (void) update { + [self dropBar]; [indicator_ startAnimation]; [prompt_ setText:UCLocalize("UPDATING_DATABASE")]; @@ -6262,22 +6363,7 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { [indicator_ stopAnimation]; - [UIView beginAnimations:nil context:NULL]; - - CGRect ovrframe = [overlay_ frame]; - ovrframe.origin.y = -ovrframe.size.height; - [overlay_ setFrame:ovrframe]; - - CGRect barframe = [navbar_ frame]; - barframe.origin.y -= ovrframe.size.height; - [navbar_ setFrame:barframe]; - - CGRect trnframe = [transition_ frame]; - trnframe.origin.y -= ovrframe.size.height; - trnframe.size.height += ovrframe.size.height; - [transition_ setFrame:trnframe]; - - [UIView commitAnimations]; + [self raiseBar]; [delegate_ performSelector:@selector(reloadData) withObject:nil afterDelay:0]; } @@ -7061,21 +7147,26 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { if (show) [animator performSelector:@selector(startAnimation:) withObject:animation afterDelay:delay]; - [delegate_ showKeyboard:show]; + //[delegate_ showKeyboard:show]; } - (void) textFieldDidBecomeFirstResponder:(UITextField *)field { [self _showKeyboard:YES]; + [table_ setObject:[field_ text] forFilter:@selector(isUnfilteredAndSelectedForBy:)]; + [self reloadData]; } - (void) textFieldDidResignFirstResponder:(UITextField *)field { [self _showKeyboard:NO]; + [table_ setObject:[field_ text] forFilter:@selector(isUnfilteredAndSearchedForBy:)]; + [self reloadData]; } - (void) keyboardInputChanged:(UIFieldEditor *)editor { if (reload_) { NSString *text([field_ text]); [field_ setClearButtonStyle:(text == nil || [text length] == 0 ? 0 : 2)]; + [table_ setObject:text forFilter:@selector(isUnfilteredAndSelectedForBy:)]; [self reloadData]; reload_ = false; } @@ -7161,7 +7252,6 @@ bool DepSubstrate(const pkgCache::VerIterator &iterator) { } - (void) reloadData { - [table_ setObject:[field_ text]]; _profile(SearchView$reloadData) [table_ reloadData]; _end @@ -7468,6 +7558,10 @@ static _finline void _setHomePage(Cydia *self) { @implementation Cydia +- (UIView *) rotatingContentViewForWindow:(UIWindow *)window { + return window_; +} + - (void) _loaded { if ([broken_ count] != 0) { int count = [broken_ count]; @@ -7595,13 +7689,15 @@ static _finline void _setHomePage(Cydia *self) { else { loaded = true; - if (NSDate *update = [Metadata_ objectForKey:@"LastUpdate"]) { + NSDate *update([Metadata_ objectForKey:@"LastUpdate"]); + + if (update != nil) { NSTimeInterval interval([update timeIntervalSinceNow]); if (interval <= 0 && interval > -(15*60)) goto loaded; } - [book_ update]; + [book_ setUpdate:update]; } } @@ -7777,6 +7873,27 @@ static _finline void _setHomePage(Cydia *self) { return sections_; } +- (ChangesView *) changesView { + if (changes_ == nil) + changes_ = [[ChangesView alloc] initWithBook:book_ database:database_]; + return changes_; +} + +- (ManageView *) manageView { + if (manage_ == nil) + manage_ = (ManageView *) [[self + _pageForURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] pathForResource:@"manage" ofType:@"html"]] + withClass:[ManageView class] + ] retain]; + return manage_; +} + +- (SearchView *) searchView { + if (search_ == nil) + search_ = [[SearchView alloc] initWithBook:book_ database:database_]; + return search_; +} + - (void) buttonBarItemTapped:(id)sender { unsigned tag = [sender tag]; if (tag == tag_) { @@ -7789,9 +7906,9 @@ static _finline void _setHomePage(Cydia *self) { case 1: _setHomePage(self); break; case 2: [self setPage:[self sectionsView]]; break; - case 3: [self setPage:changes_]; break; - case 4: [self setPage:manage_]; break; - case 5: [self setPage:search_]; break; + case 3: [self setPage:[self changesView]]; break; + case 4: [self setPage:[self manageView]]; break; + case 5: [self setPage:[self searchView]]; break; _nodefault } @@ -8091,6 +8208,8 @@ static _finline void _setHomePage(Cydia *self) { [window_ orderFront:self]; [window_ makeKey:self]; [window_ setHidden:NO]; + //[window_ setAutorotates:YES]; + //[window_ setDelegate:self]; database_ = [Database sharedInstance]; @@ -8229,24 +8348,15 @@ static _finline void _setHomePage(Cydia *self) { [overlay_ addSubview:toolbar_]; [UIKeyboard initImplementationNow]; - CGSize keysize = [UIKeyboard defaultSize]; + /*CGSize keysize = [UIKeyboard defaultSize]; CGRect keyrect = {{0, [overlay_ bounds].size.height}, keysize}; keyboard_ = [[UIKeyboard alloc] initWithFrame:keyrect]; - [overlay_ addSubview:keyboard_]; + [overlay_ addSubview:keyboard_];*/ [underlay_ addSubview:overlay_]; [self reloadData]; - [self sectionsView]; - changes_ = [[ChangesView alloc] initWithBook:book_ database:database_]; - search_ = [[SearchView alloc] initWithBook:book_ database:database_]; - - manage_ = (ManageView *) [[self - _pageForURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] pathForResource:@"manage" ofType:@"html"]] - withClass:[ManageView class] - ] retain]; - #if RecyclePackageViews details_ = [[NSMutableArray alloc] initWithCapacity:4]; [details_ addObject:[self _packageView]]; @@ -8315,6 +8425,12 @@ MSHook(void, UIWebDocumentView$_setUIKitDelegate$, UIWebDocumentView *self, SEL int main(int argc, char *argv[]) { _pooled _trace(); + if (Class $UIDevice = objc_getClass("UIDevice")) { + UIDevice *device([$UIDevice currentDevice]); + IsWildcat_ = [device respondsToSelector:@selector(isWildcat)] && [device isWildcat]; + } else + IsWildcat_ = false; + PackageName = reinterpret_cast(method_getImplementation(class_getInstanceMethod([Package class], @selector(cyname)))); /* Library Hacks {{{ */ @@ -8488,15 +8604,19 @@ int main(int argc, char *argv[]) { _pooled Finishes_ = [NSArray arrayWithObjects:@"return", @"reopen", @"restart", @"reload", @"reboot", nil]; + if (substrate && access("/Library/MobileSubstrate/DynamicLibraries/SimulatedKeyEvents.dylib", F_OK) == 0) + dlopen("/Library/MobileSubstrate/DynamicLibraries/SimulatedKeyEvents.dylib", RTLD_LAZY | RTLD_GLOBAL); if (substrate && access("/Applications/WinterBoard.app/WinterBoard.dylib", F_OK) == 0) dlopen("/Applications/WinterBoard.app/WinterBoard.dylib", RTLD_LAZY | RTLD_GLOBAL); /*if (substrate && access("/Library/MobileSubstrate/MobileSubstrate.dylib", F_OK) == 0) dlopen("/Library/MobileSubstrate/MobileSubstrate.dylib", RTLD_LAZY | RTLD_GLOBAL);*/ + int version([[NSString stringWithContentsOfFile:@"/var/lib/cydia/firmware.ver"] intValue]); + if (access("/tmp/.cydia.fw", F_OK) == 0) { unlink("/tmp/.cydia.fw"); goto firmware; - } else if (access("/User", F_OK) != 0) { + } else if (access("/User", F_OK) != 0 || version < 1) { firmware: _trace(); system("/usr/libexec/cydia/firmware.sh"); diff --git a/Library/firmware.sh b/Library/firmware.sh index e91eef34..bb5c228b 100755 --- a/Library/firmware.sh +++ b/Library/firmware.sh @@ -1,5 +1,7 @@ #!/bin/bash + set -e +shopt -s extglob version=$(sw_vers -productVersion) @@ -14,7 +16,7 @@ while IFS= read -r line; do unset blank fi - if [[ ${line} == 'Package: firmware' ]]; then + if [[ ${line} == "Package: "@(firmware|gsc.*) ]]; then firmware= elif [[ ${line} == '' ]]; then blank= @@ -43,20 +45,47 @@ Status: install ok installed Priority: required Section: System Installed-Size: 0 -Maintainer: Jay Freeman (saurik) Architecture: iphoneos-arm Version: ${version} Description: almost impressive Apple frameworks Name: iPhone Firmware +Tag: role::cydia + +EOF + +echo "/." >/var/lib/dpkg/info/firmware.list + +gssc 2>&1 | sed -re ' + /^ [^ ]* = [0-9.]*;$/ ! d; + s/^ ([^ ]*) = ([0-9.]*);$/\1 \2/; + s/([A-Z])/-\L\1/g; s/^"([^ ]*)"/\1/; + s/^-//; + / 0$/ d; +' | while read -r name value; do + +cat </var/lib/dpkg/info/gsc."${name}".list + +done + } >/var/lib/dpkg/status_ mv -f /var/lib/dpkg/status{_,} -echo "/." >/var/lib/dpkg/info/firmware.list - if [[ ${version} = 1.0* || ${version} = 1.1.[012] ]]; then user=root else @@ -66,3 +95,5 @@ fi if [[ ! -h /User && -d /User ]]; then cp -afT /User /var/"${user}" fi && rm -rf /User && ln -s "/var/${user}" /User + +echo 1 >/var/lib/cydia/firmware.ver diff --git a/control b/control index 0266b87c..17c6856f 100644 --- a/control +++ b/control @@ -3,9 +3,9 @@ Priority: required Section: Packaging Maintainer: Jay Freeman (saurik) Architecture: iphoneos-arm -Version: 1.0.3166-1 +Version: 1.0.3167-1 Replaces: com.sosiphone.addcydia -Depends: apr-lib, apt7-lib, apt7-key, darwintools, pcre, shell-cmds, system-cmds, uikittools +Depends: apr-lib, apt7-lib, apt7-key, darwintools, pcre, sed, shell-cmds, system-cmds, uikittools Pre-Depends: dpkg (>= 1.14.25-8) Conflicts: com.sosiphone.addcydia Description: graphical iPhone front-end for APT -- 2.45.2