Difference between revisions of "BASH Shortcuts"

From PrattWiki
Jump to navigation Jump to search
(EGR 103 Lab Startup)
 
(18 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
The following is a list of shortcuts Pratt students may want to add to their <code>.bashrc</code> profile.  This, first of all, assumes that they are using the bash shell.  To check this, type
 
The following is a list of shortcuts Pratt students may want to add to their <code>.bashrc</code> profile.  This, first of all, assumes that they are using the bash shell.  To check this, type
  echo $SHELL
+
  echo $SHELL  
 
If the result is
 
If the result is
 
  /bin/bash
 
  /bin/bash
 
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 >  
  
== Stayin' Alive ==
+
== Main Shortcuts ==
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:
+
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:
<source lang="bash">
+
  emacs ~/.bashrc &
xeyes -geometry 1x1-1-1 &
 
</source>
 
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.
 
  
== AFS Directory Shortcut ==
+
=== EGR 103 Lab Startup ===
If you are in a class that is using the AFS space (specifically so that permission can be set and such), you may want to add a line to your <code>.bashrc</code> file to get there more efficiently. The information on that is at the [[AFS Course Space]] page, specifically in the [[AFS_Course_Space#For_.2Fbin.2Fbash_.28newer_users.29|/bin/bash]] users section.
+
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 <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:
 +
<syntaxhighlight lang=bash>
 +
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
 +
}
 +
</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>dvips</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>dvips</code> to get a PostScript 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
dvips -t 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
 
  dvips -t letter $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
   dvips -t letter $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
  dvips -t letter FILE.dvi
+
  dvipdf FILE.dvi
 +
 
 +
<!--
 +
=== Add, Commit, and Push to Git All In One! ===
 +
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:
 +
<syntaxhighlight lang="bash">
 +
gitpush103() {
 +
cd ~/EGR103
 +
git add .
 +
if [[ -n $1 ]]
 +
then
 +
    git commit -a -m '$1'
 +
else
 +
    git commit -a -m 'no message'
 +
fi
 +
git push
 +
}
 +
</syntaxhighlight >
 +
You could include a message when using this.
 +
* ''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,
 +
<syntaxhighlight lang="bash">
 +
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