|
|
|
#1 |
|
Messages: n/a
Hébergeur: |
CBFalconer wrote:
[...] > You don't need all that confusing local declaration of variables, > etc. Consider: > > int fcopy(char const *dst, char const *src) { > FILE *sf, *df; > int ch > > if (sf = fopen(src, "r") { /* text files */ > if (df = fopen(dst, "w") { > while (EOF != (ch = getc(sf))) putc(ch, df); > fclose(df); > } > fclose(sf); > } > return sf && df; /* non-zero for success */ > } > > which I consider more readable and safer than your version. :-) This is good-weather code, and has nothing to do with "safe" code in production. Just on my first read, I think you need to consider: - fopen failure - getc failure - putc failure far more carefully. -- Tor <torust [at] online [dot] no> "I have stopped reading Stephen King novels. Now I just read C code instead" |
|
|
|
#2 |
|
Messages: n/a
Hébergeur: |
Tor Rustad <tor_rustad@hotmail.com> writes:
> CBFalconer wrote: > [...] > >> You don't need all that confusing local declaration of variables, >> etc. Consider: >> int fcopy(char const *dst, char const *src) { >> FILE *sf, *df; >> int ch >> if (sf = fopen(src, "r") { /* text files */ >> if (df = fopen(dst, "w") { >> while (EOF != (ch = getc(sf))) putc(ch, df); >> fclose(df); >> } >> fclose(sf); >> } >> return sf && df; /* non-zero for success */ >> } >> which I consider more readable and safer than your version. :-) > > This is good-weather code, and has nothing to do with "safe" code in > production. > > Just on my first read, I think you need to consider: > > - fopen failure > - getc failure > - putc failure > > far more carefully. I believe it already handles fopen failure correctly. I agree about getc and putc. -- Keith Thompson (The_Other_Keith) kst-u@mib.org <http://www.ghoti.net/~kst> San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst> "We must do something. This is something. Therefore, we must do this." -- Antony Jay and Jonathan Lynn, "Yes Minister" |
|
|
|
#3 |
|
Messages: n/a
Hébergeur: |
Keith Thompson wrote:
> Tor Rustad <tor_rustad@hotmail.com> writes: >> CBFalconer wrote: >> [...] >> >>> You don't need all that confusing local declaration of variables, >>> etc. Consider: >>> int fcopy(char const *dst, char const *src) { >>> FILE *sf, *df; >>> int ch >>> if (sf = fopen(src, "r") { /* text files */ >>> if (df = fopen(dst, "w") { >>> while (EOF != (ch = getc(sf))) putc(ch, df); >>> fclose(df); >>> } >>> fclose(sf); >>> } >>> return sf && df; /* non-zero for success */ >>> } >>> which I consider more readable and safer than your version. :-) >> This is good-weather code, and has nothing to do with "safe" code in >> production. >> >> Just on my first read, I think you need to consider: >> >> - fopen failure >> - getc failure >> - putc failure >> >> far more carefully. > > I believe it already handles fopen failure correctly. Hmm... I really hate C code like this: return sf && df; OK, I see. 'sf' will be NULL on the first fopen failure, and 'df' is not evaluated. <g> -- Tor <torust [at] online [dot] no> "I have stopped reading Stephen King novels. Now I just read C code instead" |
|
|
|
#4 |
|
Messages: n/a
Hébergeur: |
Keith Thompson wrote:
> Tor Rustad <tor_rustad@hotmail.com> writes: >> CBFalconer wrote: >> [...] >> >>> You don't need all that confusing local declaration of variables, >>> etc. Consider: >>> int fcopy(char const *dst, char const *src) { >>> FILE *sf, *df; >>> int ch >>> if (sf = fopen(src, "r") { /* text files */ >>> if (df = fopen(dst, "w") { >>> while (EOF != (ch = getc(sf))) putc(ch, df); >>> fclose(df); >>> } >>> fclose(sf); >>> } >>> return sf && df; /* non-zero for success */ >>> } >>> which I consider more readable and safer than your version. :-) >> >> This is good-weather code, and has nothing to do with "safe" code in >> production. >> >> Just on my first read, I think you need to consider: >> >> - fopen failure >> - getc failure >> - putc failure >> >> far more carefully. > > I believe it already handles fopen failure correctly. > > I agree about getc and putc. > The code snippet wont compile. |
|
|
|
#5 |
|
Messages: n/a
Hébergeur: |
Keith Thompson wrote:
> Tor Rustad <tor_rustad@hotmail.com> writes: >> CBFalconer wrote: >> [...] >> >>> You don't need all that confusing local declaration of variables, >>> etc. Consider: >>> int fcopy(char const *dst, char const *src) { >>> FILE *sf, *df; >>> int ch >>> if (sf = fopen(src, "r") { /* text files */ >>> if (df = fopen(dst, "w") { >>> while (EOF != (ch = getc(sf))) putc(ch, df); >>> fclose(df); >>> } >>> fclose(sf); >>> } >>> return sf && df; /* non-zero for success */ >>> } >>> which I consider more readable and safer than your version. :-) >> >> This is good-weather code, and has nothing to do with "safe" code in >> production. >> >> Just on my first read, I think you need to consider: >> >> - fopen failure >> - getc failure >> - putc failure >> >> far more carefully. > > I believe it already handles fopen failure correctly. > > I agree about getc and putc. It also handles getc failure. putc failure is not handled. The handling technique is simply to abort the function execution. fopen failure is signalled, the others are not. putc can be handled by "if (EOF != putc(ch, df)) { /* error action */ break; }" and similar testing after the while loop can give details about a getc failure. Most systems don't have any use for all this, and function exit suffices. -- Chuck F (cbfalconer at maineline dot net) Available for consulting/temporary embedded and systems. <http://cbfalconer.home.att.net> -- Posted via a free Usenet account from http://www.teranews.com |
|
|
|
#6 |
|
Messages: n/a
Hébergeur: |
santosh wrote:
> Keith Thompson wrote: >> Tor Rustad <tor_rustad@hotmail.com> writes: >>> CBFalconer wrote: >>> [...] >>> >>>> You don't need all that confusing local declaration of >>>> variables, etc. Consider: >>>> int fcopy(char const *dst, char const *src) { >>>> FILE *sf, *df; >>>> int ch >>>> if (sf = fopen(src, "r") { /* text files */ >>>> if (df = fopen(dst, "w") { >>>> while (EOF != (ch = getc(sf))) putc(ch, df); >>>> fclose(df); >>>> } >>>> fclose(sf); >>>> } >>>> return sf && df; /* non-zero for success */ >>>> } >>>> which I consider more readable and safer than your version. :-) >>> >>> This is good-weather code, and has nothing to do with "safe" >>> code in production. >>> >>> Just on my first read, I think you need to consider: >>> >>> - fopen failure >>> - getc failure >>> - putc failure >>> >>> far more carefully. >> >> I believe it already handles fopen failure correctly. >> >> I agree about getc and putc. > > The code snippet wont compile. Yes, there are a couple of missing ')'s. Penalty for typing into the newsreader. The above errors (apart from putc) already force function termination. -- Chuck F (cbfalconer at maineline dot net) Available for consulting/temporary embedded and systems. <http://cbfalconer.home.att.net> -- Posted via a free Usenet account from http://www.teranews.com |
|
|
|
#7 |
|
Messages: n/a
Hébergeur: |
CBFalconer <cbfalconer@yahoo.com> writes:
> Keith Thompson wrote: [...] >>> CBFalconer wrote: >>> [...] >>>> You don't need all that confusing local declaration of variables, >>>> etc. Consider: >>>> int fcopy(char const *dst, char const *src) { >>>> FILE *sf, *df; >>>> int ch >>>> if (sf = fopen(src, "r") { /* text files */ >>>> if (df = fopen(dst, "w") { >>>> while (EOF != (ch = getc(sf))) putc(ch, df); >>>> fclose(df); >>>> } >>>> fclose(sf); >>>> } >>>> return sf && df; /* non-zero for success */ >>>> } >>>> which I consider more readable and safer than your version. :-) [snip] >> I believe it already handles fopen failure correctly. >> >> I agree about getc and putc. > > It also handles getc failure. putc failure is not handled. The > handling technique is simply to abort the function execution. > fopen failure is signalled, the others are not. > > putc can be handled by "if (EOF != putc(ch, df)) { > /* error action */ > break; > }" > > and similar testing after the while loop can give details about a > getc failure. Most systems don't have any use for all this, and > function exit suffices. It doesn't distinguish between an error in getc() and reaching end-of-file. putc() can fail if, for example, the target file system is full. This is an important condition to check. Such a failure can also show up in fclose(), which should also be checked. -- Keith Thompson (The_Other_Keith) kst-u@mib.org <http://www.ghoti.net/~kst> San Diego Supercomputer Center <*> <http://users.sdsc.edu/~kst> "We must do something. This is something. Therefore, we must do this." -- Antony Jay and Jonathan Lynn, "Yes Minister" |
|
![]() |
| Outils de la discussion | |
|
|