Difference between revisions of "BASH Shortcuts"

From PrattWiki
Jump to navigation Jump to search
(EGR 103 Lab Startup)
 
(13 intermediate revisions by the same user not shown)
Line 5: Line 5:
 
than this page applies to you; if not, see the [[TCSH Shortcuts]] page.
 
than this page applies to you; if not, see the [[TCSH Shortcuts]] page.
  
If you are a bash shell user, you will also need to have a <code>.bash_profile</code> in your CIFS home directory (the ~ directory) for the shortcuts to work.  The contents of the profile should be:
+
 
<source lang="bash">
+
== Required .bash_profile File ==
 +
If you are a bash shell user, you will also need to have a <code>.bash_profile</code> in your CIFS home directory (the ~ directory) for the shortcuts to work.  Use <code>emacs</code> to edit the file with the command:
 +
emacs ~/.bash_profile &
 +
 
 +
The contents of the profile should be as given below; best bet is to select the text from the browser, middle click in the emacs window to paste, then save the file.:
 +
<syntaxhighlight lang="bash">
 
# .bash_profile
 
# .bash_profile
  
Line 18: Line 23:
  
 
export PATH
 
export PATH
</source>  
+
</syntaxhighlight >  
 +
 
 +
== Main Shortcuts ==
 +
These shourtcuts should go in a <code>~/.bashrc</code> file.  You will want to copy them from the browser and middle click them in an emacs window you started with:
 +
emacs ~/.bashrc &
  
== Stayin' Alive ==
+
=== EGR 103 Lab Startup ===
There is currently a 10-minute inactivity timeout on remote loginsIn order to eliminate this, add the following line to your <code>.bashrc</code> file:
+
You can create a script to automate the process of getting the tar file, expanding it, and making a local copyThis command should only be used once you have created the appropriate <code>labN</code> folder in your <code>EGR103</code> folder and should only be used if you have changed into that folder!  Type <code>pwd</code> first to make sure you are in the right place!  You can add the following to your <code>.bashrc</code> file:
<source lang="bash">
+
<syntaxhighlight lang=bash>
xeyes -geometry 1x1-1-1 &
+
get103(){
</source>
+
LabNum=$1;
This will start the <code>xeyes</code> program off screen and in the background. With this program running, however, your session will not time out. If that puts an xeyes window on your screen, try
+
wget people.duke.edu/~mrg/EGR103/Lab${LabNum}Files.tar
xeyes -geometry 1x1-1-100 &
+
tar -kxvf Lab${LabNum}Files.tar
instead.
+
cp -i Lab${LabNum}Sample_S20.tex lab${LabNum}.tex
 +
}
 +
</syntaxhighlight >
 +
