=================================================================== RCS file: /cvs/palm/manage_pre/manage_pre,v retrieving revision 1.3 retrieving revision 1.7 diff -u -r1.3 -r1.7 --- palm/manage_pre/manage_pre 2009/08/20 22:38:37 1.3 +++ palm/manage_pre/manage_pre 2009/11/25 21:27:15 1.7 @@ -1,7 +1,7 @@ #!/bin/sh -# $Id: manage_pre,v 1.3 2009/08/20 21:38:37 andrew Exp $ +# $Id: manage_pre,v 1.7 2009/11/25 21:27:15 andrew Exp $ -local _pre_id='Palm, Pre, 0316' +local _pre_id='Palm, Pre, 0000' #local _pre_label='Pre' #local _ipod_label='iPod' local _mount_dir='/mnt/pre' @@ -29,14 +29,14 @@ find_pre() { local _dev=`dmesg | grep 'Palm, Pre' | tail -1 | cut -d' ' -f 1` if [ X"$_dev" == X"" ]; then - echo Pre not found! >&2 - exit 1 + echo Pre not found! >&2 + exit 1 fi local _id=`dmesg | grep "^$_dev at " | tail -1 | sed -e 's/.*.*$//'` if [ X"$_id" != X"$_pre_id" ]; then - echo "Pre [$_dev] not correct id [$_id]" >&2 - exit 2 + echo "Pre [$_dev] not correct id [$_id]" >&2 + exit 2 fi echo /dev/${_dev}i @@ -50,12 +50,12 @@ local _mounted=`is_mounted $_dev` if [ X"" != X"$_mounted" ]; then /bin/sync - /sbin/umount $_dev && echo Unmounted Pre + $SUDO /sbin/umount $_dev && echo Unmounted Pre else echo Not mounted fi - /bin/eject $_dev 2> /dev/null && echo Ejected Pre - rmdir $_mount_dir 2> /dev/null + $SUDO /bin/eject $_dev 2> /dev/null && echo Ejected Pre + $SUDO rmdir $_mount_dir 2> /dev/null } mount() { @@ -64,17 +64,18 @@ echo Already mounted: ${_mounted%% type*} return fi - mkdir -p $_mount_dir - chgrp users $_mount_dir - chmod g+w $_mount_dir - /sbin/mount $_dev $_mount_dir && echo Mounted Pre on $_mount_dir + $SUDO mkdir -p $_mount_dir + $SUDO chgrp users $_mount_dir + $SUDO chmod g+w $_mount_dir + $SUDO /sbin/mount $_dev $_mount_dir && echo Mounted Pre on $_mount_dir } synchronize() { local _mounted=`is_mounted $_dev` + local _did_mount="" if [ X"" == X"$_mounted" ]; then - echo Not mounted - return 1 + mount || exit 255 + _did_mount=1 fi echo Synchronizing Pre @@ -86,6 +87,10 @@ if [ -e /usr/local/bin/unison ]; then /usr/local/bin/unison $_unison_config -auto -batch -ui text + fi + + if [ ! -z "$_did_mount" ]; then + eject fi }