diff --git a/winsup/mingw/ChangeLog b/winsup/mingw/ChangeLog index 983e2b23c..1037598ea 100644 --- a/winsup/mingw/ChangeLog +++ b/winsup/mingw/ChangeLog @@ -1,3 +1,13 @@ +2008-09-19 Keith Marshall + + Fix MinGW-Bug [2119504]. + (Reported by Peiyuan Song). + + * mingwex/getopt.c (getopt_resolved): Do not overwrite... + (*retindex): ...this already correctly assigned return variable... + (opt[index].val): ...with this; this should have been assigned to... + (*opt[index].flag) [opt[index].flag != NULL]: ...this instead. + 2008-09-19 Keith Marshall Fix MinGW-Bug [2117379]. diff --git a/winsup/mingw/mingwex/getopt.c b/winsup/mingw/mingwex/getopt.c index 40016ad3c..86fc5c615 100644 --- a/winsup/mingw/mingwex/getopt.c +++ b/winsup/mingw/mingwex/getopt.c @@ -283,12 +283,12 @@ struct option *opt, int index, int *retindex, const CHAR *optstring ) /* when the caller has provided a return buffer ... */ - if( retindex != NULL ) + if( opt[index].flag != NULL ) { /* ... then we place the proper return value there, * and return a status code of zero ... */ - *retindex = opt[index].val; + *(opt[index].flag) = opt[index].val; return 0; } /* ... otherwise, the return value becomes the status code.