and then if you log out and log back in (or type <code>source ~/.bashrc</code>, from that point forward, '''once you are in the correct directory''', you can type the command
 +
<syntaxhighlight lang=bash>
 +
get103 N
 +
</syntaxhighlight >
 +
where N is the appropriate lab number and this will get the tar file from Dr. G's web space, expand it, and make a local copy of the lab skeleton in <code>labN.tex</code>.
  
== <code>latex</code> and <code>dvipdf</code> in One Command ==
+
=== <code>latex</code> and <code>dvipdf</code> in One Command ===
Now that you need to run both <code>latex</code> and <code>dvipdf</code> to get a PDF file for [[evince]] to look at, you may want to have a shorter way that having to type
+
Now that you need to run both <code>latex</code> and <code>dvipdf</code> to get a PDF file for [[evince]] to look at, you may want to have a shorter way than having to type
<source lang="bash">
+
<syntaxhighlight lang="bash">
 
latex FILE.tex
 
latex FILE.tex
 
dvipdf FILE.dvi
 
dvipdf FILE.dvi
</source>
+
</syntaxhighlight >
 
every time.  To make a /bin/bash shortcut for that, add the following to your <code>.bashrc</code> file:
 
every time.  To make a /bin/bash shortcut for that, add the following to your <code>.bashrc</code> file:
<source lang="bash">
+
<syntaxhighlight lang="bash">
ltx() {
 
  latex $1.tex
 
  dvipdf $1
 
}
 
</source>
 
 
 
If you want a version that does some basic error-checking, use this one:
 
<source lang="bash">
 
 
ltx() {
 
ltx() {
if [[ $1 = *.* ]]
+
MyFile=$1;
then
+
MyFile=${MyFile%%.*}
  echo "ERROR: '$1' has dots. ltx does not want dots"
+
   
  return
+
if [[ -f $MyFile.tex ]]
fi
 
 
 
if [[ -f $1.tex ]]
 
 
then
 
then
   latex $1.tex
+
   latex $MyFile.tex
   dvipdf $1
+
   dvipdf $MyFile.dvi
 
else
 
else
   echo "ERROR: '$1.tex' not found"
+
   echo "*ERROR*: '$MyFile.tex' not found"
 
fi
 
fi
 
}
 
}
</source>
+
</syntaxhighlight >
 +
Note that to use it, you do not need to include the ".tex" at the end of your file name, but you can.  The script will automatically take the extension off whatever you gave as an input.
 +
 
 
From that point on, once the <code>.bashrc</code> runs to start your session, you can simply type
 
From that point on, once the <code>.bashrc</code> runs to start your session, you can simply type
 
  ltx FILE
 
  ltx FILE
 +
or
 +
ltx FILE.tex
 
and it will run
 
and it will run
 
  latex FILE.tex
 
  latex FILE.tex
  dvidf FILE.dvi
+
  dvipdf FILE.dvi
 
 
  
 +
<!--
 
=== Add, Commit, and Push to Git All In One! ===
 
=== Add, Commit, and Push to Git All In One! ===
If you want t a short command that you can use to add files to a repository, commit them all, and push them, here's a shortcut for that:
+
If you want a short command that you can use to change to your EGR103 folder, add files to a repository, commit them all, and push them, here's a shortcut for that:
<source lang="bash">
+
<syntaxhighlight lang="bash">
gitdone() {
+
gitpush103() {
 +
cd ~/EGR103
 
git add .
 
git add .
git commit -a -m $1
+
if [[ -n $1 ]]
 +
then
 +
    git commit -a -m '$1'
 +
else
 +
    git commit -a -m 'no message'
 +
fi
 
git push
 
git push
 
}
 
}
</source>
+
</syntaxhighlight >
You must include a message when using this; for instance,
+
You could include a message when using this.
<source lang="bash">
+
* ''Note'' - until 4:30pm on 9/29, the '$1' piece in the shortcut was $1 instead; this means for that shortcut that the message cannot contain spaces; for instance,
gitdone 'My Message'
+
<syntaxhighlight lang="bash">
</source>
+
gitpush103 'My_Message'
 +
</syntaxhighlight >
 +
:would work but
 +
<syntaxhighlight lang="bash">
 +
gitpush103 'My Message'
 +
</syntaxhighlight >
 +
:would not.  Putting the single quotes around the '$1' as above fixes that, such that any message between the single quotes will work.
 +
* If you do not include a message, the default message is <code>no message</code>
 +
 
 +
== Others ==
 +
=== Stayin' Alive ===
 +
There is currently a 10-minute inactivity timeout on remote logins.  In order to eliminate this, add the following line to your <code>.bashrc</code> file:
 +
<syntaxhighlight lang="bash">
 +
xeyes -geometry 1x1-1-1 &
 +
</syntaxhighlight >
 +
This will start the <code>xeyes</code> program off screen and in the background.  With this program running, however, your session will not time out.  If that puts an xeyes window on your screen, try
 +
xeyes -geometry 1x1-1-100 &
 +
instead.
 +
-->

Latest revision as of 04:08, 5 February 2020

The following is a list of shortcuts Pratt students may want to add to their .bashrc profile. This, first of all, assumes that they are using the bash shell. To check this, type

echo $SHELL 

If the result is

/bin/bash

than this page applies to you; if not, see the TCSH Shortcuts page.


Required .bash_profile File

If you are a bash shell user, you will also need to have a .bash_profile in your CIFS home directory (the ~ directory) for the shortcuts to work. Use emacs to edit the file with the command:

emacs ~/.bash_profile &

The contents of the profile should be as given below; best bet is to select the text from the browser, middle click in the emacs window to paste, then save the file.:

# .bash_profile

# Get the aliases and functions
if [ -f ~/.bashrc ]; then
      . ~/.bashrc 
fi  

# User specific environment and startup programs
PATH=$PATH:$HOME/bin

export PATH

Main Shortcuts

These shourtcuts should go in a ~/.bashrc file. You will want to copy them from the browser and middle click them in an emacs window you started with:

emacs ~/.bashrc &

EGR 103 Lab Startup

You can create a script to automate the process of getting the tar file, expanding it, and making a local copy. This command should only be used once you have created the appropriate labN folder in your EGR103 folder and should only be used if you have changed into that folder! Type pwd first to make sure you are in the right place! You can add the following to your .bashrc file:

get103(){
LabNum=$1;
wget people.duke.edu/~mrg/EGR103/Lab${LabNum}Files.tar
tar -kxvf Lab${LabNum}Files.tar
cp -i Lab${LabNum}Sample_S20.tex lab${LabNum}.tex
}

and then if you log out and log back in (or type source ~/.bashrc, from that point forward, once you are in the correct directory, you can type the command

get103 N

where N is the appropriate lab number and this will get the tar file from Dr. G's web space, expand it, and make a local copy of the lab skeleton in labN.tex.

latex and dvipdf in One Command

Now that you need to run both latex and dvipdf to get a PDF file for evince to look at, you may want to have a shorter way than having to type

latex FILE.tex
dvipdf FILE.dvi

every time. To make a /bin/bash shortcut for that, add the following to your .bashrc file:

ltx() {
MyFile=$1;
MyFile=${MyFile%%.*}
 
if [[ -f $MyFile.tex ]]
then
   latex $MyFile.tex
   dvipdf $MyFile.dvi
else
  echo "*ERROR*: '$MyFile.tex' not found"
fi
}

Note that to use it, you do not need to include the ".tex" at the end of your file name, but you can. The script will automatically take the extension off whatever you gave as an input.

From that point on, once the .bashrc runs to start your session, you can simply type

ltx FILE

or

ltx FILE.tex

and it will run

latex FILE.tex
dvipdf FILE.dvi