-darcsget()
-{
- case $* in
- *--partial*) ;;
- *) echo "warning: adding --partial, to override use --complete"
- esac
-
- repo_root=`cat _darcs/prefs/defaultrepo`
- case $repo_root in
- /*) lib_repos=$repo_root/libraries;;
- *) lib_repos=$default_lib_repo_root;;
- esac
-
- cd libraries
-
- for pkg in `cat core-packages`; do
- if test -d $pkg; then
- echo "warning: $pkg already present; omitting"
- else
- repo=$lib_repos/$pkg
- message "== running darcs get --partial $* $repo"
- darcs get --partial $* $repo
- fi
- done
-
- if test "$extra" = "YES"; then
- for pkg in `cat extra-packages`; do
- if test -d $pkg; then
- echo "warning: $pkg already present; omitting"
- else
- repo=$default_extra_lib_repo_root/$pkg
- message "== running darcs get --partial $* $repo"
- darcs get --partial $* $repo
- fi
- done
- fi
+sub darcsgetpackage {
+ my ($get_it, $r_flags, $repo_root, $package) = @_;
+
+ if ($get_it) {
+ if (-d $package) {
+ warning("$package already present; omitting");
+ }
+ else {
+ darcs (@$r_flags, "$repo_root/$package");
+ }
+ }