dropped the copying of customizations
[feisty_meow.git] / scripts / core / functions.sh
index 2fda6b3012d3f5d4c2ca978f7d84a68fc633ebc7..12cc77175b7a8f8c9b3cb4a9bde66e6df5ceb35c 100644 (file)
@@ -484,8 +484,10 @@ if [ -z "$skip_all" ]; then
     restore_terminal_title
   }
 
-  # copies a set of custom scripts into the proper location for feisty meow
-  # to merge their functions and aliases with the standard set.
+  # merges a set of custom scripts into the feisty meow environment.  can be
+  # passed a name to use as the custom scripts source folder (found on path
+  # $FEISTY_MEOW_SCRIPTS/customize/{name}), or it will try to guess the name
+  # by using the login name.
   function recustomize()
   {
     local custom_user="$1"; shift
@@ -515,50 +517,88 @@ we will skip recustomization, but these other customizations are available:
       return 1
     fi
 
-    # prevent permission foul-ups.
-    my_user="$USER"
-      # here we definitely want the effective user name (in USER), since
-      # we don't want, say, fred (as logname) to own all of root's loading
-      # dock stuff.
-    chown -R "$my_user:$my_user" \
-        "$FEISTY_MEOW_LOADING_DOCK"/* "$FEISTY_MEOW_GENERATED_STORE"/* 2>/dev/null
-    continue_on_error "chowning feisty meow generated directories to $my_user"
-
+#hmmm: begin old custom section...
+#hmmm: here is where it starts being wrong for a link due to current borked copy approach.
+##    # prevent permission foul-ups.
+##    my_user="$USER"
+##      # here we definitely want the effective user name (in USER), since
+##      # we don't want, say, fred (as logname) to own all of root's loading
+##      # dock stuff.
+###hmmm: argh, seems a bit heavyweight to do chowning here!
+##    chown -R "$my_user:$my_user" \
+##        "$FEISTY_MEOW_LOADING_DOCK"/* "$FEISTY_MEOW_GENERATED_STORE"/* 2>/dev/null
+##    continue_on_error "chowning feisty meow generated directories to $my_user"
+##
+##    regenerate >/dev/null
+##
+##    pushd "$FEISTY_MEOW_LOADING_DOCK/custom" &>/dev/null
+##    incongruous_files="$(bash "$FEISTY_MEOW_SCRIPTS/files/list_non_dupes.sh" "$FEISTY_MEOW_SCRIPTS/customize/$custom_user" "$FEISTY_MEOW_LOADING_DOCK/custom")"
+##
+##    local fail_message="\n
+##are the perl dependencies installed?  if you're on ubuntu or debian, try this:\n
+##    $(grep "apt.*perl" $FEISTY_MEOW_APEX/readme.txt)\n
+##or if you're on cygwin, then try this (if apt-cyg is available):\n
+##    $(grep "apt-cyg.*perl" $FEISTY_MEOW_APEX/readme.txt)\n";
+##
+##    #echo "the incongruous files list is: $incongruous_files"
+##    # disallow a single character result, since we get "*" as result when nothing exists yet.
+##    if [ ${#incongruous_files} -ge 2 ]; then
+##      log_feisty_meow_event "cleaning unknown older overrides..."
+##      perl "$FEISTY_MEOW_SCRIPTS/files/safedel.pl" $incongruous_files
+##      continue_on_error "running safedel.  $fail_message" 
+##    fi
+##    popd &>/dev/null
+##    log_feisty_meow_event "copying custom overrides for $custom_user"
+##    mkdir -p "$FEISTY_MEOW_LOADING_DOCK/custom" 2>/dev/null
+##    perl "$FEISTY_MEOW_SCRIPTS/text/cpdiff.pl" "$FEISTY_MEOW_SCRIPTS/customize/$custom_user" "$FEISTY_MEOW_LOADING_DOCK/custom"
+##    continue_on_error "running cpdiff.  $fail_message"
+##
+##    if [ -d "$FEISTY_MEOW_SCRIPTS/customize/$custom_user/scripts" ]; then
+##      log_feisty_meow_event "copying custom scripts for $custom_user"
+###hmmm: could save output to show if an error occurs.
+##      rsync -avz "$FEISTY_MEOW_SCRIPTS/customize/$custom_user/scripts" "$FEISTY_MEOW_LOADING_DOCK/custom/" &>/dev/null
+##      continue_on_error "copying customization scripts"
+##    fi
+##    regenerate
+##
+##    # prevent permission foul-ups, again.
+##    chown -R "$my_user:$my_user" \
+##        "$FEISTY_MEOW_LOADING_DOCK" "$FEISTY_MEOW_GENERATED_STORE" 2>/dev/null
+##    continue_on_error "once more chowning feisty meow generated directories to $my_user"
+#hmmm: begin old custom section.
+
+####
+
+#hmmm: begin new customization section...
+    # recreate the feisty meow loading dock.
     regenerate >/dev/null
-    pushd "$FEISTY_MEOW_LOADING_DOCK/custom" &>/dev/null
-    incongruous_files="$(bash "$FEISTY_MEOW_SCRIPTS/files/list_non_dupes.sh" "$FEISTY_MEOW_SCRIPTS/customize/$custom_user" "$FEISTY_MEOW_LOADING_DOCK/custom")"
-
-    local fail_message="\n
-are the perl dependencies installed?  if you're on ubuntu or debian, try this:\n
-    $(grep "apt.*perl" $FEISTY_MEOW_APEX/readme.txt)\n
-or if you're on cygwin, then try this (if apt-cyg is available):\n
-    $(grep "apt-cyg.*perl" $FEISTY_MEOW_APEX/readme.txt)\n";
-
-    #echo "the incongruous files list is: $incongruous_files"
-    # disallow a single character result, since we get "*" as result when nothing exists yet.
-    if [ ${#incongruous_files} -ge 2 ]; then
-      log_feisty_meow_event "cleaning unknown older overrides..."
-      perl "$FEISTY_MEOW_SCRIPTS/files/safedel.pl" $incongruous_files
-      continue_on_error "running safedel.  $fail_message" 
+
+    # jump into the loading dock and make our custom link.
+    pushd "$FEISTY_MEOW_LOADING_DOCK" &>/dev/null
+    if [ -h custom ]; then
+      # there's an existing link, so remove it.
+      \rm custom
+    fi
+    if [ -h custom -o -d custom -o -f custom ]; then
+      echo "
+Due to an over-abundance of caution, we are not going to remove an unexpected
+'custom' object in the file system.  This is located here:
+  $(pwd)
+"
+      ls -al .
+      return 1
     fi
+
+    # create the custom folder as a link to the customizations.
+    ln -s "$FEISTY_MEOW_SCRIPTS/customize/$custom_user" custom
+
     popd &>/dev/null
-    log_feisty_meow_event "copying custom overrides for $custom_user"
-    mkdir -p "$FEISTY_MEOW_LOADING_DOCK/custom" 2>/dev/null
-    perl "$FEISTY_MEOW_SCRIPTS/text/cpdiff.pl" "$FEISTY_MEOW_SCRIPTS/customize/$custom_user" "$FEISTY_MEOW_LOADING_DOCK/custom"
-    continue_on_error "running cpdiff.  $fail_message"
 
-    if [ -d "$FEISTY_MEOW_SCRIPTS/customize/$custom_user/scripts" ]; then
-      log_feisty_meow_event "copying custom scripts for $custom_user"
-#hmmm: could save output to show if an error occurs.
-      rsync -avz "$FEISTY_MEOW_SCRIPTS/customize/$custom_user/scripts" "$FEISTY_MEOW_LOADING_DOCK/custom/" &>/dev/null
-      continue_on_error "copying customization scripts"
-    fi
+    # now take into account all the customizations by regenerating the feisty meow environment.
     regenerate
+#hmmm: end new customization section.
 
-    # prevent permission foul-ups, again.
-    chown -R "$my_user:$my_user" \
-        "$FEISTY_MEOW_LOADING_DOCK" "$FEISTY_MEOW_GENERATED_STORE" 2>/dev/null
-    continue_on_error "once more chowning feisty meow generated directories to $my_user"
+####
 
     restore_terminal_title
   }
@@ -710,49 +750,6 @@ or if you're on cygwin, then try this (if apt-cyg is available):\n
     popd &>/dev/null
   }
 
-#  function spacem()
-#  {
-#    while [ $# -gt 0 ]; do
-#      arg="$1"; shift
-#      if [ ! -f "$arg" -a ! -d "$arg" ]; then
-#        echo "=> did not find a file or directory named '$arg'."
-#        continue
-#      fi
-#
-#      # first we will capture the output of the character replacement operation for reporting.
-#      # this is done first since some filenames can't be properly renamed in perl (e.g. if they
-#      # have pipe characters apparently).
-#      intermediate_name="$(bash "$FEISTY_MEOW_SCRIPTS/files/replace_spaces_with_underscores.sh" "$arg")"
-#      local saw_intermediate_result=0
-#      if [ -z "$intermediate_name" ]; then
-#        # make sure we report something, if there are no further name changes.
-#        intermediate_name="'$arg'"
-#      else 
-#        # now zap the first part of the name off (since original name isn't needed).
-#        intermediate_name="$(echo $intermediate_name | sed -e 's/.*=> //')"
-#        saw_intermediate_result=1
-#      fi
-#
-#      # first we rename the file to be lower case.
-#      actual_file="$(echo $intermediate_name | sed -e "s/'\([^']*\)'/\1/")"
-#      final_name="$(perl $FEISTY_MEOW_SCRIPTS/files/renlower.pl "$actual_file")"
-#      local saw_final_result=0
-#      if [ -z "$final_name" ]; then
-#        final_name="$intermediate_name"
-#      else
-#        final_name="$(echo $final_name | sed -e 's/.*=> //')"
-#        saw_final_result=1
-#      fi
-##echo intermed=$saw_intermediate_result 
-##echo final=$saw_final_result 
-#
-#      if [[ $saw_intermediate_result != 0 || $saw_final_result != 0 ]]; then
-#        # printout the combined operation results.
-#        echo "'$arg' => $final_name"
-#      fi
-#    done
-#  }
-
   ##############
 
 # new breed of definer functions goes here.  still in progress.
@@ -965,16 +962,22 @@ return 0
 
   ##############
 
-  # space 'em all fixes naming for all of the files of the appropriate types in the directories specified.
+  # space 'em all: fixes naming for all of the files of the appropriate types
+  # in the directories specified.
   function spacemall() {
     local -a dirs=("${@}")
-echo "dirs from params are: " "${dirs[@]}"
     if [ ${#dirs[@]} -eq 0 ]; then
-echo dirs had zero entries
       dirs=(.)
     fi
-echo "dirs are: " "${dirs[@]}"
-    find "${dirs[@]}" -follow -maxdepth 1 -mindepth 1 -type f \( $(echo pdf png jpg jpeg odt ods docx m4a mp3 eml html mov pptx xlsx zip | sed -e 's/\([a-z0-9][a-z0-9]*\)/-iname \"*.\1\" -o /g') -iname "*.txt" \) -exec bash "$FEISTY_MEOW_SCRIPTS/files/spacem.sh" "{}" \;
+
+    local charnfile="$(mktemp $TMP/zz_charn.XXXXXX)"
+    find "${dirs[@]}" -follow -maxdepth 1 -mindepth 1 -type f | \
+        grep -i \
+"docx\|eml\|html\|jpeg\|jpg\|m4a\|mov\|mp3\|ods\|odt\|pdf\|png\|pptx\|txt\|xlsx\|zip" | \
+        sed -e 's/^/"/' | sed -e 's/$/"/' | \
+        xargs bash "$FEISTY_MEOW_SCRIPTS/files/spacem.sh"
+    # drop the temp file now that we're done.
+    rm "$charnfile"
   }
 
   ##############