Okay, you have part of it right...

It's true that you can run a native *PGM object by fully-qualifying it. As you stated, you can in fact run a program like this:

/QSYS.LIB/SOMELIB.LIB/SOMEPGM.PGM

That's a fully qualified call... and it's more or less equivalent to doing the following in the native environment:

CALL PGM(SOMELIB/SOMEPGM)

However, it's not the full story. As you know, in the native environment, if I don't qualify the program name (i.e. I specify CALL PGM(SOMEPGM) without the library qualifier) the system will use the library list to find the program.

QShell (or, really, any Unix shell) has something similar. Of course, it uses IFS path names rather than libraries, but... it has something similar, it's called the PATH. The main difference between PATH and *LIBL is that PATH is only used when calling programs. It's not used for files or other object types like *LIBL is.

So when you type just "ls" at the QShell prompt, it actually searches the PATH to find it. You can view your current path by typing:

echo $PATH

Echo is a QShell program that prints it's parameters on the screen. You're passing one parameter, which is $PATH. $ is a special character in Unix shells, it means 'insert a variable value here.' So I've told it to insert the value of the PATH variable... thus echo will print the contents of that variable.

By default, IBM ships QShell's PATH set to only one directory, /usr/bin. So when you type 'ls' (without qualifying it with a directory name) it will look for a program named 'ls' in the /usr/bin directory of the IFS.

To see the ls object in the /usr/bin directory, you could type the following (in QShell):

ls -l /usr/bin/ls

The output would look something like this:

lrwxrwxrwx 1 QSYS 0 27 Mar 27 2001 /usr/bin/ls ->
/QSYS.LIB/QSHELL.LIB/LS.PGM

The -> means that it's a symbolic link. So /usr/bin/ls is actually a symbolic link to /QSYS.LIB/QSHELL.LIB/LS.PGM. Therefore, if you type 'ls' by itself, it results in CALL PGM(QSHELL/LS). But perhaps it was for a different reason than you originally thought. It doesn't just "automatically go to the QSHELL library", but rather it follows the PATH, resulting in the symbolic link that ultimately leads to the QSHELL library.

This behavior is really useful if you want to create your own QShell utilities. For example, you might do this (from QShell):

$
> mkdir -p /usr/local/bin
$
> ln -s /qsys.lib/somelib.lib/somepgm.pgm /usr/local/bin/somepgm
$
> export PATH=$PATH:/usr/local/bin
$

At this point, you've created a /usr/local/bin directory ("local" is for stuff that's not included with the OS -- so it makes sense to put the stuff you create into the /usr/local/bin directory -- or at least, that's the norm on Unix systems.)

In the /usr/local/bin directory, I've added a new symbolic link that makes /usr/local/bin/somepgm point to SOMELIB/SOMEPGM.

And finally, I've added (for this QShell session only) the /usr/local/bin to the end of my PATH.

Now that I've done that, I can run the 'somepgm' program simply by typing:

$
> somepgm
$

And QShell will run the somepgm that's located in the SOMELIB library. I no longer have to fully qualify the directory name that the program is in.

Furthermore, QShell is _also_ capable of running PASE programs (Assumimg that PASE has been installed.) When you run a PASE program (either by fully qualifying it, or by putting a directory containing PASE software into your PATH) QShell will see that the object is an AIX program, and will automatically invoke PASE for you -- thus letting you run AIX software from QShell.

QShell also takes care of converting any parameters or stdin data from EBCDIC to ASCII before it calls the PASE program, and it converts it back to EBCDIC when it's done.

So QShell isn't just an easy way to run native programs, it's also an easy way to run AIX/PASE programs.


On 11/10/2010 10:38 PM, Ryan Watkins wrote:
Just to clarify....I

Issuing the LS (or ls) command from QSHELL actually calls the LS
program (*PGM) object in library QSHELL behind the scenes.

And like Scott said, you can run any native IBM i programs directly from
QSHELL like this for example:

/qsys.lib/somelib.lib/somepgm.pgm

Ryan Watkins


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.