summaryrefslogtreecommitdiff
path: root/rvs/plugins/filecontent/bin
diff options
context:
space:
mode:
Diffstat (limited to 'rvs/plugins/filecontent/bin')
-rw-r--r--rvs/plugins/filecontent/bin/commit.f.sh3
-rw-r--r--rvs/plugins/filecontent/bin/get.d.sh18
-rw-r--r--rvs/plugins/filecontent/bin/get.f.sh8
-rw-r--r--rvs/plugins/filecontent/bin/get.sh32
-rw-r--r--rvs/plugins/filecontent/bin/gettype.sh8
5 files changed, 49 insertions, 20 deletions
diff --git a/rvs/plugins/filecontent/bin/commit.f.sh b/rvs/plugins/filecontent/bin/commit.f.sh
index 726a7e3..17de155 100644
--- a/rvs/plugins/filecontent/bin/commit.f.sh
+++ b/rvs/plugins/filecontent/bin/commit.f.sh
@@ -25,7 +25,8 @@ file="${1?"$usage"}"
prefix="${2-f}"
hash=`sha1sum $file | sed "s/ .*$//"`
-if [ ! -f "$REPO/@ID@/$hash" ]; then
+if [ ! -f "$REPO/@ID@/$prefix/$hash" ]; then
+ mkdir -p "$REPO/@ID@/$prefix"
install -m 644 -o $USER -g $USER -T "$file" "$REPO/@ID@/$prefix/$hash"
fi
echo "$prefix/$hash"
diff --git a/rvs/plugins/filecontent/bin/get.d.sh b/rvs/plugins/filecontent/bin/get.d.sh
index 1723d8a..1a001d3 100644
--- a/rvs/plugins/filecontent/bin/get.d.sh
+++ b/rvs/plugins/filecontent/bin/get.d.sh
@@ -19,12 +19,12 @@ ver=0.9
#. "$LIBDIR/@ID@/stdio"
-# get.d ID DIRNAME
-id="$1"
-dir="$2"
+usage="usage: $RVS get.d DIRNAME ID"
+dir="${1?"$usage"}"
+ id="${2?"$usage"}"
tmp=`mktemp`
-"$RVS" get.f "$id" "$tmp"
+"$RVS" get.f "$tmp" "$id"
#install -d "$dir"
mkdir -p "$dir"
@@ -32,13 +32,9 @@ mkdir -p "$dir"
cd "$dir"
rm -rf ./*
while read line; do
- # GNU bash optimized version
- #hash=${line/#*:/}
- #name=${line/%:${hash}/}
- # POSIX version
- hash=`echo "$line" | sed 's/^.*://'`
- name=`echo "$line" | sed "s/:$hash$//"`
- "$RVS" get "$hash" "$name"
+ _id="`echo "$line" | sed 's/^.*://'`"
+ _name="`echo "$line" | sed 's@:'"$_id"'$@@'`"
+ "$RVS" get "$_name" "$_id"
done < "$tmp"
rm "$tmp"
diff --git a/rvs/plugins/filecontent/bin/get.f.sh b/rvs/plugins/filecontent/bin/get.f.sh
index c706931..b137911 100644
--- a/rvs/plugins/filecontent/bin/get.f.sh
+++ b/rvs/plugins/filecontent/bin/get.f.sh
@@ -19,9 +19,9 @@ ver=0.9
#. "$LIBDIR/@ID@/stdio"
-# get.f ID FILENAME
-id="$1"
-file="$2"
+usage="usage: $RVS get.f FILENAME ID"
+name="${1?"$usage"}"
+ id="${2?"$usage"}"
-install -T "$REPO/@ID@/$id" "$file"
+install -T "$REPO/@ID@/$id" "$name"
diff --git a/rvs/plugins/filecontent/bin/get.sh b/rvs/plugins/filecontent/bin/get.sh
new file mode 100644
index 0000000..d3f046c
--- /dev/null
+++ b/rvs/plugins/filecontent/bin/get.sh
@@ -0,0 +1,32 @@
+#!/bin/sh
+name='rvs filecontent get'
+ver=0.9
+# Copyright (C) 2009 Luke Shumaker
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation; either version 2 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; see the file COPYING.
+# If not, see <http://www.gnu.org/licenses>.
+
+#. "$LIBDIR/@ID@/stdio"
+
+usage="usage: $RVS get FILENAME ID"
+name="${1?"$usage"}"
+ id="${2?"$usage"}"
+
+file="$REPO/@ID@/$id"
+
+type="`echo $id | sed 's:/.*::'`"
+#hash="`echo $id | sed 's:.*/::'`"
+
+"$RVS" "get.$type" "$name" "$id"
+
diff --git a/rvs/plugins/filecontent/bin/gettype.sh b/rvs/plugins/filecontent/bin/gettype.sh
index 4592ee7..84eb9da 100644
--- a/rvs/plugins/filecontent/bin/gettype.sh
+++ b/rvs/plugins/filecontent/bin/gettype.sh
@@ -1,5 +1,5 @@
#!/bin/sh
-name='rvs filecontent gettype'
+name='rvs @ID@ gettype'
ver=0.9
# Copyright (C) 2009-2010 Luke Shumaker
#
@@ -23,17 +23,17 @@ usage="usage: $RVS gettype FILE"
file=${1?"$usage"}
if [ ! -e "$file" ]; then
- error "file \`$file' does not exist";
+ fatal "file \`$file' does not exist";
else
type=''
for check in "$ETCDIR/@ID@/"*; do
type=`"$check" "$file"`
if [ -n "$type" ]; then break; fi
done
- if [ -z "$type" ]; then
+ if [ -n "$type" ]; then
echo "$type"
else
- error "cannot handle file type of \`$file'"
+ fatal "cannot handle file type of \`$file'"
fi
fi