mirror of
git://git.psyced.org/git/psyced
synced 2024-08-15 03:25:10 +00:00
psyconf: look also in /usr/local/sbin
This commit is contained in:
parent
19aab6b349
commit
0df57a4445
1 changed files with 39 additions and 43 deletions
82
bin/psyconf
82
bin/psyconf
|
@ -121,35 +121,37 @@ sub say {
|
||||||
unless -x $base;
|
unless -x $base;
|
||||||
my $sandbox = "$base/world";
|
my $sandbox = "$base/world";
|
||||||
die "psyced library $sandbox does not exist" unless -x $sandbox;
|
die "psyced library $sandbox does not exist" unless -x $sandbox;
|
||||||
my $arch = "$base/bin-$_type_architecture";
|
my $execs = "$base/bin-$_type_architecture";
|
||||||
my $config = $c{_basic_path_configuration} || $base;
|
my $config = $c{_basic_path_configuration} || $base;
|
||||||
# this isn't taking $ARCH_DIR from install.sh into account
|
# this isn't taking $ARCH_DIR from install.sh into account
|
||||||
# but maybe it shouldn't anyway..
|
# but maybe it shouldn't anyway..
|
||||||
say "Looking for driver in $arch/$driver\n";
|
say "Looking for driver in $execs/$driver\n";
|
||||||
unless (-x $arch && -x "$arch/$driver") {
|
unless (-x $execs && -x "$execs/$driver") {
|
||||||
$arch = "$base/bin-$_type_system";
|
$execs = "$base/bin-$_type_system";
|
||||||
say "Looking for driver in $arch/$driver\n";
|
say "Looking for driver in $execs/$driver\n";
|
||||||
unless (-x $arch && -x "$arch/$driver") {
|
unless (-x $execs && -x "$execs/$driver") {
|
||||||
$arch = "$base/bin-linux";
|
$execs = "$base/bin-linux";
|
||||||
say "Looking for driver in $arch/$driver\n";
|
say "Looking for driver in $execs/$driver\n";
|
||||||
if (-x $arch && -x "$arch/$driver") {
|
unless (-x $execs && -x "$execs/$driver") {
|
||||||
say "\nBug in $0: We didn't find $base/bin-linux in the appropriate way.\nThat's not nice. Continuing however.\n"
|
$execs = "$base/bin";
|
||||||
} elsif (not -x ($arch = "$base/bin") && -x "$arch/$driver") {
|
say "Looking for driver in $execs/$driver\n";
|
||||||
say "Looking for driver in $arch/$driver\n";
|
unless (-x $execs && -x "$execs/$driver") {
|
||||||
# bad place for psyclpc really..
|
$execs = "/usr/local/sbin";
|
||||||
# since it is usually of no commandline use
|
say "Looking for driver in $execs/$driver\n";
|
||||||
# but where else should psyclpc.ebuild
|
unless (-x $execs && -x "$execs/$driver") {
|
||||||
# install it? in /opt/psyclpc? for two files?
|
$execs = "/usr/sbin";
|
||||||
$arch = "/usr/sbin";
|
say "Looking for driver in $execs/$driver\n";
|
||||||
say "Looking for driver in $arch/$driver\n";
|
die <<X unless -x $execs && -x "$execs/$driver";
|
||||||
# the following is very unlikely to happen:
|
|
||||||
die <<X unless -x $arch && -x "$arch/$driver";
|
|
||||||
Could not find any directory containing $driver.
|
Could not find any directory containing $driver.
|
||||||
X
|
X
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
say "Found driver in $arch/$driver\n";
|
}
|
||||||
|
}
|
||||||
|
say "Found driver in $execs/$driver\n";
|
||||||
|
# is it really that hard?
|
||||||
|
die "but $execs/erq is missing\n" unless -x "$execs/erq";
|
||||||
|
|
||||||
my $user = $c{_basic_system_user} || 'daemon';
|
my $user = $c{_basic_system_user} || 'daemon';
|
||||||
my ($login,$pass,$uid,$gid) = getpwnam($user)
|
my ($login,$pass,$uid,$gid) = getpwnam($user)
|
||||||
|
@ -345,7 +347,7 @@ X
|
||||||
open O, '>', $t or die "Cannot write to $t";
|
open O, '>', $t or die "Cannot write to $t";
|
||||||
|
|
||||||
my $db = $c{_optional_level_debug} || '0';
|
my $db = $c{_optional_level_debug} || '0';
|
||||||
my $psyced = "$arch/$driver -DDEBUG=$db";
|
my $psyced = "$execs/$driver -DDEBUG=$db";
|
||||||
my $debugfile;
|
my $debugfile;
|
||||||
|
|
||||||
if ( $c{_optional_use_file_debug} ) {
|
if ( $c{_optional_use_file_debug} ) {
|
||||||
|
@ -454,18 +456,12 @@ if test "\$1" = "-u"
|
||||||
then
|
then
|
||||||
if test -e $sandbox/status-0-beta-OK
|
if test -e $sandbox/status-0-beta-OK
|
||||||
then
|
then
|
||||||
# echo "automated update functionality no longer available. try"
|
|
||||||
# echo "'git fetch origin', optionally 'git diff master..origin/master'"
|
|
||||||
# echo "and finally 'git merge -s resolve origin' instead"
|
|
||||||
# exit 1
|
|
||||||
# echo "${hi}ATTENTION: ${lo}Please give an empty password to log in (-> press enter)"
|
|
||||||
## (cd $base && cvs login && cvs -q update -dP && cvs logout)
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "Fetching update from public git repository..."
|
echo "Fetching update from public git repository..."
|
||||||
echo ""
|
echo ""
|
||||||
(cd $base && git fetch origin)
|
git fetch origin
|
||||||
echo ""
|
echo ""
|
||||||
echo "You can now read the changes using ${hi}\$0 -d${lo}"
|
echo "You can now look at the changes using ${hi}\$0 -d${lo}"
|
||||||
echo "or activate the changes using ${hi}\$0 -m${lo}"
|
echo "or activate the changes using ${hi}\$0 -m${lo}"
|
||||||
fi
|
fi
|
||||||
if ! test -e $sandbox/status-0-beta-OK
|
if ! test -e $sandbox/status-0-beta-OK
|
||||||
|
@ -482,34 +478,34 @@ then
|
||||||
echo "The file you just saw is: ${hi}${lib}/status-0-DEPRECATED${lo}."
|
echo "The file you just saw is: ${hi}${lib}/status-0-DEPRECATED${lo}."
|
||||||
exit 1
|
exit 1
|
||||||
else
|
else
|
||||||
echo "It may be a good idea to run ${hi}\$0${lo} again before you continue."
|
# this \$0 is for psyconf, not for psyced.. don't escape it
|
||||||
|
echo ""
|
||||||
|
echo "It may be a good idea to run ${hi}$0${lo} again before you continue."
|
||||||
fi
|
fi
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "\$1" = "-d"
|
if test "\$1" = "-d"
|
||||||
then
|
then
|
||||||
## (cd $base && cvs -q diff -ur HEAD|\$PAGER)
|
## cvs -q diff -ur HEAD|\$PAGER
|
||||||
(cd $base && git diff master..origin/master | \$PAGER)
|
git diff master..origin/master | \$PAGER
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "\$1" = "-m"
|
if test "\$1" = "-m"
|
||||||
then
|
then
|
||||||
# # git is seriously unsuited for this job. we need to "check in" the changes
|
git stash save 'changes stashed automatically by psyced -m'
|
||||||
# # to file permissions etc or otherwise we can't update things at all...
|
git merge -s resolve origin
|
||||||
# (cd $base && git commit -a -m 'automatic by psyced -m')
|
# restore local changes?
|
||||||
# stash local changes
|
# git stash apply
|
||||||
(cd $base && git stash)
|
echo ""
|
||||||
# merging will of course fail.. sigh
|
echo "If you had local changes to your files you can now restore them using"
|
||||||
(cd $base && git merge -s resolve origin)
|
echo "${hi}git stash apply${lo}"
|
||||||
# restore local changes
|
|
||||||
(cd $base && git stash apply)
|
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if your ldmud is too old, it may not understand --pidfile and --tls-*
|
# if your ldmud is too old, it may not understand --pidfile and --tls-*
|
||||||
commandline="$psyced -s 0 -s v0 --swap-file $base/psyced.swap --erq $arch/erq --pidfile $sandbox/data/$driver.pid -m $sandbox -u $portUDP $ports"
|
commandline="$psyced -s 0 -s v0 --swap-file $base/psyced.swap --erq $execs/erq --pidfile $sandbox/data/$driver.pid -m $sandbox -u $portUDP $ports"
|
||||||
|
|
||||||
# keep the pid of this wrapper process, too
|
# keep the pid of this wrapper process, too
|
||||||
echo \$\$ >data/psyced.pid
|
echo \$\$ >data/psyced.pid
|
||||||
|
|
Loading…
Reference in a new issue