diff options
author | jan.nijtmans <nijtmans@users.sourceforge.net> | 2017-01-11 10:51:15 (GMT) |
---|---|---|
committer | jan.nijtmans <nijtmans@users.sourceforge.net> | 2017-01-11 10:51:15 (GMT) |
commit | 92c41abbd48f10bdb31acf6b98b7cf6d448c66cc (patch) | |
tree | 68dc8a4d9a6b01fe2552e0189e05f9455cdf9887 | |
parent | aa9bd3dbdd1d48a32b4e6315b190be65d430f57d (diff) | |
download | tk-92c41abbd48f10bdb31acf6b98b7cf6d448c66cc.zip tk-92c41abbd48f10bdb31acf6b98b7cf6d448c66cc.tar.gz tk-92c41abbd48f10bdb31acf6b98b7cf6d448c66cc.tar.bz2 |
Alternative proposed solution for [d4fb4e80d220e46e588f310291fd7a4205e8cd67|d4fb4e80d2], with test-case.
-rw-r--r-- | generic/tkImgPhoto.c | 6 | ||||
-rw-r--r-- | tests/imgPhoto.test | 10 |
2 files changed, 15 insertions, 1 deletions
diff --git a/generic/tkImgPhoto.c b/generic/tkImgPhoto.c index 4ee9f69..1bd0142 100644 --- a/generic/tkImgPhoto.c +++ b/generic/tkImgPhoto.c @@ -1540,7 +1540,11 @@ ParseSubcommandOptions( */ if (!(allowedOptions & bit)) { - goto unknownOrAmbiguousOption; + if (optPtr->name != NULL) { + goto unknownOrAmbiguousOption; + } + optPtr->name = objv[index]; + continue; } /* diff --git a/tests/imgPhoto.test b/tests/imgPhoto.test index db23fea..e93dab4 100644 --- a/tests/imgPhoto.test +++ b/tests/imgPhoto.test @@ -804,6 +804,16 @@ test imgPhoto-4.74 {ImgPhotoCmd procedure: put option error handling} -setup { } -cleanup { image delete photo1 } -returnCodes 1 -result {wrong # args: should be "photo1 put data ?-option value ...?"} +test imgPhoto-4.75 {<photo> read command: filename starting with '-'} -constraints { + hasTeapotPhoto +} -body { + file copy -force $teapotPhotoFile -teapotPhotoFile + image create photo photo1 + photo1 read -teapotPhotoFile +} -cleanup { + image delete photo1 + file delete ./-teapotPhotoFile +} -result {} test imgPhoto-5.1 {ImgPhotoGet/Free procedures, shared instances} -constraints { hasTeapotPhoto |