dropped the copying of customizations
[feisty_meow.git] / scripts / core / functions.sh
index 3b782a70d52b6f237fd67506fd9574d9e8828f74..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
   }