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
cr_perror(3)						     Library Functions Manual						      cr_perror(3)

NAME
cr_perror - print a libcrash error or warning message SYNOPSIS
DESCRIPTION
prints to standard error an error or warning message corresponding to error, which should be the return value from an immediately previous call to one of the libcrash calls. The message describes the problem that occurred, explains its implications when appropriate, and gives corrective action where appropriate. If called with a zero error value, indicating success, prints nothing. Therefore, it can be called after each libcrash call without harm. (If called after with the flag set, repeated error messages may result.) crash_cb should be the same crash dump descriptor as was passed to the call that returned error. If the call was pass the crash dump descriptor returned by that call, even if it is NULL. If error is indicating that the system variable contains the error information, will refer to to print the appropriate message. In these cases it is critical that be called immediately after the offending libcrash call returns. AUTHOR
was developed by HP. SEE ALSO
cr_open(3), cr_verify(3), libcrash(5). cr_perror(3)
All times are GMT -4. The time now is 03:37 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy