Is it better to use if or [ for simple checks?
I'm not new to bash, but I don't know most things behind the scenes of bash noscript. So, if I'm doing something simple like checking if a variable has a value, is it better to use an if statement, or \[\[? Or does it even matter?
Example:
my_var="some value"
[[ "$my_var" ] && {
: Do something
}
if [ "$my_var" ]; then
: Do something
fi
​
https://redd.it/1bn3gu7
@r_bash
I'm not new to bash, but I don't know most things behind the scenes of bash noscript. So, if I'm doing something simple like checking if a variable has a value, is it better to use an if statement, or \[\[? Or does it even matter?
Example:
my_var="some value"
[[ "$my_var" ] && {
: Do something
}
if [ "$my_var" ]; then
: Do something
fi
​
https://redd.it/1bn3gu7
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
I need to have something to detect and unmount a Windows OS drive. I have some code that I wrote in order to detect it whether it's mounted or not. This works fine so far...
...can I get some help smoothing this code down to something that is just as reliable.
Here is the function. It may be a bit crude but so far it has worked without any hitches. Can I do the same in a better way? This is for a backup noscript that allows me to find a Windows OS drive whether mounted or not in order to exclude that partition from any backups that are initiated, and the only way I could think of to do that was to look for the "Microsoft reserved" flag that is attached on every drive where an OS is installed. I couldn't reliably look solely for "Microsoft basic data" or anything merely "ntfs" because of /media drives that are formatted as ntfs and don't have any associated OS. This is what I came up with to find the drive partition where the OS is installed. It has been good finding only one Windows OS installed, but I have yet to try it on more than one (one is enough).
[Edit:\] I can't do anything about the formatting. As soon as I enter the change the browser left justifies everything, removing all my white spaces.
https://redd.it/1bn484p
@r_bash
...can I get some help smoothing this code down to something that is just as reliable.
Here is the function. It may be a bit crude but so far it has worked without any hitches. Can I do the same in a better way? This is for a backup noscript that allows me to find a Windows OS drive whether mounted or not in order to exclude that partition from any backups that are initiated, and the only way I could think of to do that was to look for the "Microsoft reserved" flag that is attached on every drive where an OS is installed. I couldn't reliably look solely for "Microsoft basic data" or anything merely "ntfs" because of /media drives that are formatted as ntfs and don't have any associated OS. This is what I came up with to find the drive partition where the OS is installed. It has been good finding only one Windows OS installed, but I have yet to try it on more than one (one is enough).
[Edit:\] I can't do anything about the formatting. As soon as I enter the change the browser left justifies everything, removing all my white spaces.
unmount=true FIND_WIN_PARTITION(){ unset FIND_WIN_OS FIND_WIN_REC WIN_OS_DRIVE ; local FIND_WIN_OS FIND_WIN_REC WIN_OS_DRIVE ; FIND_WIN_REC=$(sudo fdisk -l | grep "Microsoft reserved" | awk '{print $1}') ; # Find the reserved drive flag. FIND_WIN_OS="${FIND_WIN_REC:5:3}" ; # removes ("/dev/") echoing the next 3 characters (sd?, nvm, dis...) if eval sudo fdisk -l | grep "${FIND_WIN_OS}" | grep "Microsoft basic data" | awk '{print $1}' ; then # Now we can find the Windows OS drive WIN_OS_DRIVE="$(sudo fdisk -l | grep "${FIND_WIN_OS}" | grep "Microsoft basic data" | grep -v "/media" | awk '{print $1}')" &>/dev/null ; # unmount, true or false if [[ "${unmount}" == true ]] ; then if df | grep "$WIN_OS_DRIVE" &>/dev/null ;then sudo umount -f "$WIN_OS_DRIVE" ;fi ; fi ; if [[ -n "${FIND_WIN_OS}" ]] ; then { echo "${FIND_WIN_OS}" ; return 0 ; } ; fi ; else [[ -z ${FIND_WIN_REC} ]] && return 1 ;fi ; }https://redd.it/1bn484p
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
compgen -c
Hi,
I'm getting a bit confused with this command, I have a few machines that are configured in the same way, same bash version and distro, etc.
I've noticed that in one of those machines the output of `compgen -c` is sligthly different than on the rest, for example, commands that start with the letter k such as keepass* are grouped together, but on this machine it isn't.
Does anyone know what determines the output/ordering with this command? Does the number of installed programs affect it? I've checked things like the locale and it's all configured exactly the same.
Thanks.
https://redd.it/1bni2k2
@r_bash
Hi,
I'm getting a bit confused with this command, I have a few machines that are configured in the same way, same bash version and distro, etc.
I've noticed that in one of those machines the output of `compgen -c` is sligthly different than on the rest, for example, commands that start with the letter k such as keepass* are grouped together, but on this machine it isn't.
Does anyone know what determines the output/ordering with this command? Does the number of installed programs affect it? I've checked things like the locale and it's all configured exactly the same.
Thanks.
https://redd.it/1bni2k2
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
Enhance ArchLinux with this Bash Wrapper for Reflector
Greetings, r/bash and /r/archlinux enthusiasts,
I'm sharing a Bash noscript designed to automate the updating of your Pacman mirrorlist, ensuring you're always fetching packages from the fastest, most reliable mirrors. This tool not only updates your mirrorlist but also offers the flexibility to create a systemd service for automatic updates at your preferred frequency.
Key Features:
Update your Pacman mirrorlist with mirrors best suited for your region.
Customize the number of mirrors to test, filter by country, protocol, and more.
Create a systemd service to automate updates on an hourly, daily, weekly, or monthly basis.
Includes options for dry runs, logging, and verbose output for detailed process insights.
The noscript requires root or sudo privileges and is designed with options to tailor its operation to your needs, such as setting the country or region code for mirror filtering, excluding specific mirrors, and adjusting the number of mirrors to test.
Usage:
Options include:
-h, --help for displaying the help menu.
-c, --country <code> to set the country or region code.
--config <path> to use a specific configuration file.
And more, detailed within the noscript's help section.
Example Commands:
To set the service frequency to daily and test 100 mirrors:
For a dry run using HTTP protocol and creating the systemd service:
The noscript is thoroughly commented, making customization straightforward for those different levels of Bash knowledge. Feel free to adapt, improve, and share your enhancements.
Half of why I post these things is to get feedback on how my submission can be improved and/or just done plain better. You don't know what you don't know.
Cheers!
GitHub Script
Config File
https://redd.it/1bnoxqv
@r_bash
Greetings, r/bash and /r/archlinux enthusiasts,
I'm sharing a Bash noscript designed to automate the updating of your Pacman mirrorlist, ensuring you're always fetching packages from the fastest, most reliable mirrors. This tool not only updates your mirrorlist but also offers the flexibility to create a systemd service for automatic updates at your preferred frequency.
Key Features:
Update your Pacman mirrorlist with mirrors best suited for your region.
Customize the number of mirrors to test, filter by country, protocol, and more.
Create a systemd service to automate updates on an hourly, daily, weekly, or monthly basis.
Includes options for dry runs, logging, and verbose output for detailed process insights.
The noscript requires root or sudo privileges and is designed with options to tailor its operation to your needs, such as setting the country or region code for mirror filtering, excluding specific mirrors, and adjusting the number of mirrors to test.
Usage:
./update_mirrorlist.sh [OPTIONS]Options include:
-h, --help for displaying the help menu.
-c, --country <code> to set the country or region code.
--config <path> to use a specific configuration file.
And more, detailed within the noscript's help section.
Example Commands:
To set the service frequency to daily and test 100 mirrors:
./update_mirrorlist.sh -f daily -m 100For a dry run using HTTP protocol and creating the systemd service:
./update_mirrorlist.sh -s -p http --dry-runThe noscript is thoroughly commented, making customization straightforward for those different levels of Bash knowledge. Feel free to adapt, improve, and share your enhancements.
Half of why I post these things is to get feedback on how my submission can be improved and/or just done plain better. You don't know what you don't know.
Cheers!
GitHub Script
Config File
https://redd.it/1bnoxqv
@r_bash
GitHub
noscript-repo/Bash/Arch Linux Scripts/update_mirrorlist.sh at main · slyfox1186/noscript-repo
My personal noscript repository with multiple languages supported. AHK v1+v2 | BASH | BATCH | JSON | POWERSHELL | POWERSHELL | PYTHON | WINDOWS REGISTRY | XML - slyfox1186/noscript-repo
grep \ sed \ awk random parameter from a line between special characters
I have a echo of "getend passwd <user>" with format:
randomUsername:<random>:<random>:<random>:randomFullname:<random>:<random>
How to get randomFullname parameter between fixed quantity of special characters like : ?
THX
https://redd.it/1bog8s4
@r_bash
I have a echo of "getend passwd <user>" with format:
randomUsername:<random>:<random>:<random>:randomFullname:<random>:<random>
How to get randomFullname parameter between fixed quantity of special characters like : ?
THX
https://redd.it/1bog8s4
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
rsync-based mv--remove dirs in source as they get synced?
I'm implementing an rsync-based version of mv because destination is not reliable (not using
Any way, with
However, the rsync operation is potentially very long and I would like it to behave like mv where as a file gets moved, it gets deleted (vs. the existing behavior described above where empty remaining directories do not get deleted).
Is there a way to implement this without invoking an rsync on every sub directory of source directory (so that when each sub directory gets synced, rsync ends so clean up of files can begin for that sub directory)? I imagine that would significantly slow down performance of the overall sync. I guess rync would need to support some kind of hook otherwise (not that I would expect it to, it's not inline with unix philosophy of just doing one thing well).
https://redd.it/1boex01
@r_bash
I'm implementing an rsync-based version of mv because destination is not reliable (not using
--checksum though, rsync by default compares file sizes and modification times which I assume is good enough for media files)?Any way, with
--remove-source-files it only removes files, leaving behind empty directories under the source directory. I handle this manually by checking if there are files in source dir after the rsync operation and if not, rm -r it.However, the rsync operation is potentially very long and I would like it to behave like mv where as a file gets moved, it gets deleted (vs. the existing behavior described above where empty remaining directories do not get deleted).
Is there a way to implement this without invoking an rsync on every sub directory of source directory (so that when each sub directory gets synced, rsync ends so clean up of files can begin for that sub directory)? I imagine that would significantly slow down performance of the overall sync. I guess rync would need to support some kind of hook otherwise (not that I would expect it to, it's not inline with unix philosophy of just doing one thing well).
https://redd.it/1boex01
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
duplicate a telnet entry
I am trying to replicate something simple like this
telnet IP
#011000 (typed in manually)
I hit the enter key and the command executes
when I try to duplicate that
echo '#011000' | netcat -N IP
this does NOT work. I'm guessing because of the carriage return isn't being sent.
What am I missing to get this to work. I'm guessing the echo isn't sending an "enter" key at the end
I also tried
echo '#011000\r' | netcat -N IP
but that didn't work either.
What am I missing?
https://redd.it/1bokgip
@r_bash
I am trying to replicate something simple like this
telnet IP
#011000 (typed in manually)
I hit the enter key and the command executes
when I try to duplicate that
echo '#011000' | netcat -N IP
this does NOT work. I'm guessing because of the carriage return isn't being sent.
What am I missing to get this to work. I'm guessing the echo isn't sending an "enter" key at the end
I also tried
echo '#011000\r' | netcat -N IP
but that didn't work either.
What am I missing?
https://redd.it/1bokgip
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
Help with variables
Hi all. I am not a programmer though I have some basics of coding from some years ago. I tried writing a noscript for my computer (Linux) mostly for fun.
I don't know much of bash, but since the noscript was overall easy, I only read the very basics.
The idea of the noscript is to launch some games with MelonDS or mgba.
The command for melonDS is "melonDS path/of/the game".
The noscript:
- lists the games
-asks for input for the name of the game and stores the name in a variable (a)
- if the last three letters are "nds" then executes the command "melonDS path/$a" (where a is the name of the game)
- haven't written the rest yet
The problem is that I don't understand what I might be doing wrong, because the final result is indeed "melonDS /path/of/the game" but melonDS just launches without the actual game. When I run the exact same command from terminal, it works.
Sorry, if this is maybe a noob mistake, that's my real first noscript.
Update:code
Update 2: I noticed that the "d" variable part was wrong. Thanks for pointing out!
Now, I noticed that the name and path is not stored in the correct way. There are the '\' signs, so the final command comes out wrong.
picture
https://redd.it/1bpc37r
@r_bash
Hi all. I am not a programmer though I have some basics of coding from some years ago. I tried writing a noscript for my computer (Linux) mostly for fun.
I don't know much of bash, but since the noscript was overall easy, I only read the very basics.
The idea of the noscript is to launch some games with MelonDS or mgba.
The command for melonDS is "melonDS path/of/the game".
The noscript:
- lists the games
-asks for input for the name of the game and stores the name in a variable (a)
- if the last three letters are "nds" then executes the command "melonDS path/$a" (where a is the name of the game)
- haven't written the rest yet
The problem is that I don't understand what I might be doing wrong, because the final result is indeed "melonDS /path/of/the game" but melonDS just launches without the actual game. When I run the exact same command from terminal, it works.
Sorry, if this is maybe a noob mistake, that's my real first noscript.
Update:code
Update 2: I noticed that the "d" variable part was wrong. Thanks for pointing out!
Now, I noticed that the name and path is not stored in the correct way. There are the '\' signs, so the final command comes out wrong.
picture
https://redd.it/1bpc37r
@r_bash
Validating input and adding a prefix before executing ansible playbook
I am creating a bash noscript that runs an ansible playbook. So far I have
The targethostnames variable accepts one or more store number. I need to do the following:
1)Make sure that each store number is five digits long and starts with number 2
Something like `$storenumber =~ ^20-9{4}$
while [ ! $store_number =~ ^2[0-9{4}$ ]]; do
read -p "Store number must be five digits starting with 2. Please enter a valid store number: " storenumber
done
```
The above validates for one user input but I don't know how to validate for several inputs separated by comma.
2) Add a "store" prefix before each store number. So it would be like store22345
I am expecting the value of "targethostnames=store22345,store28750" and so on. One input is minimum.
https://redd.it/1bpeuxc
@r_bash
I am creating a bash noscript that runs an ansible playbook. So far I have
cd /path/to/playbook
python3 inventory_updater.py
# Check if there are no errors from executing python noscript.
[ $? -eq 0 ] # Is this an appropriate way to check with an if condition and exit code ?
read -p "Enter store numbers separated by commas (e.g., 22345,28750): " store_numbers
ansible-playbook update_specific_stores.yml -e "target_hostnames=$store_numbers"
The targethostnames variable accepts one or more store number. I need to do the following:
1)Make sure that each store number is five digits long and starts with number 2
Something like `$storenumber =~ ^20-9{4}$
. Prompt user if incorrect.
while [ ! $store_number =~ ^2[0-9{4}$ ]]; do
read -p "Store number must be five digits starting with 2. Please enter a valid store number: " storenumber
done
```
The above validates for one user input but I don't know how to validate for several inputs separated by comma.
2) Add a "store" prefix before each store number. So it would be like store22345
I am expecting the value of "targethostnames=store22345,store28750" and so on. One input is minimum.
https://redd.it/1bpeuxc
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
What is the role of bash noscript in Machine Learning?
This is the requirement of a ML intern. Can anyone tell me what is the use cases of bash noscript in ML field?
Thanks in Advance
Qualifications
A bachelor’s, master's, or PhD (ongoing or complete) degree or equivalent from a top university, available to join for an in-office Summer Internship from May 2024.
Prior experience with training, building, and deploying models via Tensorflow/Pytorch (or similar) is mandatory.
Experience with CI/CD pipelines and MLOps for automating model deployments.
Skilled in using Linux, SQL, Git, and BASH noscripting.
Strong knowledge of Python and hands-on.
https://redd.it/1bpnvp0
@r_bash
This is the requirement of a ML intern. Can anyone tell me what is the use cases of bash noscript in ML field?
Thanks in Advance
Qualifications
A bachelor’s, master's, or PhD (ongoing or complete) degree or equivalent from a top university, available to join for an in-office Summer Internship from May 2024.
Prior experience with training, building, and deploying models via Tensorflow/Pytorch (or similar) is mandatory.
Experience with CI/CD pipelines and MLOps for automating model deployments.
Skilled in using Linux, SQL, Git, and BASH noscripting.
Strong knowledge of Python and hands-on.
https://redd.it/1bpnvp0
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
why does /bin/bash -c 'ssh user@host' work?
I expected keyboard input for ssh running in a child shell to break, and that I would have to do something fancy with wiring the child process input/output to the parent shell's tty, but to my surprise this worked without any fanciness required? Would someone be able to explain what is happening at a low level that enables this to work? Thank you!
https://redd.it/1bptn6k
@r_bash
I expected keyboard input for ssh running in a child shell to break, and that I would have to do something fancy with wiring the child process input/output to the parent shell's tty, but to my surprise this worked without any fanciness required? Would someone be able to explain what is happening at a low level that enables this to work? Thank you!
https://redd.it/1bptn6k
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
TIL: not all line continuations are the same
An unquoted slash `\` can be used to continue some command onto the next line:
$ echo abc \
> def
abc def
Both `||` and `&&` act like that:
$ echo abc &&
> echo def
abc
def
$ ! echo 123 ||
> echo 345
123
345
But there is something more to the last two: you can put multiple newlines OR comments in-between:
$ echo abc &&
>
> # some
> # comment
>
> echo def
abc
def
Or in a more practical code:
[[ $repack_early3 == n ]] ||
# The symlink is no longer needed
rm "$initrd_main/lib/modules/$kernel/kernel"
https://redd.it/1bq0enr
@r_bash
An unquoted slash `\` can be used to continue some command onto the next line:
$ echo abc \
> def
abc def
Both `||` and `&&` act like that:
$ echo abc &&
> echo def
abc
def
$ ! echo 123 ||
> echo 345
123
345
But there is something more to the last two: you can put multiple newlines OR comments in-between:
$ echo abc &&
>
> # some
> # comment
>
> echo def
abc
def
Or in a more practical code:
[[ $repack_early3 == n ]] ||
# The symlink is no longer needed
rm "$initrd_main/lib/modules/$kernel/kernel"
https://redd.it/1bq0enr
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
command help
I want to use a simple one-liner something like this:
whois $domainname | grep "Expir" | xargs $domainname = example.com
Something I can quickly change (or make into an useful alias).
I'm on the hunt for a new domain name, and want to avoid the long wall of text that comes from each whois search.
Is this possible without making it complicated and using noscript files etc?
https://redd.it/1bq8wii
@r_bash
I want to use a simple one-liner something like this:
whois $domainname | grep "Expir" | xargs $domainname = example.com
Something I can quickly change (or make into an useful alias).
I'm on the hunt for a new domain name, and want to avoid the long wall of text that comes from each whois search.
Is this possible without making it complicated and using noscript files etc?
https://redd.it/1bq8wii
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
Bash noscript help to launch docker container
I’m running Debian 12 and I have a Windows 11 docker container that I use with FreeRDP. I would like to have an “app” for lack of a better term that when clicked would start the windows container and start FreeRDP. I’ve written an easy little bash noscript that starts both the container and FreeRDP. I’m running into trouble checking to see if the windows container is already running. If it is, then just launch FreeRDP. If not, launch both.
I also need to have the noscript automatically stop the Windows container when I close out of FreeRDP.
Anyone have any ideas about the best way to do this?
https://redd.it/1bqbad2
@r_bash
I’m running Debian 12 and I have a Windows 11 docker container that I use with FreeRDP. I would like to have an “app” for lack of a better term that when clicked would start the windows container and start FreeRDP. I’ve written an easy little bash noscript that starts both the container and FreeRDP. I’m running into trouble checking to see if the windows container is already running. If it is, then just launch FreeRDP. If not, launch both.
I also need to have the noscript automatically stop the Windows container when I close out of FreeRDP.
Anyone have any ideas about the best way to do this?
https://redd.it/1bqbad2
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
I've implemented a few utilities to enumerate/disable/enable Linux input devices using Bash shell noscripts
https://gitlab.com/brlin/linux-input-utils
https://redd.it/1bqkrca
@r_bash
https://gitlab.com/brlin/linux-input-utils
https://redd.it/1bqkrca
@r_bash
GitLab
林博仁 Buo-ren, Lin / Linux input device management utilites · GitLab
Manage Linux input devices(mice, keyboards, touch pads, and more) with ease!
Help with quotes and variables
Hi all, I am new to bash. I have a problem to which I haven't found a solution yet. I am starting to learn right now, so forgive me if my knowledge of bash isn't the best at all.
What I want to achieve is this output:
command $d
Where "command" is a command and $d is a variable. The variable d is based on another variable, called a.
It's something like this: d="/home/name/$a".
The problem is that variable a contains single quotes, like this: a='name of the file'
So, as you can guess the idea is to launch a command with the path of the file. However, the single quotes make it very difficult because when under the double quotes ("") are interpreted differently. How can I overcome this problem?
https://redd.it/1bqlxcj
@r_bash
Hi all, I am new to bash. I have a problem to which I haven't found a solution yet. I am starting to learn right now, so forgive me if my knowledge of bash isn't the best at all.
What I want to achieve is this output:
command $d
Where "command" is a command and $d is a variable. The variable d is based on another variable, called a.
It's something like this: d="/home/name/$a".
The problem is that variable a contains single quotes, like this: a='name of the file'
So, as you can guess the idea is to launch a command with the path of the file. However, the single quotes make it very difficult because when under the double quotes ("") are interpreted differently. How can I overcome this problem?
https://redd.it/1bqlxcj
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community
So what is your bash coding environment?
It's a quiet Saturday on the subreddit, so I was curious.
My setup is:
Neovim → conquer of completion (coc.nvim) → coc-sh Current version 1.2.2
I do want to learn lua to set up those nvim language server protocol to skip coc. Just not that good on learning new things.
I do not have any other bash related plugins. Ok, I use
My
So I usually have the code in my right pane and the execution of the code with bash -x on the left, to see where I messed up.
Any workflow, cool plugins you might want to share?
https://redd.it/1brm1iy
@r_bash
It's a quiet Saturday on the subreddit, so I was curious.
My setup is:
Neovim → conquer of completion (coc.nvim) → coc-sh Current version 1.2.2
I do want to learn lua to set up those nvim language server protocol to skip coc. Just not that good on learning new things.
I do not have any other bash related plugins. Ok, I use
nerdtree to navigate sourced files, but I don't think that counts.My
PS4='•\[\e[1;33m\] ${BASH_SOURCE[0]##*/} ${LINENO}\[\e[m\] 'So I usually have the code in my right pane and the execution of the code with bash -x on the left, to see where I messed up.
Any workflow, cool plugins you might want to share?
https://redd.it/1brm1iy
@r_bash
GitHub
GitHub - neoclide/coc.nvim: Nodejs extension host for vim & neovim, load extensions like VSCode and host language servers.
Nodejs extension host for vim & neovim, load extensions like VSCode and host language servers. - neoclide/coc.nvim
Building Signal for RaspberryPi. Look over the start of this noscript?
Using THIS blog post as a start I put this together. This will build but some things are hard coded and Id like to "detect" more. Like pulling a "stable" branch for Signal or always installing the latest nvm. I'm also struggling to use sed correctly to edit the packages.json file to add the "AppImage" part.
Any help is welcome. Hope theres a few folks out there that want this.
​
​
#!/bin/bash
## This noscript based on Andrea Fortunas blog post here: https://andreafortuna.org/2019/03/27/how-to-build-signal-desktop-on-linux/
## NVH Homepage: https://github.com/nvm-sh/nvm
## Signal-Desktop releases: https://github.com/signalapp/Signal-Desktop/releases
sudo apt install build-essential -y
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.39.7/install.sh | bash
git clone https://github.com/signalapp/Signal-Desktop.git --branch v7.4.0-beta.2 .local/share/Signal-Desktop ; exit
####EXIT TERMINAL HERE (i think to reset bash enviornment)
cd ~/.local/share/Signal-Desktop/
#sed -i 's/original/new/g' package.json
nvm use ; nvm install 20.9.0 ; npm install --global yarn ; yarn install --frozen-lockfile ; yarn generate ; yarn build-release
mkdir ~/.local/share/applications
cat > ~/.local/share/applications/signal-desktop.desktop <<EOF
Desktop Entry
Name=Signal
Exec=env LANGUAGE=tlh ~/.local/share/Signal-Desktop/release/linux-arm64-unpacked/signal-desktop --no-sandbox %U
Terminal=false
Type=Application
Icon=signal-desktop
StartupWMClass=Signal
Comment=Private messaging from your desktop
MimeType=x-scheme-handler/sgnl;x-scheme-handler/signalcaptcha;
Categories=Network;InstantMessaging;Chat;
EOF
##REMOVAL
#rm -R ~/.local/share/applications/signal-desktop.desktop ~/.local/share/Signal-Desktop ~/.nvm ##.config/Signal/
​
Thanx
https://redd.it/1bru7yk
@r_bash
Using THIS blog post as a start I put this together. This will build but some things are hard coded and Id like to "detect" more. Like pulling a "stable" branch for Signal or always installing the latest nvm. I'm also struggling to use sed correctly to edit the packages.json file to add the "AppImage" part.
Any help is welcome. Hope theres a few folks out there that want this.
​
​
#!/bin/bash
## This noscript based on Andrea Fortunas blog post here: https://andreafortuna.org/2019/03/27/how-to-build-signal-desktop-on-linux/
## NVH Homepage: https://github.com/nvm-sh/nvm
## Signal-Desktop releases: https://github.com/signalapp/Signal-Desktop/releases
sudo apt install build-essential -y
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.39.7/install.sh | bash
git clone https://github.com/signalapp/Signal-Desktop.git --branch v7.4.0-beta.2 .local/share/Signal-Desktop ; exit
####EXIT TERMINAL HERE (i think to reset bash enviornment)
cd ~/.local/share/Signal-Desktop/
#sed -i 's/original/new/g' package.json
nvm use ; nvm install 20.9.0 ; npm install --global yarn ; yarn install --frozen-lockfile ; yarn generate ; yarn build-release
mkdir ~/.local/share/applications
cat > ~/.local/share/applications/signal-desktop.desktop <<EOF
Desktop Entry
Name=Signal
Exec=env LANGUAGE=tlh ~/.local/share/Signal-Desktop/release/linux-arm64-unpacked/signal-desktop --no-sandbox %U
Terminal=false
Type=Application
Icon=signal-desktop
StartupWMClass=Signal
Comment=Private messaging from your desktop
MimeType=x-scheme-handler/sgnl;x-scheme-handler/signalcaptcha;
Categories=Network;InstantMessaging;Chat;
EOF
##REMOVAL
#rm -R ~/.local/share/applications/signal-desktop.desktop ~/.local/share/Signal-Desktop ~/.nvm ##.config/Signal/
​
Thanx
https://redd.it/1bru7yk
@r_bash
Andrea Fortuna
How to build Signal Desktop on Linux
Today let's try to make your own Linux build of Signal Desktop, in .deb and .AppImage format. Signal is a mobile app developed by Open Whisper Systems. The app provides instant messaging, voice and video calling, and all communications are end-to-end encrypted.…
Printf -v var
Works
printf -v var “%s” “hi”
echo “$var”
Works
printf “%s” “hi” | tee somefile
cat somefile
Why this one doesnt work?
printf -v var “%s” “hi” | tee somefile
echo “$var” # var is empty
cat somefile # file is empty
https://redd.it/1brz5a9
@r_bash
Works
printf -v var “%s” “hi”
echo “$var”
Works
printf “%s” “hi” | tee somefile
cat somefile
Why this one doesnt work?
printf -v var “%s” “hi” | tee somefile
echo “$var” # var is empty
cat somefile # file is empty
https://redd.it/1brz5a9
@r_bash
Reddit
From the bash community on Reddit
Explore this post and more from the bash community