summaryrefslogtreecommitdiff
path: root/classes
diff options
context:
space:
mode:
authorBruno Randolf <br1@subnet.at>2004-12-20 18:51:21 +0000
committerBruno Randolf <br1@subnet.at>2004-12-20 18:51:21 +0000
commit0d266125a7b21f393afdd9dfb8375ede7671dbe4 (patch)
tree2a988dd32894d4fef05fa6dd173ab6f8b7a0687e /classes
parent8030efaa44d23deb74e1b475d477d64ba982c3ba (diff)
Merge http://oe-devel@oe-devel.bkbits.net/openembedded
into null.(none):/data/mtx/oe/openembedded 2004/12/20 19:50:50+01:00 (none)!br1 add cvsdate to nylon scripts & co 2004/12/20 19:49:59+01:00 (none)!br1 pkg_distribute: exclude SCCS directories BKrev: 41c71f29ho5gzr6iqCq8yVYs6u8s9Q
Diffstat (limited to 'classes')
-rw-r--r--classes/pkg_distribute.bbclass29
1 files changed, 29 insertions, 0 deletions
diff --git a/classes/pkg_distribute.bbclass b/classes/pkg_distribute.bbclass
index e69de29bb2..81978e3e3b 100644
--- a/classes/pkg_distribute.bbclass
+++ b/classes/pkg_distribute.bbclass
@@ -0,0 +1,29 @@
+PKG_DISTRIBUTECOMMAND[func] = "1"
+python do_distribute_packages () {
+ cmd = bb.data.getVar('PKG_DISTRIBUTECOMMAND', d, 1)
+ if not cmd:
+ raise bb.build.FuncFailed("Unable to distribute packages, PKG_DISTRIBUTECOMMAND not defined")
+ bb.build.exec_func('PKG_DISTRIBUTECOMMAND', d)
+}
+
+addtask distribute_packages before do_build after do_fetch
+
+PKG_DIST_LOCAL ?= "symlink"
+PKG_DISTRIBUTEDIR ?= "${DEPLOY_DIR}/packages"
+
+PKG_DISTRIBUTECOMMAND () {
+ p=`dirname ${FILE}`
+ d=`basename $p`
+ mkdir -p ${PKG_DISTRIBUTEDIR}
+ case "${PKG_DIST_LOCAL}" in
+ copy)
+ # use this weird tar command to copy because we want to
+ # exclude the BitKeeper directories
+ test -e ${PKG_DISTRIBUTEDIR}/${d} || mkdir ${PKG_DISTRIBUTEDIR}/${d};
+ (cd ${p}; tar -c --exclude SCCS -f - . ) | tar -C ${PKG_DISTRIBUTEDIR}/${d} -xpf -
+ ;;
+ symlink)
+ ln -sf $p ${PKG_DISTRIBUTEDIR}/
+ ;;
+ esac
+}