aboutsummaryrefslogtreecommitdiff
path: root/st.c
diff options
context:
space:
mode:
authorAurélien Aptel <aurelien.aptel@gmail.com>2010-04-26 19:20:53 +0200
committerAurélien Aptel <aurelien.aptel@gmail.com>2010-04-26 19:20:53 +0200
commitd01c55c9ab58588d98239c515aa8db6443ae75ca (patch)
tree39669771cc74f2603f44f31b9d0ae2fa776cbe10 /st.c
parentb3b7ffce5f1cb1d82aa26df976f0316d89d15d7f (diff)
downloadst-d01c55c9ab58588d98239c515aa8db6443ae75ca.tar.gz
st-d01c55c9ab58588d98239c515aa8db6443ae75ca.tar.bz2
st-d01c55c9ab58588d98239c515aa8db6443ae75ca.zip
use SHELL environment variable (thx Thomas Adam)
Diffstat (limited to 'st.c')
-rwxr-xr-xst.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/st.c b/st.c
index deb1610..ee79a33 100755
--- a/st.c
+++ b/st.c
@@ -208,9 +208,12 @@ die(const char *errstr, ...) {
void
execsh(void) {
- char *args[3] = {SHELL, "-i", NULL};
+ char *shell = getenv("SHELL");
+ if(!shell)
+ shell = "/bin/sh";
+ char *args[3] = {shell, "-i", NULL};
putenv("TERM=" TNAME);
- execvp(SHELL, args);
+ execvp(shell, args);
}
void
@@ -844,7 +847,6 @@ tputtab(void) {
void
tputc(char c) {
- /* dump(c); */
if(term.esc & ESC_START) {
if(term.esc & ESC_CSI) {
escseq.buf[escseq.len++] = c;
@@ -1277,7 +1279,7 @@ run(void) {
}
if(FD_ISSET(cmdfd, &rfd)) {
ttyread();
- draw(SCREEN_UPDATE);
+ draw(SCREEN_UPDATE);
}
while(XPending(xw.dis)) {
XNextEvent(xw.dis, &ev);