Sponsored Content
Top Forums Programming [C language] system function print output when not expected. Post 302418447 by ejdv on Tuesday 4th of May 2010 10:03:29 AM
Old 05-04-2010
[C language] system function print output when not expected.

Hi,

I am new to C and have a little problem.
I am not planning to be a C expert, but this would be nice to understand.

The problem is that a 'system' call prints it output to stdout, when I do not expect this.

This is the program:

trial.c

Code:
#include <ctype.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>


int main() {

fprintf(stdout, "-> main()\n");

int return_value;
char passing_var[9];

strcpy(passing_var, "datum");

fprintf(stdout, "main() passing_var  = %s\n",passing_var);

return_value=date(passing_var);

fprintf(stdout, "main() return_value = %s\n",return_value);
fprintf(stdout, "<- main()\n");

}


int date(char *passing_var) {

fprintf(stdout, "-> date()\n");
fprintf(stdout, "date() passing_var  = %s\n",passing_var);

char command[128];
int date_return;

strcpy(command, "date");

fprintf(stdout, "date() command      = %s\n",command);

date_return=system(command);

fprintf(stdout, "date() date_return  = %s\n",date_return);
fprintf(stdout, "<- date()\n");

return date_return;

}

This is the output:

# ./trial

Code:
-> main()
main() passing_var  = datum
-> date()
date() passing_var  = datum
date() command      = date
Tue May  4 13:53:42 GMT 2010
date() date_return  =
<- date()
main() return_value =
<- main()

I do not understand why the 'date' output is printed in the 'date()' subroutine and not given to the 'date_value' variable.

Probably wrong declarations and other mistakes.

Can someone help and shine a light on this ?

Many thanks in advance,

E.J.
 

9 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk not generating the expected output

Hi, I am presently stuck in a csv file. INPUT CSV baseball,NULL,8798765,Most played baseball,NULL,8928192,Most played baseball,NULL,5678945,Most played cricket,NOTNULL,125782,Usually played cricket,NOTNULL,678921,Usually played EXPECTED OUTPUT CSV ... (7 Replies)
Discussion started by: scripter12
7 Replies

2. Shell Programming and Scripting

Print records which do not have expected number of fields in a comma delimited file

Hi, I have a comma (,) delimited file, in which few fields are enclosed with in double quotes " ". I have to print the records in the file which donot have expected number of field with the line number. File1 ==== name,desgnation,doj,project #header#... (7 Replies)
Discussion started by: machomaddy
7 Replies

3. Shell Programming and Scripting

Output is not comming as expected

Hi All, I am in middle of one script. I want output in the form of xls file. There are 4 fields - user name, email Id, full name, date of birth. I want these details to get in seperate columns. But, i am getting it in the single cell and as like a paragraph.:mad: Please suggest me some... (8 Replies)
Discussion started by: Agupte
8 Replies

4. Shell Programming and Scripting

Not getting expected output

Hi I have written below script to get the data in table form. #!/bin/sh echo "File Name\tType" for i in *; do echo "$i\t\c" if ; then echo "directory" elif ; then echo "symbolic link" elif ; then echo "file" else echo "unknown" fi donehowever i am getting output in different way... (3 Replies)
Discussion started by: scriptor
3 Replies

5. Shell Programming and Scripting

Grep can't match expected but output all

lyang001@lyang001-OptiPlex-9010:~$ service --status-all |grep dbus acpid acpi-support alsa-restore alsa-store anacron apport atd avahi-daemon bluetooth cgroup-lite console-setup cron cups dbus dmesg dns-clean failsafe-x ... (1 Reply)
Discussion started by: yanglei_fage
1 Replies

6. Shell Programming and Scripting

How to capture system() function output in variable

How to capture system() function output in awk variable and the print that awk variable..... (8 Replies)
Discussion started by: bharat1211
8 Replies

7. Shell Programming and Scripting

awk output not what was expected

Good Moring, I am currently reading about awk in a manual and following the examples using the oratab file. My system is SOLARIS 10 I think I am getting strange behavior judging by what the book says to do and what I am getting with my little program. Here is my program: grep -v oratab |... (4 Replies)
Discussion started by: bdby
4 Replies

8. Shell Programming and Scripting

For loop not giving expected output

#cat /tmp/input old_array old_dev new_dev new_array 0577 008AB 01744 0125 0577 008AC 01745 0125 0577 008AD 005C8 0125 0577 008AE 005C9 0125 0577 008AF 005CA 0125 0577 008B0 005CB 0125 0577 008B1 005CC 0125 cat test.sh #!/bin/ksh... (4 Replies)
Discussion started by: mbak
4 Replies

9. Shell Programming and Scripting

awk not giving the output expected

Hello, I am practising awk and decided to compare two columns and print the result of the comparison as third column i/p data c1,c2,c3 1,a,b 1,b,b i am trying to compare the last two columns and if they match I am trying to print match else mismatch(Ideally i want that as a last column... (5 Replies)
Discussion started by: mkathi
5 Replies
trpt(8c)																  trpt(8c)

Name
       trpt - transliterate protocol trace

Syntax
       trpt [ -a ] [ -s ]  [ -t ] [ -j ] [ -p hex-address ] [ system [ core ] ]

Description
       The command interrogates the buffer of TCP trace records created when a socket is marked for debugging and prints a readable description of
       these records.

Options
       When no options are supplied, prints all the trace records found in the system grouped according to TCP connection protocol  control  block
       (PCB).  The following options may be used to alter this behavior:

       -s     In addition to the normal output, prints a detailed description of the packet sequencing information.

       -t     In addition to the normal output, prints the values for all timers at each point in the trace.

       -j     Gives a list of the protocol control block addresses for which there are trace records.

       -p     Shows only trace records associated with the protocol control block whose address follows.

       -a     In addition to the normal output, prints the values of the source and destination addresses for each packet recorded.

       The recommended use of is to isolate the problem and enable debugging on the socket(s) involved in the connection.  Find the address of the
       protocol control blocks associated with the sockets using the -A option to Then run with the -p option, supplying the  associated  protocol
       control block addresses.  If there are many sockets using the debugging option, the -j option may be useful in checking to see if any trace
       records are present for the socket in question.

       If debugging is being performed on a system or core file other than the default, the last  two  arguments  may  be  used  to  supplant  the
       defaults.

Diagnostics
       no namelist
       The system image does not contain the proper symbols to find the trace buffer.

       Other diagnostic messages are self-explanatory.

Files
See Also
       netstat(1), setsockopt(2)

																	  trpt(8c)
All times are GMT -4. The time now is 02:48 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy