2022-11-23 17:16:20 +01:00
|
|
|
--- doc/refchan.n.orig
|
|
|
|
+++ doc/refchan.n
|
|
|
|
@@ -53,8 +53,8 @@ here, then the \fBfinalize\fR subcommand
|
|
|
|
.PP
|
|
|
|
The \fImode\fR argument tells the handler whether the channel was
|
|
|
|
opened for reading, writing, or both. It is a list containing any of
|
|
|
|
-the strings \fBread\fR or \fBwrite\fR. The list will always
|
|
|
|
-contain at least one element.
|
|
|
|
+the strings \fBread\fR or \fBwrite\fR. The list may be empty, but
|
|
|
|
+will usually contain at least one element.
|
|
|
|
.PP
|
|
|
|
The subcommand must throw an error if the chosen mode is not
|
|
|
|
supported by the \fIcmdPrefix\fR.
|
|
|
|
--- generic/tclIORChan.c.orig
|
|
|
|
+++ generic/tclIORChan.c
|
2023-03-30 12:58:46 +02:00
|
|
|
@@ -532,7 +532,7 @@ TclChanCreateObjCmd(
|
2022-11-23 17:16:20 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* First argument is a list of modes. Allowed entries are "read", "write".
|
|
|
|
- * Expect at least one list element. Abbreviations are ok.
|
|
|
|
+ * Empty list is uncommon, but allowed. Abbreviations are ok.
|
|
|
|
*/
|
|
|
|
|
|
|
|
modeObj = objv[MODE];
|
2023-03-30 12:58:46 +02:00
|
|
|
@@ -905,6 +905,11 @@ TclChanPostEventObjCmd(
|
|
|
|
if (EncodeEventMask(interp, "event", objv[EVENT], &events) != TCL_OK) {
|
2022-11-23 17:16:20 +01:00
|
|
|
return TCL_ERROR;
|
|
|
|
}
|
2023-03-30 12:58:46 +02:00
|
|
|
+ if (events == 0) {
|
|
|
|
+ Tcl_SetObjResult(interp,
|
|
|
|
+ Tcl_NewStringObj("bad event list: is empty", -1));
|
|
|
|
+ return TCL_ERROR;
|
|
|
|
+ }
|
2022-11-23 17:16:20 +01:00
|
|
|
|
2023-03-30 12:58:46 +02:00
|
|
|
/*
|
|
|
|
* Check that the channel is actually interested in the provided events.
|
|
|
|
@@ -2007,10 +2012,10 @@ ReflectGetOption(
|
2022-11-23 17:16:20 +01:00
|
|
|
* EncodeEventMask --
|
|
|
|
*
|
|
|
|
* This function takes a list of event items and constructs the
|
|
|
|
- * equivalent internal bitmask. The list must contain at least one
|
|
|
|
- * element. Elements are "read", "write", or any unique abbreviation of
|
2023-03-30 12:58:46 +02:00
|
|
|
- * them. Note that the bitmask is not changed if problems are
|
|
|
|
- * encountered.
|
|
|
|
+ * equivalent internal bitmask. The list may be empty but will usually
|
|
|
|
+ * contain at least one element. Valid elements are "read", "write", or
|
|
|
|
+ * any unique abbreviation of them. Note that the bitmask is not changed
|
|
|
|
+ * if problems are encountered.
|
2022-11-23 17:16:20 +01:00
|
|
|
*
|
2023-03-30 12:58:46 +02:00
|
|
|
* Results:
|
|
|
|
* A standard Tcl error code. A bitmask where TCL_READABLE and/or
|
|
|
|
@@ -2040,12 +2045,6 @@ EncodeEventMask(
|
2022-11-23 17:16:20 +01:00
|
|
|
return TCL_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (listc < 1) {
|
2023-03-30 12:58:46 +02:00
|
|
|
- Tcl_SetObjResult(interp, Tcl_ObjPrintf(
|
|
|
|
- "bad %s list: is empty", objName));
|
|
|
|
- return TCL_ERROR;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
events = 0;
|
|
|
|
while (listc > 0) {
|
|
|
|
if (Tcl_GetIndexFromObj(interp, listv[listc-1], eventOptions,
|
2022-11-23 17:16:20 +01:00
|
|
|
--- tests/ioCmd.test.orig
|
|
|
|
+++ tests/ioCmd.test
|
|
|
|
@@ -670,12 +670,12 @@ test iocmd-21.1 {chan create, wrong#args
|
|
|
|
catch {chan create a b c} msg
|
|
|
|
set msg
|
|
|
|
} {wrong # args: should be "chan create mode cmdprefix"}
|
|
|
|
-test iocmd-21.2 {chan create, invalid r/w mode, empty} {
|
|
|
|
- proc foo {} {}
|
|
|
|
- catch {chan create {} foo} msg
|
|
|
|
+test iocmd-21.2 {chan create, r/w mode empty} {
|
2023-03-30 12:58:46 +02:00
|
|
|
+ proc foo {cmd args} { return {initialize finalize watch} }
|
2022-11-23 17:16:20 +01:00
|
|
|
+ set chan [chan create {} foo]
|
|
|
|
+ close $chan
|
|
|
|
rename foo {}
|
|
|
|
- set msg
|
|
|
|
-} {bad mode list: is empty}
|
|
|
|
+} {}
|
|
|
|
test iocmd-21.3 {chan create, invalid r/w mode, bad string} {
|
|
|
|
proc foo {} {}
|
|
|
|
catch {chan create {c} foo} msg
|