Compare commits
4 Commits
8dd5e34e4d
...
bf419bfd98
Author | SHA1 | Date | |
---|---|---|---|
bf419bfd98 | |||
7f1b122a53 | |||
fd8f96a54d | |||
b8611eb590 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,3 +1,4 @@
|
|||||||
/backup
|
/backup
|
||||||
/home_internal
|
/home_internal
|
||||||
/root_internal
|
/root_internal
|
||||||
|
output.txt
|
||||||
|
@ -204,7 +204,7 @@ ex ()
|
|||||||
}
|
}
|
||||||
|
|
||||||
# BEGIN_KITTY_SHELL_INTEGRATION
|
# BEGIN_KITTY_SHELL_INTEGRATION
|
||||||
if [[ -n "$KITTY_INSTALLATION_DIR" -a -e "$KITTY_INSTALLATION_DIR/shell-integration/bash/kitty.bash" ]]; then
|
if [[ -n "$KITTY_INSTALLATION_DIR" && -e "$KITTY_INSTALLATION_DIR/shell-integration/bash/kitty.bash" ]]; then
|
||||||
source "$KITTY_INSTALLATION_DIR/shell-integration/bash/kitty.bash";
|
source "$KITTY_INSTALLATION_DIR/shell-integration/bash/kitty.bash";
|
||||||
fi
|
fi
|
||||||
# END_KITTY_SHELL_INTEGRATION
|
# END_KITTY_SHELL_INTEGRATION
|
||||||
|
File diff suppressed because one or more lines are too long
65
scripts/sync_general.sh
Normal file
65
scripts/sync_general.sh
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
shopt -s expand_aliases
|
||||||
|
source /sync/home_internal/.bash_aliases # FSCLEANUP -> zum besseren testen
|
||||||
|
# source /sync/home_external/.bash_aliases
|
||||||
|
|
||||||
|
|
||||||
|
sync () {
|
||||||
|
dry_run=false
|
||||||
|
home_or_root=
|
||||||
|
update=true
|
||||||
|
in_to_ex=
|
||||||
|
while [[ $# > 0 ]]; do
|
||||||
|
case $1 in
|
||||||
|
-d | --dry ) dry_run=true; shift;;
|
||||||
|
-c | --checksum ) update=false; shift;;
|
||||||
|
--in-to-ex ) in_to_ex=true; shift;;
|
||||||
|
--ex-to-in ) in_to_ex=false; shift;;
|
||||||
|
--dir ) home_or_root=$2; shift 2;;
|
||||||
|
* ) break ;; # Anything else stops command line processing.
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
dir_external=/sync/${home_or_root}_external/
|
||||||
|
dir_internal=/sync/${home_or_root}_internal/
|
||||||
|
# dry-run
|
||||||
|
if [[ "$dry_run" == true ]]; then
|
||||||
|
ex_to_in=
|
||||||
|
in_to_ex=
|
||||||
|
update_or_default=
|
||||||
|
if [[ "$update" == true ]]; then
|
||||||
|
update_or_default='UPDATE'
|
||||||
|
ex_to_in=$(rsync_update $dir_external $dir_internal --dry-run)
|
||||||
|
in_to_ex=$(rsync_update $dir_internal $dir_external --dry-run)
|
||||||
|
else
|
||||||
|
update_or_default='DEFAULT'
|
||||||
|
ex_to_in=$(rsync_default $dir_external $dir_internal --dry-run)
|
||||||
|
in_to_ex=$(rsync_default $dir_internal $dir_external --dry-run)
|
||||||
|
fi
|
||||||
|
# use printf for displaying \n as newline correctly
|
||||||
|
printf "RSYNC ${update_or_default}: external -> internal:\n\n$ex_to_in\n\nRSYNC ${update_or_default}: internal -> external:\n\n$in_to_ex\n"
|
||||||
|
exit 0;
|
||||||
|
fi
|
||||||
|
|
||||||
|
# real deal
|
||||||
|
if [[ -z "$in_to_ex" ]]; then
|
||||||
|
echo "Error. No sync direction given."
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$update" == true ]]; then
|
||||||
|
if [[ "$in_to_ex" == true ]]; then
|
||||||
|
rsync_update $dir_internal $dir_external
|
||||||
|
else
|
||||||
|
rsync_update $dir_external $dir_internal
|
||||||
|
fi
|
||||||
|
exit 0;
|
||||||
|
fi
|
||||||
|
if [[ "$in_to_ex" == true ]]; then
|
||||||
|
rsync_default $dir_internal $dir_external
|
||||||
|
else
|
||||||
|
rsync_default $dir_external $dir_internal
|
||||||
|
fi
|
||||||
|
}
|
6
scripts/sync_home.sh
Executable file
6
scripts/sync_home.sh
Executable file
@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
source /sync/scripts/sync_general.sh
|
||||||
|
|
||||||
|
sync --dir home $@
|
6
scripts/sync_root.sh
Executable file
6
scripts/sync_root.sh
Executable file
@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
source /sync/scripts/sync_general.sh
|
||||||
|
|
||||||
|
sync --dir root $@
|
Loading…
Reference in New Issue
Block a user