| 
|  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  | There's no cd program in my system. I suppose that's because what this
program is supposed to do is to change something internal to a
process; the shell in this case.
Is there a way to overcome this? I'd like to run a program that
changes my current working directory. I don't want to do it through my
shell's language.
 Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  | 
| From: clipka Subject: Re: how to change the cwd of a running shell?
 Date: 22 Aug 2009 21:23:57
 Message: <4a909a2d@news.povray.org>
 
 |  |  |  |  |  |  |  |  |  
|  |  | Daniel Bastos schrieb:
> Is there a way to overcome this? I'd like to run a program that
> changes my current working directory. I don't want to do it through my
> shell's language.
You can /only/ do it through your shell's language.
The current working directory is part of the so-called "environment" of 
a process (i.e. a running program) - a collection of various information 
that is local to the process; there is exactly one situation where one 
process has control over another's environment: A new process will 
always start with its environment set to the same values as the process 
which started it. Aside from that, no process can tamper with the 
environment of another process - so no external program your shell could 
possibly start would have the ability to change the shell's working 
directory.
You will not find a "cd" command on /any/ Unix machine - it only exists 
as a built-in shell command.
(Assuming you're talking about some Unix variant here; but I guess other 
multitasking OS will handle the CWD in a similar fashion.)
 Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  | In article <4a909a2d@news.povray.org>,
clipka wrote:
[...]
> You will not find a "cd" command on /any/ Unix machine - it only exists 
> as a built-in shell command.
That makes sense. I will then give the shell the information, and have
it execute. I suppose I can insert an environment variable back to the
shell, somehow? For instance,
./setvar var value
%echo $var
value
I hope this can work, somehow.
 Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  | Daniel Bastos wrote:
> I hope this can work, somehow.
No. What you want to look at is the command called "source".
If you want to arbitrarily change the shell's behavior, and your program is 
called "xyz", then what you want is the commands
% ./xyz ; source ./pdq
and then have your "xyz" program output a file of shell commands (with 
setvar and cd and such) to a file called "pdq".  Environment variables are 
like the working directory - they are copied per-process.
Wow, that was surprisingly easy to find. I expected to spend 10 minutes 
coming up with the right google terms, even already knowing how all this 
works. Check this out:
http://perl.plover.com/yak/commands/
Note that the "source" command basically says "Here's a shell script - don't 
fork before interpreting it." Note also that many bits of this are different 
in Windows, DOS, etc.  Note also that if it's your program for which you're 
setting up the environment this way, you're doing it wrong. (I.e., if you 
stick stuff in "environment variables" that change on a per-program basis, 
that's not really part of your "environment", and that's exactly why you're 
having those troubles. Just as a philosophical point.)
Hope that helps you understand things.
-- 
   Darren New, San Diego CA, USA (PST)
   Understanding the structure of the universe
    via religion is like understanding the
     structure of computers via Tron.
Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  | 
| From: Jim Henderson Subject: Re: how to change the cwd of a running shell?
 Date: 23 Aug 2009 00:55:17
 Message: <4a90cbb5@news.povray.org>
 
 |  |  |  |  |  |  |  |  |  
|  |  | On Sat, 22 Aug 2009 23:27:36 -0400, Daniel Bastos wrote:
>  I suppose I can insert an environment variable back to the shell,
> somehow?
Generally no, because the current working directory isn't "set" by the 
shell, rather the CWD variable is set by changing the directory.  IOW, 
it's a "status" value, not a "push" value.
Jim
 Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  | 
| From: clipka Subject: Re: how to change the cwd of a running shell?
 Date: 23 Aug 2009 03:59:20
 Message: <4a90f6d8@news.povray.org>
 
 |  |  |  |  |  |  |  |  |  
|  |  | Daniel Bastos schrieb:
> That makes sense. I will then give the shell the information, and have
> it execute. I suppose I can insert an environment variable back to the
> shell, somehow? For instance,
> 
> ./setvar var value
> 
> %echo $var
> value
> 
> I hope this can work, somehow.
As Darren and Jim have pointed out already, the way via environment 
variables suffers from the same problem as the working directory itself: 
They're part of the process environment (hence the name ;-)).
In Unix, there are two (well, three) standard ways to get information 
out of a program to the calling shell:
(1) exit code:
This is an integer value returned by every program, usually used to 
indicate success (=zero) or failure (=nonzero, the particular value 
often indicating the reason for the failure), which a standard shell 
will typically expose via the $? (pseudo-) environment variable; most 
shells also feature built-in flow-control commands that take a command 
to be executed and directly evaluate the exit code, such as:
   if foo
   then
     ...
   else
     ...
   fi
(i.e. execute foo, and depending on its exit code do diffent things) or 
other shorthand forms, such as:
   foo && bar
meaning "try executing foo; if it succeeds (exit code != 0), execute bar 
as well".
(2a) standard output stream:
This is /the/ standard method of getting bulk data out of a program 
(again, this is why it's called that way). Virtually all shells will 
have some way of doing smart things with the data (usually text) some 
program sends to its standard output:
- Display it (this is the default)
- Redirect it to the standard input stream of another program 
("piping"); this is often used with filter or conversion program (grep 
or sed, for instance) - which in turn send the results to their own 
standard out, which can be processed further by a third command... The 
syntax would be:
   foo | bar | ...
- Store (or append) it to a file:
   foo > bar.txt
   foo >> bar.txt
- Store it in an environment variable(!):
   bar=`foo`
   bar=$(foo)
both instructing the shell to "execute foo, and store its output in your 
environment variable bar" (the second is bash syntax; I don't know 
whether it is supported by other common shells as well).
(2b) standard error stream:
This is just like standard output, except that it's intended as a 
separate channel for diagnostic information (including - but not 
necessarily limited to - error messages), so that it can be 
distinguished from "proper" output.
So to come back to your sample script:
 > ./setvar var value
 >
 > %echo $var
 > value
this can be easily done using:
   var=`echo value`
   echo "changing to directory '$var'"
   cd "$var"
which will output "changing to directory 'value'" and do exactly that.
Or your program foo might output "dir=value" somewhere in its output 
stream, which you could then evaluate using:
   var=`foo | grep -e '^dir=' | sed -e 's/^dir=//'`
   echo "changing to directory '$var'"
   cd "$var"
The first line instructs the shell to run "foo", hand its output over to 
the command "grep" instructing it to output only lines starting with 
"dir=", pass grep's output on to the command "sed" instructing it to 
substitute any leading "dir=" with an empty string (i.e. strip all 
leading "dir="), and ultimately store the resulting output in the 
shell's environment variable "var".
Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  | clipka wrote:
> if it succeeds (exit code != 0),
Technically, exit code == 0 means success, on the grounds that there's only 
one success but multiple possible failures.  C function calls tend to work 
the other way, with one failure and multiple possible successes.
-- 
   Darren New, San Diego CA, USA (PST)
   Understanding the structure of the universe
    via religion is like understanding the
     structure of computers via Tron.
Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |  |  
|  |  | Darren New schrieb:
>> if it succeeds (exit code != 0),
> 
> Technically, exit code == 0 means success, on the grounds that there's 
> only one success but multiple possible failures.  C function calls tend 
> to work the other way, with one failure and multiple possible successes.
Darn - indeed, got it wrong way round there. Should have proofread more.
 Post a reply to this message
 |  |  |  |  |  |  |  |  
|  |  |  |  |  |  |  |  |  |