diff options
Diffstat (limited to 'generic/tclScan.c')
| -rw-r--r-- | generic/tclScan.c | 80 | 
1 files changed, 55 insertions, 25 deletions
| diff --git a/generic/tclScan.c b/generic/tclScan.c index c862be4..4dfc2d6 100644 --- a/generic/tclScan.c +++ b/generic/tclScan.c @@ -261,6 +261,10 @@ ValidateFormat(      int objIndex, xpgSize, nspace = numVars;      int *nassign = TclStackAlloc(interp, nspace * sizeof(int));      char buf[TCL_UTF_MAX+1]; +    Tcl_Obj *errorMsg;		/* Place to build an error messages. Note that +				 * these are messy operations because we do +				 * not want to use the formatting engine; +				 * we're inside there! */      /*       * Initialize an array that records the number of times a variable is @@ -328,9 +332,10 @@ ValidateFormat(  	gotSequential = 1;  	if (gotXpg) {  	mixedXPG: -	    Tcl_SetResult(interp, +	    Tcl_SetObjResult(interp, Tcl_NewStringObj(  		    "cannot mix \"%\" and \"%n$\" conversion specifiers", -		    TCL_STATIC); +		    -1)); +	    Tcl_SetErrorCode(interp, "TCL", "FORMAT", "MIXEDSPECTYPES", NULL);  	    goto error;  	} @@ -374,9 +379,10 @@ ValidateFormat(  	switch (ch) {  	case 'c':  	    if (flags & SCAN_WIDTH) { -		Tcl_SetResult(interp, +		Tcl_SetObjResult(interp, Tcl_NewStringObj(  			"field width may not be specified in %c conversion", -			TCL_STATIC); +			-1)); +		Tcl_SetErrorCode(interp, "TCL", "FORMAT", "BADWIDTH", NULL);  		goto error;  	    }  	    /* @@ -387,9 +393,12 @@ ValidateFormat(  	    if (flags & (SCAN_LONGER|SCAN_BIG)) {  	    invalidFieldSize:  		buf[Tcl_UniCharToUtf(ch, buf)] = '\0'; -		Tcl_AppendResult(interp, -			"field size modifier may not be specified in %", buf, -			" conversion", NULL); +		errorMsg = Tcl_NewStringObj( +			"field size modifier may not be specified in %", -1); +		Tcl_AppendToObj(errorMsg, buf, -1); +		Tcl_AppendToObj(errorMsg, " conversion", -1); +		Tcl_SetObjResult(interp, errorMsg); +		Tcl_SetErrorCode(interp, "TCL", "FORMAT", "BADSIZE", NULL);  		goto error;  	    }  	    /* @@ -397,17 +406,21 @@ ValidateFormat(  	     */  	case 'd':  	case 'e': +	case 'E':  	case 'f':  	case 'g': +	case 'G':  	case 'i':  	case 'o':  	case 'x': +	case 'X':  	case 'b':  	    break;  	case 'u':  	    if (flags & SCAN_BIG) { -		Tcl_SetResult(interp, -			"unsigned bignum scans are invalid", TCL_STATIC); +		Tcl_SetObjResult(interp, Tcl_NewStringObj( +			"unsigned bignum scans are invalid", -1)); +		Tcl_SetErrorCode(interp, "TCL", "FORMAT", "BADUNSIGNED",NULL);  		goto error;  	    }  	    break; @@ -442,13 +455,18 @@ ValidateFormat(  	    }  	    break;  	badSet: -	    Tcl_SetResult(interp, "unmatched [ in format string", -		    TCL_STATIC); +	    Tcl_SetObjResult(interp, Tcl_NewStringObj( +		    "unmatched [ in format string", -1)); +	    Tcl_SetErrorCode(interp, "TCL", "FORMAT", "BRACKET", NULL);  	    goto error;  	default:  	    buf[Tcl_UniCharToUtf(ch, buf)] = '\0'; -	    Tcl_AppendResult(interp, "bad scan conversion character \"", buf, -		    "\"", NULL); +	    errorMsg = Tcl_NewStringObj( +		    "bad scan conversion character \"", -1); +	    Tcl_AppendToObj(errorMsg, buf, -1); +	    Tcl_AppendToObj(errorMsg, "\"", -1); +	    Tcl_SetObjResult(interp, errorMsg); +	    Tcl_SetErrorCode(interp, "TCL", "FORMAT", "BADTYPE", NULL);  	    goto error;  	}  	if (!(flags & SCAN_SUPPRESS)) { @@ -492,9 +510,10 @@ ValidateFormat(      }      for (i = 0; i < numVars; i++) {  	if (nassign[i] > 1) { -	    Tcl_SetResult(interp, +	    Tcl_SetObjResult(interp, Tcl_NewStringObj(  		    "variable is assigned by multiple \"%n$\" conversion specifiers", -		    TCL_STATIC); +		    -1)); +	    Tcl_SetErrorCode(interp, "TCL", "FORMAT", "POLYASSIGNED", NULL);  	    goto error;  	} else if (!xpgSize && (nassign[i] == 0)) {  	    /* @@ -502,9 +521,10 @@ ValidateFormat(  	     * and/or numVars != 0), then too many vars were given  	     */ -	    Tcl_SetResult(interp, +	    Tcl_SetObjResult(interp, Tcl_NewStringObj(  		    "variable is not assigned by any conversion specifiers", -		    TCL_STATIC); +		    -1)); +	    Tcl_SetErrorCode(interp, "TCL", "FORMAT", "UNASSIGNED", NULL);  	    goto error;  	}      } @@ -514,12 +534,14 @@ ValidateFormat(    badIndex:      if (gotXpg) { -	Tcl_SetResult(interp, "\"%n$\" argument index out of range", -		TCL_STATIC); +	Tcl_SetObjResult(interp, Tcl_NewStringObj( +		"\"%n$\" argument index out of range", -1)); +	Tcl_SetErrorCode(interp, "TCL", "FORMAT", "INDEXRANGE", NULL);      } else { -	Tcl_SetResult(interp, +	Tcl_SetObjResult(interp, Tcl_NewStringObj(  		"different numbers of variable names and field specifiers", -		TCL_STATIC); +		-1)); +	Tcl_SetErrorCode(interp, "TCL", "FORMAT", "FIELDVARMISMATCH", NULL);      }    error: @@ -724,6 +746,7 @@ Tcl_ScanObjCmd(  	    parseFlag |= TCL_PARSE_OCTAL_ONLY | TCL_PARSE_SCAN_PREFIXES;  	    break;  	case 'x': +	case 'X':  	    op = 'i';  	    parseFlag |= TCL_PARSE_HEXADECIMAL_ONLY;  	    break; @@ -739,7 +762,9 @@ Tcl_ScanObjCmd(  	case 'f':  	case 'e': +	case 'E':  	case 'g': +	case 'G':  	    op = 'f';  	    break; @@ -991,9 +1016,14 @@ Tcl_ScanObjCmd(  		continue;  	    }  	    result++; -	    if (Tcl_ObjSetVar2(interp, objv[i+3], NULL, objs[i], 0) == NULL) { -		Tcl_AppendResult(interp, "couldn't set variable \"", -			TclGetString(objv[i+3]), "\"", NULL); + +	    /* +	     * In case of multiple errors in setting variables, just report +	     * the first one. +	     */ + +	    if (Tcl_ObjSetVar2(interp, objv[i+3], NULL, objs[i], +		    (code == TCL_OK) ? TCL_LEAVE_ERR_MSG : 0) == NULL) {  		code = TCL_ERROR;  	    }  	    Tcl_DecrRefCount(objs[i]); @@ -1039,7 +1069,7 @@ Tcl_ScanObjCmd(      }      return code;  } - +  /*   * Local Variables:   * mode: c | 
