From c8a8ed15c7b8d31cbdc24c981dfbb36d42a87fa8 Mon Sep 17 00:00:00 2001 From: Yejiang Luo Date: Mon, 31 May 2021 14:28:54 +0800 Subject: [PATCH] scripts: update feed script gen_config.py requires the latest version of the feeds script. Signed-off-by: Yejiang Luo --- openwrt-18.06/scripts/feeds | 142 ++++++++++++++++++++++++++++++++++++++------ 1 file changed, 123 insertions(+), 19 deletions(-) diff --git a/openwrt-18.06/scripts/feeds b/openwrt-18.06/scripts/feeds index 304ef6c..46c5f5c 100755 --- a/openwrt-18.06/scripts/feeds +++ b/openwrt-18.06/scripts/feeds @@ -41,34 +41,56 @@ my $feed_src = {}; my $feed_target = {}; my $feed_vpackage = {}; -sub parse_config() { +sub parse_file($$); + +sub parse_file($$) { + my ($fname, $existing) = @_; my $line = 0; - my %name; + my $fh; - open FEEDS, "feeds.conf" or - open FEEDS, "feeds.conf.default" or - die "Unable to open feeds configuration"; - while () { + open $fh, $fname or return undef; + while (<$fh>) { chomp; s/#.+$//; - next unless /\S/; - my @line = split /\s+/, $_, 3; - my @src; $line++; + next unless /\S/; + + my ($type, $flags, $name, $urls) = m!^src-([\w\-]+)((?:\s+--\w+(?:=\S+)?)*)\s+(\w+)(?:\s+(\S.*))?$!; + unless ($type && $name) { + die "Syntax error in $fname, line $line\n"; + } - my $valid = 1; - $line[0] =~ /^src-[\w-]+$/ or $valid = 0; - $line[1] =~ /^\w+$/ or $valid = 0; - @src = split /\s+/, ($line[2] or ''); - @src = ('') if @src == 0; - $valid or die "Syntax error in feeds.conf, line: $line\n"; + if ($existing->{$name}++) { + die "Duplicate feed name '$name' in '$fname' line: $line\n"; + } - $name{$line[1]} and die "Duplicate feed name '$line[1]', line: $line\n"; - $name{$line[1]} = 1; + my @src = defined($urls) ? split /\s+/, $urls : (); + push @src, '' if @src == 0; - push @feeds, [$line[0], $line[1], \@src]; + my %flags; + if (defined $flags) { + while ($flags =~ m!\s+--(\w+)(?:=(\S+))?!g) { + $flags{$1} = defined($2) ? $2 : 1; + } + } + + if ($type eq "include") { + parse_file($urls, $existing) or + die "Unable to open included file '$urls'"; + next; + } + + push @feeds, ["src-$type", $name, \@src, \%flags]; } - close FEEDS; + close $fh; + return 1; +} + +sub parse_config() { + my %name; + parse_file("feeds.conf", \%name) or + parse_file("feeds.conf.default", \%name) or + die "Unable to open feeds configuration"; } sub update_location($$) @@ -506,6 +528,11 @@ sub install_src { get_feed($feed->[1]); my $src = $feed_src->{$name} or return 1; + # enable force flag if feed src line was declared with --force + if (exists($feed->[3]{force})) { + $force = 1; + } + # If it's a core package and we don't want to override, just return my $override = 0; if (is_core_src($name)) { @@ -617,6 +644,35 @@ sub refresh_config { } } +sub install_profiles { + my $feed = shift; + my $dir = sprintf('feeds/%s/', $feed->[1]); + + -d "./feeds/profiles" or mkdir "./feeds/profiles" or return 1; + + opendir (DIR, $dir) or return 0; + while (my $file = readdir(DIR)) { + next unless (-f "$dir/$file"); + next unless ($file =~ m/\.profile$/); + -e "./feeds/profiles/$file" or system("ln -s ../$feed->[1]/$file ./feeds/profiles/"); + } + closedir(DIR); +} + +sub install_dl { + my $feed = shift; + my $dir = sprintf('feeds/%s/dl/', $feed->[1]); + + -d "./dl" or mkdir "./dl" or return 1; + + opendir (DIR, $dir) or return 0; + while (my $file = readdir(DIR)) { + next unless (-f "$dir/$file"); + -e "./dl/$file" or system("ln -s ../feeds/$feed->[1]/dl/$file ./dl/"); + } + closedir(DIR); +} + sub install { my $name; my %opts; @@ -649,6 +705,8 @@ sub install { install_src($feed, $name, exists($opts{f})) == 0 or $ret = 1; get_feed($f->[1]); } + install_profiles($f); + install_dl($f); } } } else { @@ -819,6 +877,47 @@ sub update { return $failed; } +sub setup { + my %opts; + + getopts('bh', \%opts); + + if ($opts{h}) { + usage(); + return 0; + } + + if (-e "feeds.conf") { + warn "The file feeds.conf already exists.\n"; + return 1; + } + + open(my $fd, ">>feeds.conf"); + + if ($opts{b}) { + printf $fd "src-include defaults feeds.conf.default\n"; + } + + while (my $entry = shift @ARGV) { + my ($type, $name, $src) = split /,/, $entry; + + $update_method{$type} or do { + warn "Unknown type '$type' in parameter $entry\n"; + unlink "feeds.conf"; + return 1; + }; + + if ($name =~ /[\s-]/) { + warn "Feed names or sources may not contain whitespace or - characters in parameter $entry\n"; + unlink "feeds.conf"; + return 1; + } + printf $fd "%s %s %s\n", $type, $name, $src; + } + + return 0; +} + sub feed_config() { foreach my $feed (@feeds) { my $installed = (-f "feeds/$feed->[1].index"); @@ -870,6 +969,10 @@ Commands: -i : Recreate the index only. No feed update from repository is performed. -f : Force updating feeds even if there are changed, uncommitted files. + setup [options] ...: generate feeds.conf + Options: + -b : Use feeds.conf.default as base for new feeds.conf. + clean: Remove downloaded/generated files. EOF @@ -883,6 +986,7 @@ my %commands = ( 'search' => \&search, 'uninstall' => \&uninstall, 'feed_config' => \&feed_config, + 'setup' => \&setup, 'clean' => sub { system("rm -rf ./feeds ./package/feeds"); } -- 2.7.4