former33t has asked for the wisdom of the Perl Monks concerning the following question:
The shell command looks like this:
MyDbQueryProgram "SELECT * FROM MY_TABLE;"
It runs fine from the command line, but I'm having a bear of a time getting it to work from POE. Any ideas on how to escape the string here? POE::Wheel::Run does a "sh -c" to run the command. Just running from the shell, this works:
sh -c 'MyDbQueryProgram "SELECT * FROM MY_TABLE;"'
Does anyone have any ideas? Thanks in advance for your help.
#!/usr/bin/perl use warnings; use strict; use POE; use POE::Wheel::Run; use POE::Filter::Line; use POE::Filter::Stream; $| = 1; my $outCT = 0; my $program = "MyDbQueryProgram"; my @progargs = ("SELECT * FROM MY_TABLE;"); POE::Session->create( inline_states => { _start => \&startup, stdout => \&stdout, stdin => \&stdin, stderr => \&stderr, } ); POE::Kernel->run(); sub startup { my $heap = $_[HEAP]; my $wheel = POE::Wheel::Run->new( Program => $program, ProgramArgs => \@progargs, StdinEvent => 'stdin', StderrEvent => 'stderr', StdoutEvent => "stdout", StdoutFilter => POE::Filter::Stream->new(), ); print "Wheel ID is ".$wheel->ID."\n"; print "Wheel's PID is ".$wheel->PID."\n"; $heap->{program} = $wheel; } sub stdout { my ($heap, $input, $wheelID) = @_[HEAP, ARG0, ARG1]; print "$input\n"; $outCT++; print $outCT; } sub stderr { my ($op, $errnum, $errstr, $wheel_id) = @_[ARG0, ARG1, ARG2, ARG3]; print "stderr\n"; print "OP = $op\nERRNUM = $errnum\nERRSTR = $errstr\nID = $wheel_id\n +"; } sub stdin { print "stdin\n"; }
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: database query with POE::Wheel::Run
by Corion (Patriarch) on Aug 16, 2007 at 21:29 UTC | |
|
Re: database query with POE::Wheel::Run
by rcaputo (Chaplain) on Aug 16, 2007 at 21:34 UTC | |
by finidi20 (Initiate) on Oct 08, 2013 at 00:51 UTC | |
by rcaputo (Chaplain) on Sep 25, 2016 at 06:09 UTC |