opt_dryrun = False
-def parseVer_1234(match):
+def parseVer_1234(match, filepath):
progname = match.group(1)
progversion = (int(match.group(2)) << 64) |\
(int(match.group(3)) << 48) |\
(int(match.group(5)) << 16)
return (progname, progversion)
-def parseVer_123(match):
+def parseVer_123(match, filepath):
progname = match.group(1)
try:
patchlevel = match.group(5)
patchlevel
return (progname, progversion)
-def parseVer_12(match):
+def parseVer_12(match, filepath):
progname = match.group(1)
try:
patchlevel = match.group(4)
patchlevel
return (progname, progversion)
-def parseVer_r(match):
+def parseVer_r(match, filepath):
progname = match.group(1)
progversion = (int(match.group(2)) << 64)
return (progname, progversion)
-def parseVer_ymd(match):
+def parseVer_ymd(match, filepath):
progname = match.group(1)
progversion = (int(match.group(2)) << 64) |\
(int(match.group(3)) << 48) |\
(int(match.group(4)) << 32)
return (progname, progversion)
+def parseVer_GIT(match, filepath):
+ progname = match.group(1)
+ st = os.stat(filepath)
+ progversion = int(st.st_mtime) << 64
+ return (progname, progversion)
+
extensions = (
".tar.gz",
".tar.bz2",
)
versionRegex = (
+ (re.compile(r"(.+)[-_]([0-9a-fA-F]{40,40})"), parseVer_GIT), # xxx-GIT_SHASUM
(re.compile(r"(.+)[-_](\d+)\.(\d+)\.(\d+)\.(\d+)"), parseVer_1234), # xxx-1.2.3.4
(re.compile(r"(.+)[-_](\d\d\d\d)-?(\d\d)-?(\d\d)"), parseVer_ymd), # xxx-YYYY-MM-DD
(re.compile(r"(.+)[-_](\d+)\.(\d+)\.(\d+)(\w?)"), parseVer_123), # xxx-1.2.3a
self.directory = directory
self.filename = filename
self.progname = ""
+ self.fileext = ""
for ext in extensions:
if filename.endswith(ext):
filename = filename[0:0-len(ext)]
+ self.fileext = ext
break
else:
print self.filename, "has an unknown file-extension"
for (regex, parseVersion) in versionRegex:
match = regex.match(filename)
if match:
- (self.progname, self.version) = parseVersion(match)
+ (self.progname, self.version) = parseVersion(
+ match, directory + "/" + filename + self.fileext)
break
else:
print self.filename, "has an unknown version pattern"
my @feeds;
my %build_packages;
my %installed;
+my %feed_cache;
+
+my $feed_package = {};
+my $feed_src = {};
sub parse_config() {
my $line = 0;
sub get_feed($) {
my $feed = shift;
- my $file = "./feeds/$feed.index";
- clear_packages();
+ if (!defined($feed_cache{$feed})) {
+ my $file = "./feeds/$feed.index";
- -f $file or do {
- print "Ignoring feed '$feed' - index missing\n";
- return;
- };
- parse_package_metadata($file) or return;
- return { %package };
+ clear_packages();
+ -f $file or do {
+ print "Ignoring feed '$feed' - index missing\n";
+ return;
+ };
+ parse_package_metadata($file) or return;
+ $feed_cache{$feed} = [ { %package }, { %srcpackage } ];
+ }
+
+ $feed_package = $feed_cache{$feed}->[0];
+ $feed_src = $feed_cache{$feed}->[1];
+ return $feed_cache{$feed}->[0];
}
sub get_installed() {
return unless @substr > 0;
get_feed($feed);
- foreach my $name (sort { lc($a) cmp lc($b) } keys %package) {
- my $pkg = $package{$name};
+ foreach my $name (sort { lc($a) cmp lc($b) } keys %$feed_package) {
+ my $pkg = $feed_package->{$name};
my $substr;
my $pkgmatch = 1;
my $feed = shift;
get_feed($feed);
- foreach my $name (sort { lc($a) cmp lc($b) } keys %package) {
- my $pkg = $package{$name};
+ foreach my $name (sort { lc($a) cmp lc($b) } keys %$feed_package) {
+ my $pkg = $feed_package->{$name};
next if $pkg->{vdepends};
if($pkg->{name}) {
printf "\%-32s\t\%s\n", $pkg->{name}, $pkg->{title};
$feed or do {
$installed{$name} and return 0;
# TODO: check if it's already installed within ./package directory
- $srcpackage{$name} or -d "./package/$name" or warn "WARNING: No feed for package '$name' found, maybe it's already part of the standard packages?\n";
+ $feed_src->{$name} or -d "./package/$name" or warn "WARNING: No feed for package '$name' found, maybe it's already part of the standard packages?\n";
return 0;
};
+ # switch to the metadata for the selected feed
+ get_feed($feed->[1]);
+
my $pkg = $feed{$feed->[1]}->{$name} or return 1;
$pkg->{name} or do {
$installed{$name} and return 0;
return 1;
};
- # install all dependencies
- foreach my $vpkg (@{$srcpackage{$src}}, $pkg) {
+ # install all dependencies referenced from the source package
+ foreach my $vpkg (@{$feed_src->{$src}}) {
foreach my $dep (@{$vpkg->{depends}}, @{$vpkg->{builddepends}}, @{$vpkg->{"builddepends/host"}}) {
next if $dep =~ /@/;
$dep =~ s/^\+//;
if (!defined($opts{p}) or $opts{p} eq $f->[1]) {
printf "Installing all packages from feed %s.\n", $f->[1];
get_feed($f->[1]);
- foreach my $name (sort { lc($a) cmp lc($b) } keys %package) {
- my $p = $package{$name};
+ foreach my $name (sort { lc($a) cmp lc($b) } keys %$feed_package) {
+ my $p = $feed_package->{$name};
next if $p->{vdepends};
if( $p->{name} ) {
install_package($feed, $p->{name}) == 0 or $ret = 1;
+ get_feed($f->[1]);
}
}
}
$pkg->{buildonly} and $config = "";
print "package-$config += $pkg->{subdir}$pkg->{src}\n";
if ($pkg->{variant}) {
+ if (!defined($done{$pkg->{src}})) {
+ print "\$(curdir)/$pkg->{subdir}$pkg->{src}/default-variant := $pkg->{variant}\n";
+ }
print "\$(curdir)/$pkg->{subdir}$pkg->{src}/variants += \$(if $config,$pkg->{variant})\n"
}
$pkg->{prereq} and print "prereq-$config += $pkg->{subdir}$pkg->{src}\n";
next unless $cmds;
print <<EOF
+ifndef DUMP_TARGET_DB
\$(TARGET_DIR)/etc/uci-defaults/$preconfig: FORCE
( \\
$cmds \\
ifneq (\$(IMAGEOPT)\$(CONFIG_IMAGEOPT),)
package/preconfig: \$(TARGET_DIR)/etc/uci-defaults/$preconfig
endif
+endif
+
EOF
}
}