What's your most useful shell?


Poll: What's your most useful shell?
Poll Options
What's your most useful shell?

 
Thread Tools Search this Thread
Top Forums UNIX for Advanced & Expert Users What's your most useful shell?
# 204  
Old 09-02-2011
I like bash then ksh then sh
# 205  
Old 05-13-2012
Hi,

I use bash shell at my home,but I use ksh at office. But most of the IT organizations use korn shell for scripting and other unix related activities, even if every facilities of ksh are also available in bash.

Could anyone please explain why it organizations prefer korn shell instead of bash shell. Thanks!

Kind regrads,
# 206  
Old 05-14-2012
Quote:
Originally Posted by crazybisu
Could anyone please explain why it organizations prefer korn shell instead of bash shell. Thanks!
OK, just one of the most annoying differences.

Suppose the following command lines, which could also be part of a script:

Code:
# mkdir kshtest ; cd kshtest ; touch a ; touch b ; touch c
# typeset x=""
> ls | while read y ; do
>      x="$x $y"
>      echo "$x"
> done
> echo "$x"

What is the content of "$x" after the loop? I every programming language i know (and ksh as well) it is "a b c". In bash it will be "" (empty string), because the content of "$x" is somewhat local to the code block. Notice the difference in the first "echo $x" and the last line.

Of course it would be possible to prevent this by replacing the pipeline with a redirection:

Code:
# mkdir kshtest ; cd kshtest ; touch a ; touch b ; touch c
# typeset x=""
> while read y ; do
>      x="$x $y"
>      echo "$x"
> done < "$(ls)"
> echo "$x"

but i would like my while-loops not to be steered at the bottom. It is just hard to read if the loop is longer and you have to go three pages down to find out what is fed into the loop, then go back up to see what is done with the input.

bakunin
# 207  
Old 05-14-2012
Quote:
Could anyone please explain why it organizations prefer korn shell instead of bash shell. Thanks!
Portability and availability.
Many unix Operating Systems do not come with bash.
There are non-standard scripting language extensions in bash.
# 208  
Old 05-14-2012
Quote:
Originally Posted by crazybisu
even if every facilities of ksh are also available in bash.
This is incorrect, ksh has several features bash doesn't implement (and reciprocally). Some I'm missing in bash are:
- co-processes
- FPATH
- floating-point arithmetic (ksh93)
- discipline functions (ksh93)
Also, I find very annoying how command history is handled in bash.
Quote:
Could anyone please explain why it organizations prefer korn shell instead of bash shell.
A mixture of cleverness, pragmatism and inertia ...

---------- Post updated at 15:17 ---------- Previous update was at 14:50 ----------

Quote:
Originally Posted by bakunin
Code:
# mkdir kshtest ; cd kshtest ; touch a ; touch b ; touch c
# typeset x=""
> while read y ; do
>      x="$x $y"
>      echo "$x"
> done < "$(ls)"
> echo "$x"

...
Instead of
Code:
done < "$(ls)"

which makes a syntax errror, you probably want:
Code:
done < <(ls)

or
Code:
done <<< "$(ls)"

or even better because portable (POSIX):
Code:
done << %EOF%
$(ls)
%EOF%

While I share your opinion about the unfortunate bash implementation choice regarding the pipeline subshell, I have to admit ksh behavior is not guaranteed by POSIX, it is just an accepted extension. Portable scripts shouldn't rely on it.
These 2 Users Gave Thanks to jlliagre For This Post:
# 209  
Old 05-14-2012
Quote:
Originally Posted by methyl
Portability and availability.
I get tired of hearing ksh being called "portable" when it's available almost nowhere I go unless I install it myself, and people keep banging their heads on ancient versions which have almost none of the features people like so much about ksh.

If you want shell code to be portable and available, program for neither bash nor ksh, which contain mutually exclusive features, and neither are available everywhere. Program for posix SH.
This User Gave Thanks to Corona688 For This Post:
# 210  
Old 05-14-2012
Quote:
Program for posix SH
Which of the many Posix standards would you chose?

Ps. Veiled in the original question was the implication that ksh was available on all that organisation's servers.
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Pass C shell array to another C shell script(csh) and shell(sh)

Dear Friends, Please help me on this my script name is send.csh In this i have written the statement like this set args = ( city state country price ) I want to pass this array to another c shell called receiver.csh. and i want to use it in this c shell or how to pass to... (2 Replies)
Discussion started by: SA_Palani
2 Replies

2. UNIX for Dummies Questions & Answers

Shell script to read lines in a text file and filter user data Shell Programming and Scripting

sxsaaas (3 Replies)
Discussion started by: VikrantD
3 Replies

3. Shell Programming and Scripting

Any shell or hack that makes the shell command line take vi commands?

basically i'm tired of hitting the left arrow a few dozen times when correcting a mistake or modifying a history command i'd like to use vim style key shortcuts while on the command line so that a 55 moves the cursor 55 places to the left... and i want all the other vi goodies, search of... (3 Replies)
Discussion started by: marqul
3 Replies

4. Shell Programming and Scripting

calling 'n' number of shell scripts based on dependency in one shell script.

Hello gurus, I have three korn shell script 3.1, 3.2, 3.3. I would like to call three shell script in one shell script. i m looking for something like this call 3.1; If 3.1 = "complete" then call 3.2; if 3.2 = ''COMPlete" then call 3.3; else exit The... (1 Reply)
Discussion started by: shashi369
1 Replies

5. Shell Programming and Scripting

simple shell - how to get a parameter typed in a shell script

Hi, I am new to unix and using linux 7.2. I would like to create a script that would make it easyer for me to run my java programms. At the moment I have to type java myJavaprogram I am trying to write a script that will allow me to type something like this "myscript myJavaprogram" or maybe... (4 Replies)
Discussion started by: cmitulescu
4 Replies

6. Shell Programming and Scripting

How to run cmds after changing to a new env (shell) in a shell script

Hi, I am using HP-UNIX. I have a requirement as below I have to change env twice like: cadenv <env> cadenv <env> ccm start -d /dbpath ccm tar -xvf *.tar ccm rcv .... mv *.tar BACKUP but after I do the first cadenv <env> , I am unable to execute any of the later commands . ... (6 Replies)
Discussion started by: charlei
6 Replies

7. Shell Programming and Scripting

Help need to make a shell script run for ffmpeg vhook watermaking in shell

i have a small problem getting a batxh shell script to run in shell this is the code the problem seems to be centered around the ffmpeg command, something maybe to do with the ' ' wrapping around the vhook part command this is a strange problem , if i take the ffmpeg command and... (1 Reply)
Discussion started by: wingchun22
1 Replies

8. Linux

How to Start a Shell as Login shell instead of ordinary shell

Hi I tried with bash --login option. but the output is siva:~$ bash --login siva:~$ is there any way to make the shell ask for user id and password ( and login as different user instead of using sudo / su ) Thx in advance Siva (3 Replies)
Discussion started by: Sivaswami
3 Replies

9. AIX

Difference between writing Unix Shell script and AIX Shell Scripts

Hi, Please give me the detailed Differences between writing Unix Shell script and AIX Shell Scripts. Thanks in advance..... (0 Replies)
Discussion started by: haroonec
0 Replies

10. Shell Programming and Scripting

How to run unix commands in a new shell inside a shell script?

Hi , I am having one situation in which I need to run some simple unix commands after doing "chroot" command in a shell script. Which in turn creates a new shell. So scenario is that - I need to have one shell script which is ran as a part of crontab - in this shell script I need to do a... (2 Replies)
Discussion started by: hkapil
2 Replies
Login or Register to Ask a Question