summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornijtmans@users.sourceforge.net <jan.nijtmans>2017-01-11 10:51:15 (GMT)
committernijtmans@users.sourceforge.net <jan.nijtmans>2017-01-11 10:51:15 (GMT)
commita59604a7c466f09bd2756fcc568c044cbba7dd79 (patch)
tree68dc8a4d9a6b01fe2552e0189e05f9455cdf9887
parentb1caabe329c6e8ee762ae50d31c663627feacd94 (diff)
downloadtk-a59604a7c466f09bd2756fcc568c044cbba7dd79.zip
tk-a59604a7c466f09bd2756fcc568c044cbba7dd79.tar.gz
tk-a59604a7c466f09bd2756fcc568c044cbba7dd79.tar.bz2
Alternative proposed solution for [d4fb4e80d220e46e588f310291fd7a4205e8cd67|d4fb4e80d2], with test-case.
-rw-r--r--generic/tkImgPhoto.c6
-rw-r--r--tests/imgPhoto.test10
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