shell scripting topic
-
So again - I'm looking forward in v1.7
two versions- Mausberry shutdown script without inotify
- Mausberry shutdown script with inotify
I would like to emphasize the difference between versions this way:
- Shutdown script checking for a change in that file every single second.
- Shutdown script that does nothing until that file changes.
:-)
-
-
@meleu
I pushed the mausberry shutdown script to 1.55 - all kudos to you.
But I want to avoid different usecased. Because some use 1.5 now.
So I think it doesn't matter if there is a v1.7 with better coding style or a v1.55 with more if-then clauses.
All contain your genoius RegEx sniplet that will work in all cases! I hope it is okay for you. In the sake for the best user experience we can give. -
@cyperghost said in shell scripting topic:
I hope it is okay for you.
C'mon man! Every line of code I post in this forum can be considered public domain. ;-)
Use it the way you want!
-
@meleu okay PD-meleu
-
@cyperghost said in Mausberry Shutdown Script Doesn't Save Metadata:
I think so, but I'm pretty sure that your solution (ScummVM fix) is already in usage by @hansolo77
Your posted script is still using this:
emupid="$(pgrep -f "${emupid%% *}")"
Which gets only
bash
on ScumVM case. Maybe you want to change it to v1.56 and useemupid="$(pgrep -f "$emupid")"
-
@meleu Thx my friend
-
@meleu About the inotify thing.
Do you have any clue why the GPIO signal is not detected? At first it works only if you have root access - but I'm pretty sure you already know. As far as I looked to v 1.6 of your code it should work without any problem.If there are any issues you can try to use GPIO control
If you watch Pin26 for a switch via GPIO control just place file
26
(without .sh!) to/etc/gpio-scripts/
and give theecho 1
> command in this file.26
#!/bin/bash #this is the GPIO pin connected to the lead on switch labeled OUT GPIOpin1=23 echo "1" > /sys/class/gpio/gpio$GPIOpin1/value
-
@cyperghost said in shell scripting topic:
@meleu About the inotify thing.
Do you have any clue why the GPIO signal is not detected?it's pretty hard to test things without the respective thing! :-)
I've made some tests with @lostless (I was giving instructions via IRC) and he was able to turn off his raspi with
echo 1 > /sys...
, but not with the switch pressing.Then I'm pretty sure that my method works as expected, but there's something in the Mausberry switch that I'm not able to diagnose...
-
@meleu I also have no clue why the thing won't catch up.
I tried to loadinotifywait
throug rc.local and it worked.
As I changed the monitored file I get a note and the process inotifywait finished.I've made some tests with @lostless (I was giving instructions via IRC) and he was able to turn off his raspi with echo 1 > /sys..., but not with the switch pressing.
It would be interesting to see what is happening internal through the GPIO if you press a button. Maybe it's better do use an more "advanced" bibliothek like wiring pi. Because with wPi you can detect flanks. But that's the suggestion I made by using an driver to detect keypresses.
-
@cyperghost Just to share some bash coding knowledge, I would like to make some comments about your bash coding philosophy :)
- the bash scripting language is an interpreted programming language
- if you google about "compiled vs intepreted language" and you realize that interpreted languaged tends to be slower.
- type
man bash
on your terminal, go the end of the bash man page and look at the first sentence in the BUGS section. ;-)
Why is @meleu trying to convince me that bash is slow if he loves bash?
Well, I love bash because it is widely used. If it wasn't for that I would have migrated to zsh (which is even more powerfull), but let's not go deep into this nerdy stuff...
I'm talking all those things because of your very good practice of checking if everything is really fine before running a command. In other languages, if you don't do these checkings, the program may crash. But when coding bash scripts (or any other shell language) it's a better yet practice to take advantage of every chance you have to optimize things.
I'm talking specifically for this part:
if [[ -e "/dev/shm/runcommand.info" ]]; then emupid="$(sed -n 4p /dev/shm/runcommand.info | tr -d '\\"' | tr '^$[]*.()|+?{}' '.')" emupid="$(pgrep -f "$emupid")" fi if [ "$emupid" ]; then kill $emupid && sleep 9 fi
You're making bash check if the
runcommand.info
exists, butsed
already does that.
You're getting the emulator's PID withpgrep
, butpkill
won't kill anything if there isn't a process matching the pattern.That's why I would change all the logic above with this here:
emupid="$(sed -n 4p /dev/shm/runcommand.info | tr -d '\\"' | tr '^$[]*.()|+?{}' '.')" [[ -n "$emu_command" ]] && pkill -f "${emupid}" && sleep 9
That's it. :-)
Cheers.
-
@meleu Me after reading that whole post
-
@lilbud this topic was created exactly to avoid this reaction on other people's topics. :-)
-
@lilbud You're welcome to ask and post things affecting bash :)
-
@cyperghost OK, I have very little experience with code and zero experience with bash.
Where in the hell do I start?
-
@lilbud at prompt. Type
echo "Hello World"
. ;-) -
@meleu So...
echo
is like a print command? -
@lilbud
You start withcd ~ touch hello.sh && chmod +x hello.sh && echo 'echo -e "Hello World\nThis is my 1. code in bash"' > hello.sh ./hello.sh
-
@meleu Upss..
Are we not in lesson #2? -
@cyperghost Me after reading your tutorial:
Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.
Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.