#####################################################
#
#(: "SMP" = 'snapmergepuppy'
#(: entered by GlenE77s, 220302-0800
#(: We have attached our BASH mod of the current GITHUB Save2Flash .
#(: Note: 'snapmergepuppy' is a "MERGE" not a true "COPY".
#(: Any pre-existing extraneous data in the saveDATA may remain.
#(: New data will be "MERGED" into the current saveDATA
#(: just as the name implies.
#(:
#(: quoted from system help:
#(: snapmergepuppy is -u, --update
#(: ... copy only when
#(: ... the SOURCE file is newer than the destination file
#(: ... or
#(: ... when the destination file is missing
#(:
#(:
#(: Note: 'snapmergepuppy' Error Message bug
#(: We have noticed that the original 'old' SMP appeared to 'drop'
#(: some system edit changes
#(: if the system was running multiple threads;
#(: ie, resulting edit changes did not appear in the saveDATA on reboot.
#(: We initiated the practice of always running 'save2flash' several times,
#(:
#(: We introduced several repetitions of the SMP call.
#(: We run our edited copy of "/usr/sbin/save2flash" as "rc.z_S2F.sh"
#(: in order to flush the RAM data to the saveDATA.
#(:
#(:----------------------------------------------------------------------
#(:# Now implemented this way in our version of "Save2Flash" code :
#(:# nice -n 19 snapmergepuppy /initrd/pup_ro1 /initrd/pup_rw
#(:#
#(:----------------------------------------------------------------------
#(: 1:
#(: this line in "rc.z_S2F.sh" ( our copy of "/usr/sbin/save2flash" )
#(: [ /usr/sbin/snapmergepuppy /initrd/pup_ro1 /initrd/pup_rw ]
#(: was changed to
#(: [ nice -n 19 snapmergepuppy /initrd/pup_ro1 /initrd/pup_rw ]
#(: in order to inhibit background system procesesses
#(: during the 'snapmergepuppy' run time.
#(:
#(:----------------------------------------------------------------------
#(: 2:
#(: We use GEANY for IDE , and Geany Execute for BASH terminal to test/debug.
#(: We observe the following 'non-fatal' error message
#(: displayed by the BASH terminal during a run on "save2flash" :
#(: "unary operator expected".
#(:
#(: /usr/sbin/snapmergepuppy generates 'non-fatal' error messages,
#(: associated with line # 169, and # 171 inside snapmergepuppy binary file,
#(: This error message can be observed from the terminal mode:
#(: "unary operator expected".
#(:
#(: 3:
#(: First run may have 25 messages.
#(: Second run may have 5 messages.
#(: Third run may have 1 message.
#(:
#(: With this special "save2flash" running 5+ repititions
#(: our edit changes now appear secured in the saveDATA on reboot.
#(:
#(: 4:
#(: Running "sync" before "snapmergepuppy"
#(: does not eliminate his error message.
#(:
#(: 5:
#(: When we enhanced the current 'new distro' '/usr/sbin/save2flash' ,
#(: with the following call:
#(: [ nice -n 19 snapmergepuppy ]
#(: We observed the same non-fatal error message.
#(: We managed this problem with the same repetition method.
#(: Five loops through "snapmergeuppy" appears to cure this problem.
#(:
#(: Similar error message exists in all 8 of our currently running Puppy OS
#(: if we run a raw "nice -n 19 snapmergepuppy" .
#(:
#(: With this special "save2flash" running 5+ repititions
#(: our edit changes now appear secured in the saveDATA on reboot.
#(:
#(:
#(: We have tracked this event through last 7 distros of UpupBB ( up to #29)
#(: and also in Tahr, Xenial, BionicBeaver, FocalFosso, etc.
#(:
#(: 6:
#(: We believe this involves system time requirements to complete system tasks,
#(: before "snapmergepuppy" runs.
#(:
#(: Anybody have a comment:
#(:
#####################################################