mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2024-11-27 18:23:09 +02:00
Add an 'Image Configuration' menu to menuconfig
Packages can export a list of config options with labels and data types through the metadata. The selected config values will be exported to the target filesystem in /etc/uci-defaults and applied on the first boot. git-svn-id: svn://svn.openwrt.org/openwrt/trunk@6572 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
11817df895
commit
a1aed6ae61
@ -6,7 +6,11 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
ifneq ($(DUMP),)
|
ifneq ($(DUMP),)
|
||||||
define Dumpinfo
|
define Config
|
||||||
|
preconfig_$$(1) += echo "Preconfig: $(1)"; echo "Preconfig-Type: $(2)"; echo "Preconfig-Default: $(3)"; echo "Preconfig-Label: $(4)";
|
||||||
|
endef
|
||||||
|
|
||||||
|
define Dumpinfo
|
||||||
dumpinfo: dumpinfo-$(1)
|
dumpinfo: dumpinfo-$(1)
|
||||||
dumpinfo-$(1): FORCE
|
dumpinfo-$(1): FORCE
|
||||||
@echo "Package: $(1)" ; \
|
@echo "Package: $(1)" ; \
|
||||||
@ -28,5 +32,6 @@ define Dumpinfo
|
|||||||
$(if $(URL),echo;echo "$(URL)";) \
|
$(if $(URL),echo;echo "$(URL)";) \
|
||||||
echo "@@" ; \
|
echo "@@" ; \
|
||||||
$$(if $$(Package/$(1)/config),echo "Config: "; getvar $(call shvar,Package/$(1)/config); echo "@@")
|
$$(if $$(Package/$(1)/config),echo "Config: "; getvar $(call shvar,Package/$(1)/config); echo "@@")
|
||||||
|
$(if $$(preconfig_$(1)),@$$(preconfig_$(1)) echo "")
|
||||||
endef
|
endef
|
||||||
endif
|
endif
|
||||||
|
@ -54,12 +54,14 @@ define BuildIPKG
|
|||||||
done; \
|
done; \
|
||||||
echo "Depends: $$$$DEPENDS" >> $$(IDIR_$(1))/CONTROL/control; \
|
echo "Depends: $$$$DEPENDS" >> $$(IDIR_$(1))/CONTROL/control; \
|
||||||
)
|
)
|
||||||
echo "Source: $(SOURCE)" >> $$(IDIR_$(1))/CONTROL/control
|
( \
|
||||||
echo "Section: $(SECTION)" >> $$(IDIR_$(1))/CONTROL/control
|
echo "Source: $(SOURCE)"; \
|
||||||
echo "Priority: $(PRIORITY)" >> $$(IDIR_$(1))/CONTROL/control
|
echo "Section: $(SECTION)"; \
|
||||||
echo "Maintainer: $(MAINTAINER)" >> $$(IDIR_$(1))/CONTROL/control
|
echo "Priority: $(PRIORITY)"; \
|
||||||
echo "Architecture: $(PKGARCH)" >> $$(IDIR_$(1))/CONTROL/control
|
echo "Maintainer: $(MAINTAINER)"; \
|
||||||
echo "Description: $(DESCRIPTION)" | sed -e 's,\\,\n,g' | sed -e 's,^[[:space:]]*$$$$, .,g' >> $$(IDIR_$(1))/CONTROL/control
|
echo "Architecture: $(PKGARCH)"; \
|
||||||
|
echo -n "Description: "; getvar $(call shvar,Package/$(1)/description) | sed -e 's,^[[:space:]]*, ,g'; \
|
||||||
|
) >> $$(IDIR_$(1))/CONTROL/control
|
||||||
chmod 644 $$(IDIR_$(1))/CONTROL/control
|
chmod 644 $$(IDIR_$(1))/CONTROL/control
|
||||||
(cd $$(IDIR_$(1))/CONTROL; \
|
(cd $$(IDIR_$(1))/CONTROL; \
|
||||||
$($(1)_COMMANDS) \
|
$($(1)_COMMANDS) \
|
||||||
|
@ -8,9 +8,12 @@
|
|||||||
|
|
||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
include $(TOPDIR)/.config
|
include $(TOPDIR)/.config
|
||||||
include $(TMP_DIR)/.pkgdeps
|
|
||||||
include $(INCLUDE_DIR)/host.mk
|
include $(INCLUDE_DIR)/host.mk
|
||||||
|
|
||||||
|
all: compile
|
||||||
|
|
||||||
|
include $(TMP_DIR)/.pkgdeps
|
||||||
|
|
||||||
PREREQ_PACKAGES:=$(patsubst %,%-prereq,$(prereq-y) $(prereq-m))
|
PREREQ_PACKAGES:=$(patsubst %,%-prereq,$(prereq-y) $(prereq-m))
|
||||||
DOWNLOAD_PACKAGES:=$(patsubst %,%-download,$(package-y) $(package-m))
|
DOWNLOAD_PACKAGES:=$(patsubst %,%-download,$(package-y) $(package-m))
|
||||||
COMPILE_PACKAGES:=$(patsubst %,%-compile,$(package-y) $(package-m))
|
COMPILE_PACKAGES:=$(patsubst %,%-compile,$(package-y) $(package-m))
|
||||||
@ -29,9 +32,9 @@ GENDEP_OPTS := -s
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
$(TMP_DIR)/.pkgdeps: $(TMP_DIR)/.pkginfo
|
$(TMP_DIR)/.pkgdeps: $(TMP_DIR)/.pkginfo
|
||||||
@$(TOPDIR)/scripts/gen_deps.pl $(GENDEP_OPTS) < $< > $@ || rm -f $@
|
@$(TOPDIR)/scripts/metadata.pl package_mk $(GENDEP_OPTS) < $< > $@ || rm -f $@
|
||||||
|
|
||||||
all: compile
|
preconfig:
|
||||||
clean: $(patsubst %,%-clean,$(package-) $(package-y) $(package-m))
|
clean: $(patsubst %,%-clean,$(package-) $(package-y) $(package-m))
|
||||||
prereq: $(PREREQ_PACKAGES)
|
prereq: $(PREREQ_PACKAGES)
|
||||||
download: $(DOWNLOAD_PACKAGES)
|
download: $(DOWNLOAD_PACKAGES)
|
||||||
@ -41,6 +44,7 @@ install-targets: $(INSTALL_PACKAGES)
|
|||||||
install:
|
install:
|
||||||
rm -rf $(BUILD_DIR)/root
|
rm -rf $(BUILD_DIR)/root
|
||||||
$(MAKE) install-targets
|
$(MAKE) install-targets
|
||||||
|
$(MAKE) preconfig
|
||||||
@if [ -d $(TOPDIR)/files ]; then \
|
@if [ -d $(TOPDIR)/files ]; then \
|
||||||
$(CP) $(TOPDIR)/files/. $(BUILD_DIR)/root; \
|
$(CP) $(TOPDIR)/files/. $(BUILD_DIR)/root; \
|
||||||
fi
|
fi
|
||||||
@ -49,7 +53,7 @@ install:
|
|||||||
for script in ./etc/init.d/*; do \
|
for script in ./etc/init.d/*; do \
|
||||||
grep '#!/bin/sh /etc/rc.common' $$script >/dev/null || continue; \
|
grep '#!/bin/sh /etc/rc.common' $$script >/dev/null || continue; \
|
||||||
IPKG_INSTROOT=$(BUILD_DIR)/root $(which bash) ./etc/rc.common $$script enable; \
|
IPKG_INSTROOT=$(BUILD_DIR)/root $(which bash) ./etc/rc.common $$script enable; \
|
||||||
done; \
|
done || true \
|
||||||
)
|
)
|
||||||
|
|
||||||
index: $(PACKAGE_DIR)/Packages
|
index: $(PACKAGE_DIR)/Packages
|
||||||
|
@ -47,7 +47,7 @@ do_set() {
|
|||||||
local VALUE
|
local VALUE
|
||||||
|
|
||||||
strtok "$1" PACKAGE . CONFIG = VALUE
|
strtok "$1" PACKAGE . CONFIG = VALUE
|
||||||
[ $? -ne 3 ] && {
|
[ $? -ne 3 -a $? -ne 2 ] && {
|
||||||
uci_usage set
|
uci_usage set
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
@ -86,6 +86,7 @@ do_remove() {
|
|||||||
do_commit() {
|
do_commit() {
|
||||||
local PACKAGE="$1"
|
local PACKAGE="$1"
|
||||||
for package in ${PACKAGE:-$(cd /tmp/.uci; ls)}; do
|
for package in ${PACKAGE:-$(cd /tmp/.uci; ls)}; do
|
||||||
|
[ "${package##.*}" != "$package" ] && continue # ignore .lock files
|
||||||
uci_commit "$package"
|
uci_commit "$package"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
9
package/base-files/files/etc/init.d/config
Executable file
9
package/base-files/files/etc/init.d/config
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/sh /etc/rc.common
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
|
||||||
|
START=15
|
||||||
|
|
||||||
|
start() {
|
||||||
|
include /lib/config
|
||||||
|
uci_apply_defaults
|
||||||
|
}
|
@ -28,6 +28,17 @@ uci_load() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uci_apply_defaults() {(
|
||||||
|
cd /etc/uci-defaults || return 0
|
||||||
|
files="$(ls)"
|
||||||
|
[ -z "$files" ] && return 0
|
||||||
|
mkdir -p /tmp/.uci
|
||||||
|
for file in $files; do
|
||||||
|
( . "./$(basename $file)" ) && rm -f "$file"
|
||||||
|
done
|
||||||
|
uci commit
|
||||||
|
)}
|
||||||
|
|
||||||
uci_do_update() {
|
uci_do_update() {
|
||||||
local FILENAME="$1"
|
local FILENAME="$1"
|
||||||
local UPDATE="$2"
|
local UPDATE="$2"
|
||||||
|
@ -1,101 +0,0 @@
|
|||||||
#!/usr/bin/perl
|
|
||||||
#
|
|
||||||
# Copyright (C) 2006 OpenWrt.org
|
|
||||||
#
|
|
||||||
# This is free software, licensed under the GNU General Public License v2.
|
|
||||||
# See /LICENSE for more information.
|
|
||||||
#
|
|
||||||
|
|
||||||
use strict;
|
|
||||||
|
|
||||||
my $name;
|
|
||||||
my $src;
|
|
||||||
my $makefile;
|
|
||||||
my %conf;
|
|
||||||
my %pkg;
|
|
||||||
my %prereq;
|
|
||||||
my %dep;
|
|
||||||
my %options;
|
|
||||||
my $opt;
|
|
||||||
|
|
||||||
while ($opt = shift @ARGV) {
|
|
||||||
$opt =~ /^-s/ and $options{SDK} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
my $line;
|
|
||||||
while ($line = <>) {
|
|
||||||
chomp $line;
|
|
||||||
$line =~ /^Source-Makefile: \s*(.+\/([^\/]+)\/Makefile)\s*$/ and do {
|
|
||||||
$makefile = $1;
|
|
||||||
$src = $2;
|
|
||||||
defined $pkg{$src} or $pkg{$src} = {};
|
|
||||||
$pkg{$src}->{src} = $src;
|
|
||||||
};
|
|
||||||
$line =~ /^Package: \s*(.+)\s*$/ and do {
|
|
||||||
$name = $1;
|
|
||||||
defined $pkg{$name} or $pkg{$name} = {};
|
|
||||||
$pkg{$name}->{src} = $src;
|
|
||||||
};
|
|
||||||
$line =~ /^Provides: \s*(.+)\s*$/ and do {
|
|
||||||
foreach my $vpkg (split /\s+/, $1) {
|
|
||||||
defined $pkg{$vpkg} or $pkg{$vpkg} = {};
|
|
||||||
$pkg{$vpkg}->{virtual} = 1;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
$line =~ /^Prereq-Check:/ and !defined $prereq{$src} and do {
|
|
||||||
$pkg{$name}->{prereq} = 1;
|
|
||||||
};
|
|
||||||
$line =~ /^(Build-)?Depends: \s*(.+)\s*$/ and do {
|
|
||||||
$pkg{$name}->{depends} ||= [];
|
|
||||||
foreach my $v (split /\s+/, $2) {
|
|
||||||
next if $v =~ /^[\+]?@/;
|
|
||||||
$v =~ s/^\+//;
|
|
||||||
push @{$pkg{$name}->{depends}}, $v;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
$line="";
|
|
||||||
|
|
||||||
foreach $name (sort {uc($a) cmp uc($b)} keys %pkg) {
|
|
||||||
my $config;
|
|
||||||
|
|
||||||
next if defined $pkg{$name}->{virtual};
|
|
||||||
if ($options{SDK}) {
|
|
||||||
$conf{$pkg{$name}->{src}} or do {
|
|
||||||
$config = 'm';
|
|
||||||
$conf{$pkg{$name}->{src}} = 1;
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
$config = "\$(CONFIG_PACKAGE_$name)"
|
|
||||||
}
|
|
||||||
if ($config) {
|
|
||||||
print "package-$config += $pkg{$name}->{src}\n";
|
|
||||||
$pkg{$name}->{prereq} and print "prereq-$config += $pkg{$name}->{src}\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
my $hasdeps = 0;
|
|
||||||
my $depline = "";
|
|
||||||
foreach my $dep (@{$pkg{$name}->{depends}}) {
|
|
||||||
my $idx;
|
|
||||||
next if defined $pkg{$dep}->{virtual};
|
|
||||||
if (defined $pkg{$dep}->{src}) {
|
|
||||||
($pkg{$name}->{src} ne $pkg{$dep}->{src}) and $idx = $pkg{$dep}->{src};
|
|
||||||
} elsif (defined($pkg{$dep}) && !$options{SDK}) {
|
|
||||||
$idx = $dep;
|
|
||||||
}
|
|
||||||
undef $idx if $idx =~ /^(kernel)|(base-files)$/;
|
|
||||||
if ($idx) {
|
|
||||||
next if $dep{$pkg{$name}->{src}."->".$idx};
|
|
||||||
$depline .= " $idx\-compile";
|
|
||||||
$dep{$pkg{$name}->{src}."->".$idx} = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($depline ne "") {
|
|
||||||
$line .= "$pkg{$name}->{src}-compile: $depline\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($line ne "") {
|
|
||||||
print "\n$line";
|
|
||||||
}
|
|
@ -1,6 +1,8 @@
|
|||||||
#!/usr/bin/perl
|
#!/usr/bin/perl
|
||||||
use strict;
|
use strict;
|
||||||
|
my %preconfig;
|
||||||
my %package;
|
my %package;
|
||||||
|
my %srcpackage;
|
||||||
my %category;
|
my %category;
|
||||||
|
|
||||||
sub parse_target_metadata() {
|
sub parse_target_metadata() {
|
||||||
@ -70,21 +72,26 @@ sub parse_target_metadata() {
|
|||||||
sub parse_package_metadata() {
|
sub parse_package_metadata() {
|
||||||
my $pkg;
|
my $pkg;
|
||||||
my $makefile;
|
my $makefile;
|
||||||
|
my $preconfig;
|
||||||
my $src;
|
my $src;
|
||||||
while (<>) {
|
while (<>) {
|
||||||
chomp;
|
chomp;
|
||||||
/^Source-Makefile: \s*(.+\/([^\/]+)\/Makefile)\s*$/ and do {
|
/^Source-Makefile: \s*(.+\/([^\/]+)\/Makefile)\s*$/ and do {
|
||||||
$makefile = $1;
|
$makefile = $1;
|
||||||
$src = $2;
|
$src = $2;
|
||||||
|
$srcpackage{$src} = [];
|
||||||
undef $pkg;
|
undef $pkg;
|
||||||
};
|
};
|
||||||
/^Package: \s*(.+)\s*$/ and do {
|
/^Package:\s*(.+?)\s*$/ and do {
|
||||||
$pkg = {};
|
$pkg = {};
|
||||||
$pkg->{src} = $src;
|
$pkg->{src} = $src;
|
||||||
$pkg->{makefile} = $makefile;
|
$pkg->{makefile} = $makefile;
|
||||||
$pkg->{name} = $1;
|
$pkg->{name} = $1;
|
||||||
$pkg->{default} = "m if ALL";
|
$pkg->{default} = "m if ALL";
|
||||||
|
$pkg->{depends} = [];
|
||||||
|
$pkg->{builddepends} = [];
|
||||||
$package{$1} = $pkg;
|
$package{$1} = $pkg;
|
||||||
|
push @{$srcpackage{$src}}, $pkg;
|
||||||
};
|
};
|
||||||
/^Version: \s*(.+)\s*$/ and $pkg->{version} = $1;
|
/^Version: \s*(.+)\s*$/ and $pkg->{version} = $1;
|
||||||
/^Title: \s*(.+)\s*$/ and $pkg->{title} = $1;
|
/^Title: \s*(.+)\s*$/ and $pkg->{title} = $1;
|
||||||
@ -103,6 +110,10 @@ sub parse_package_metadata() {
|
|||||||
my @dep = split /\s+/, $1;
|
my @dep = split /\s+/, $1;
|
||||||
$pkg->{depends} = \@dep;
|
$pkg->{depends} = \@dep;
|
||||||
};
|
};
|
||||||
|
/^Build-Depends: \s*(.+)\s*$/ and do {
|
||||||
|
my @dep = split /\s+/, $1;
|
||||||
|
$pkg->{builddepends} = \@dep;
|
||||||
|
};
|
||||||
/^Category: \s*(.+)\s*$/ and do {
|
/^Category: \s*(.+)\s*$/ and do {
|
||||||
$pkg->{category} = $1;
|
$pkg->{category} = $1;
|
||||||
defined $category{$1} or $category{$1} = {};
|
defined $category{$1} or $category{$1} = {};
|
||||||
@ -126,7 +137,19 @@ sub parse_package_metadata() {
|
|||||||
$conf .= "$line";
|
$conf .= "$line";
|
||||||
}
|
}
|
||||||
$pkg->{config} = $conf;
|
$pkg->{config} = $conf;
|
||||||
}
|
};
|
||||||
|
/^Prereq-Check:/ and $pkg->{prereq} = 1;
|
||||||
|
/^Preconfig:\s*(.+)\s*$/ and do {
|
||||||
|
my $pkgname = $pkg->{name};
|
||||||
|
$preconfig{$pkgname} or $preconfig{$pkgname} = [];
|
||||||
|
$preconfig = {
|
||||||
|
id => $1
|
||||||
|
};
|
||||||
|
push @{$preconfig{$pkgname}}, $preconfig;
|
||||||
|
};
|
||||||
|
/^Preconfig-Type:\s*(.*?)\s*$/ and $preconfig->{type} = $1;
|
||||||
|
/^Preconfig-Label:\s*(.*?)\s*$/ and $preconfig->{label} = $1;
|
||||||
|
/^Preconfig-Default:\s*(.*?)\s*$/ and $preconfig->{default} = $1;
|
||||||
}
|
}
|
||||||
return %category;
|
return %category;
|
||||||
}
|
}
|
||||||
@ -450,23 +473,117 @@ sub print_package_config_category($) {
|
|||||||
|
|
||||||
sub gen_package_config() {
|
sub gen_package_config() {
|
||||||
parse_package_metadata();
|
parse_package_metadata();
|
||||||
|
print "menu \"Image configuration\"\n";
|
||||||
|
foreach my $preconfig (keys %preconfig) {
|
||||||
|
print "\tcomment \"$preconfig\"\n";
|
||||||
|
foreach my $cfg (@{$preconfig{$preconfig}}) {
|
||||||
|
my $conf = $cfg->{id};
|
||||||
|
$conf =~ tr/\.-/__/;
|
||||||
|
print <<EOF
|
||||||
|
config UCI_PRECONFIG_$conf
|
||||||
|
string "$cfg->{label}"
|
||||||
|
depends PACKAGE_$preconfig
|
||||||
|
default "$cfg->{default}"
|
||||||
|
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
}
|
||||||
|
print "endmenu\n\n";
|
||||||
print_package_config_category 'Base system';
|
print_package_config_category 'Base system';
|
||||||
foreach my $cat (keys %category) {
|
foreach my $cat (keys %category) {
|
||||||
print_package_config_category $cat;
|
print_package_config_category $cat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub gen_package_mk() {
|
||||||
|
my %conf;
|
||||||
|
my %dep;
|
||||||
|
my $line;
|
||||||
|
|
||||||
|
parse_package_metadata();
|
||||||
|
foreach my $name (sort {uc($a) cmp uc($b)} keys %package) {
|
||||||
|
my $config;
|
||||||
|
my $pkg = $package{$name};
|
||||||
|
|
||||||
|
next if defined $pkg->{vdepends};
|
||||||
|
if ($ENV{SDK}) {
|
||||||
|
$conf{$pkg->{src}} or do {
|
||||||
|
$config = 'm';
|
||||||
|
$conf{$pkg->{src}} = 1;
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
$config = "\$(CONFIG_PACKAGE_$name)"
|
||||||
|
}
|
||||||
|
if ($config) {
|
||||||
|
print "package-$config += $pkg->{src}\n";
|
||||||
|
$pkg->{prereq} and print "prereq-$config += $pkg->{src}\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $hasdeps = 0;
|
||||||
|
my $depline = "";
|
||||||
|
foreach my $dep (@{$pkg->{depends}}, @{$pkg->{builddepends}}) {
|
||||||
|
next if $dep =~ /@/;
|
||||||
|
$dep =~ s/\+//;
|
||||||
|
my $idx;
|
||||||
|
my $pkg_dep = $package{$dep};
|
||||||
|
$pkg_dep or $pkg_dep = $srcpackage{$dep}->[0];
|
||||||
|
next unless defined $pkg_dep;
|
||||||
|
next if defined $pkg_dep->{vdepends};
|
||||||
|
|
||||||
|
if (defined $pkg_dep->{src}) {
|
||||||
|
($pkg->{src} ne $pkg_dep->{src}) and $idx = $pkg_dep->{src};
|
||||||
|
} elsif (defined($pkg_dep) && !defined($ENV{SDK})) {
|
||||||
|
$idx = $dep;
|
||||||
|
}
|
||||||
|
undef $idx if $idx =~ /^(kernel)|(base-files)$/;
|
||||||
|
if ($idx) {
|
||||||
|
next if $dep{$pkg->{src}."->".$idx};
|
||||||
|
$depline .= " $idx\-compile";
|
||||||
|
$dep{$pkg->{src}."->".$idx} = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($depline) {
|
||||||
|
$line .= "$pkg->{src}-compile: $depline\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($line ne "") {
|
||||||
|
print "\n$line";
|
||||||
|
}
|
||||||
|
foreach my $preconfig (keys %preconfig) {
|
||||||
|
my $cmds;
|
||||||
|
foreach my $cfg (@{$preconfig{$preconfig}}) {
|
||||||
|
my $conf = $cfg->{id};
|
||||||
|
$conf =~ tr/\.-/__/;
|
||||||
|
$cmds .= "\techo \"uci set '$cfg->{id}=\$(subst \",,\$(CONFIG_UCI_PRECONFIG_$conf))'\"; \\\n";
|
||||||
|
}
|
||||||
|
next unless $cmds;
|
||||||
|
print <<EOF
|
||||||
|
|
||||||
|
\$(TARGET_DIR)/etc/uci-defaults/$preconfig: FORCE
|
||||||
|
( \\
|
||||||
|
$cmds \\
|
||||||
|
) > \$@
|
||||||
|
|
||||||
|
preconfig: \$(TARGET_DIR)/etc/uci-defaults/$preconfig
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
sub parse_command() {
|
sub parse_command() {
|
||||||
my $cmd = shift @ARGV;
|
my $cmd = shift @ARGV;
|
||||||
for ($cmd) {
|
for ($cmd) {
|
||||||
/^target_mk$/ and return gen_target_mk();
|
/^target_mk$/ and return gen_target_mk();
|
||||||
/^target_config$/ and return gen_target_config();
|
/^target_config$/ and return gen_target_config();
|
||||||
|
/^package_mk$/ and return gen_package_mk();
|
||||||
/^package_config$/ and return gen_package_config();
|
/^package_config$/ and return gen_package_config();
|
||||||
}
|
}
|
||||||
print <<EOF
|
print <<EOF
|
||||||
Available Commands:
|
Available Commands:
|
||||||
$0 target_mk [file] Target metadata in makefile format
|
$0 target_mk [file] Target metadata in makefile format
|
||||||
$0 target_config [file] Target metadata in Kconfig format
|
$0 target_config [file] Target metadata in Kconfig format
|
||||||
|
$0 package_mk [file] Package metadata in makefile format
|
||||||
$0 package_config [file] Package metadata in Kconfig format
|
$0 package_config [file] Package metadata in Kconfig format
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,9 @@ export TOPDIR
|
|||||||
DEVELOPER=1
|
DEVELOPER=1
|
||||||
export DEVELOPER
|
export DEVELOPER
|
||||||
|
|
||||||
|
SDK=1
|
||||||
|
export SDK
|
||||||
|
|
||||||
all: world
|
all: world
|
||||||
|
|
||||||
.pkginfo: FORCE
|
.pkginfo: FORCE
|
||||||
|
Loading…
Reference in New Issue
Block a user