1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2024-11-27 18:23:09 +02:00

Add some more comments on the feeds script, use parameters in functions

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@5985 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
florian 2007-01-05 15:28:52 +00:00
parent 67562874eb
commit b8a41d9b79

View File

@ -4,15 +4,17 @@
# This is free software, licensed under the GNU General Public License v2. # This is free software, licensed under the GNU General Public License v2.
# See /LICENSE for more information. # See /LICENSE for more information.
# #
# Usage : $1 -> source feeds # Usage : $1 -> source feeds, space separated
# $2 -> other options # $2 -> other options (not used yet)
# #
# Note : we do not yet resolve package name conflicts # Note : we do not yet resolve package name conflicts
# #
#
# Directories
FEEDS_DIR=$TOPDIR/feeds FEEDS_DIR=$TOPDIR/feeds
PACKAGE_DIR=$TOPDIR/package PACKAGE_DIR=$TOPDIR/package
# We work in the TOPDIR as defined in the caller Makefile
cd $TOPDIR cd $TOPDIR
# This directory will be structured this way : feeds/feed-name # This directory will be structured this way : feeds/feed-name
[ -d $FEEDS_DIR ] || mkdir -p $FEEDS_DIR [ -d $FEEDS_DIR ] || mkdir -p $FEEDS_DIR
@ -20,23 +22,24 @@ cd $TOPDIR
# Some functions we might call several times a run # Some functions we might call several times a run
delete_symlinks() { delete_symlinks() {
find $PACKAGE_DIR -type l | xargs rm -f find $1 -type l | xargs rm -f
} }
setup_symlinks() { setup_symlinks() {
# We assume that feeds do reproduce the hierarchy : section/package # We assume that feeds do reproduce the hierarchy : section/package
for dir in $(ls $FEEDS_DIR/) # so that we can make this structure be flat in $PACKAGE_DIR
for dir in $(ls $2/)
do do
ln -s $FEEDS_DIR/$dir/*/* $PACKAGE_DIR/ ln -s $2/$dir/*/* $1/
done done
} }
checkout_feed() { checkout_feed() {
# We ensure the feed has not already been checkout, if so, just update the source feed # We ensure the feed has not already been checked out, if so, we just update the source feed
if [ -d $FEEDS_DIR/$2 ]; then if [ -d $FEEDS_DIR/$2 ]; then
svn update $FEEDS_DIR/$2 svn update $FEEDS_DIR/$2
echo "Updated to revision $(LANG=C svn info $FEEDS_DIR/$2 | awk '/^Revision:/ { print $2 }' )"; echo "Updated to revision $(LANG=C svn info $FEEDS_DIR/$2 | awk '/^Revision:/ { print $2 }' )";
# Otherwise, we have to checkout in the # Otherwise, we have to checkout in the $FEEDS_DIR
else else
svn co $1 $FEEDS_DIR/$2 svn co $1 $FEEDS_DIR/$2
echo "Checked out revision $(LANG=C svn info $FEEDS_DIR/$2 | awk '/^Revision:/ { print $2 }' )"; echo "Checked out revision $(LANG=C svn info $FEEDS_DIR/$2 | awk '/^Revision:/ { print $2 }' )";
@ -44,11 +47,12 @@ checkout_feed() {
} }
extract_feed_name() { extract_feed_name() {
# We extract the last name of the URL, maybe we should rename this as domain.tld.repository.name
echo "$(echo $1 | awk -F/ '{ print $NF}')" echo "$(echo $1 | awk -F/ '{ print $NF}')"
} }
# We can delete symlinks every time we start this script, since modifications have been made anyway # We can delete symlinks every time we start this script, since modifications have been made in the $FEEDS_DIR anyway
delete_symlinks "" delete_symlinks "$PACKAGE_DIR"
# Now let's checkout feeds # Now let's checkout feeds
for feed in $1 for feed in $1
do do
@ -56,4 +60,4 @@ do
checkout_feed "$feed" "$name" checkout_feed "$feed" "$name"
done done
# Finally setup symlinks # Finally setup symlinks
setup_symlinks "" setup_symlinks "$FEEDS_DIR" "$PACKAGE_DIR"