mirror of
https://github.com/QB64-Phoenix-Edition/QB64pe.git
synced 2024-07-01 13:50:36 +00:00
Improves console output in verbose mode.
This commit is contained in:
parent
9755992de9
commit
4dd5d11c8c
240
source/qb64.bas
240
source/qb64.bas
|
@ -104,7 +104,7 @@ TYPE usedVarList
|
||||||
END TYPE
|
END TYPE
|
||||||
|
|
||||||
REDIM SHARED usedVariableList(1000) AS usedVarList, totalVariablesCreated AS LONG
|
REDIM SHARED usedVariableList(1000) AS usedVarList, totalVariablesCreated AS LONG
|
||||||
DIM SHARED totalUnusedVariables AS LONG, bypassNextVariable AS _BYTE
|
DIM SHARED bypassNextVariable AS _BYTE
|
||||||
DIM SHARED totalWarnings AS LONG, warningListItems AS LONG, lastWarningHeader AS STRING
|
DIM SHARED totalWarnings AS LONG, warningListItems AS LONG, lastWarningHeader AS STRING
|
||||||
DIM SHARED duplicateConstWarning AS _BYTE, warningsissued AS _BYTE
|
DIM SHARED duplicateConstWarning AS _BYTE, warningsissued AS _BYTE
|
||||||
DIM SHARED emptySCWarning AS _BYTE
|
DIM SHARED emptySCWarning AS _BYTE
|
||||||
|
@ -1130,6 +1130,7 @@ f$ = LTRIM$(RTRIM$(f$))
|
||||||
IF FileHasExtension(f$) = 0 THEN f$ = f$ + ".bas"
|
IF FileHasExtension(f$) = 0 THEN f$ = f$ + ".bas"
|
||||||
|
|
||||||
sourcefile$ = f$
|
sourcefile$ = f$
|
||||||
|
CMDLineFile = sourcefile$
|
||||||
'derive name from sourcefile
|
'derive name from sourcefile
|
||||||
f$ = RemoveFileExtension$(f$)
|
f$ = RemoveFileExtension$(f$)
|
||||||
|
|
||||||
|
@ -1417,7 +1418,6 @@ subfunc = ""
|
||||||
SelectCaseCounter = 0
|
SelectCaseCounter = 0
|
||||||
ExecCounter = 0
|
ExecCounter = 0
|
||||||
UserDefineCount = 6
|
UserDefineCount = 6
|
||||||
totalUnusedVariables = 0
|
|
||||||
totalVariablesCreated = 0
|
totalVariablesCreated = 0
|
||||||
totalWarnings = 0
|
totalWarnings = 0
|
||||||
duplicateConstWarning = 0
|
duplicateConstWarning = 0
|
||||||
|
@ -1571,7 +1571,7 @@ IF idemode THEN GOTO ideret1
|
||||||
|
|
||||||
IF NOT QuietMode THEN
|
IF NOT QuietMode THEN
|
||||||
PRINT
|
PRINT
|
||||||
PRINT "Beginning C++ output from QB64 code... ";
|
PRINT "Beginning C++ output from QB64 code... "
|
||||||
END IF
|
END IF
|
||||||
|
|
||||||
lineinput3load sourcefile$
|
lineinput3load sourcefile$
|
||||||
|
@ -2153,51 +2153,7 @@ DO
|
||||||
END IF
|
END IF
|
||||||
IF issueWarning THEN
|
IF issueWarning THEN
|
||||||
IF NOT IgnoreWarnings THEN
|
IF NOT IgnoreWarnings THEN
|
||||||
addWarning 0, 0, 0, "", "Constant already defined (same value):"
|
addWarning linenumber, inclevel, inclinenumber(inclevel), incname$(inclevel), "duplicate constant definition", n$ + " =" + thisconstval$
|
||||||
addWarning linenumber, inclevel, inclinenumber(inclevel), incname$(inclevel), n$ + " =" + thisconstval$
|
|
||||||
IF idemode = 0 AND NOT QuietMode THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 5
|
|
||||||
IF duplicateConstWarning = 0 THEN PRINT: PRINT "Warning: ";
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
PRINT "duplicate constant definition";
|
|
||||||
IF VerboseMode THEN
|
|
||||||
thisincname$ = getfilepath$(incname$(inclevel))
|
|
||||||
thisincname$ = MID$(incname$(inclevel), LEN(thisincname$) + 1)
|
|
||||||
IF inclevel = 0 THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ": '";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT n$;
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "' (line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(linenumber);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ")"
|
|
||||||
ELSE
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ": '";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT n$;
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "' (line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(linenumber);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT " in file '";
|
|
||||||
IF ColorVerboseMode THEN COLOR 2
|
|
||||||
PRINT thisincname$;
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "')"
|
|
||||||
END IF
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
ELSE
|
|
||||||
IF duplicateConstWarning = 0 THEN
|
|
||||||
duplicateConstWarning = -1
|
|
||||||
PRINT
|
|
||||||
END IF
|
|
||||||
END IF
|
|
||||||
END IF
|
|
||||||
END IF
|
END IF
|
||||||
GOTO constAddDone
|
GOTO constAddDone
|
||||||
ELSE
|
ELSE
|
||||||
|
@ -2652,7 +2608,7 @@ IF declaringlibrary THEN declaringlibrary = 0 'ignore this error so that auto-fo
|
||||||
|
|
||||||
totallinenumber = reallinenumber
|
totallinenumber = reallinenumber
|
||||||
|
|
||||||
IF idemode = 0 AND NOT QuietMode THEN PRINT "first pass finished.": PRINT "Translating code... "
|
'IF idemode = 0 AND NOT QuietMode THEN PRINT "first pass finished.": PRINT "Translating code... "
|
||||||
|
|
||||||
'prepass finished
|
'prepass finished
|
||||||
|
|
||||||
|
@ -2787,7 +2743,7 @@ DO
|
||||||
layout = ""
|
layout = ""
|
||||||
layoutok = 1
|
layoutok = 1
|
||||||
|
|
||||||
IF idemode = 0 AND NOT QuietMode THEN
|
IF idemode = 0 AND NOT QuietMode AND NOT VerboseMode THEN
|
||||||
'IF LEN(a3$) THEN
|
'IF LEN(a3$) THEN
|
||||||
' dotlinecount = dotlinecount + 1: IF dotlinecount >= 100 THEN dotlinecount = 0: PRINT ".";
|
' dotlinecount = dotlinecount + 1: IF dotlinecount >= 100 THEN dotlinecount = 0: PRINT ".";
|
||||||
'END IF
|
'END IF
|
||||||
|
@ -5907,47 +5863,7 @@ DO
|
||||||
IF SelectCaseCounter > 0 AND SelectCaseHasCaseBlock(SelectCaseCounter) = 0 THEN
|
IF SelectCaseCounter > 0 AND SelectCaseHasCaseBlock(SelectCaseCounter) = 0 THEN
|
||||||
'warn user of empty SELECT CASE block
|
'warn user of empty SELECT CASE block
|
||||||
IF NOT IgnoreWarnings THEN
|
IF NOT IgnoreWarnings THEN
|
||||||
addWarning 0, 0, 0, "", "Empty SELECT CASE block:"
|
addWarning linenumber, inclevel, inclinenumber(inclevel), incname$(inclevel), "empty SELECT CASE block", ""
|
||||||
addWarning linenumber, inclevel, inclinenumber(inclevel), incname$(inclevel), "END SELECT"
|
|
||||||
IF idemode = 0 AND NOT QuietMode THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 5
|
|
||||||
IF emptySCWarning = 0 THEN PRINT: PRINT "Warning: ";
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
PRINT "Empty SELECT CASE block";
|
|
||||||
IF VerboseMode THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ": ";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT "'END SELECT' ";
|
|
||||||
IF inclevel = 0 THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "(line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(linenumber);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ")"
|
|
||||||
ELSE
|
|
||||||
thisincname$ = getfilepath$(incname$(inclevel))
|
|
||||||
thisincname$ = MID$(incname$(inclevel), LEN(thisincname$) + 1)
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "' (line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(linenumber);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT " in file '";
|
|
||||||
IF ColorVerboseMode THEN COLOR 2
|
|
||||||
PRINT thisincname$;
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "')"
|
|
||||||
END IF
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
ELSE
|
|
||||||
IF emptySCWarning = 0 THEN
|
|
||||||
emptySCWarning = -1
|
|
||||||
PRINT
|
|
||||||
END IF
|
|
||||||
END IF
|
|
||||||
END IF
|
|
||||||
END IF
|
END IF
|
||||||
END IF
|
END IF
|
||||||
|
|
||||||
|
@ -11563,7 +11479,7 @@ OPEN tmpdir$ + "temp.bin" FOR OUTPUT LOCK WRITE AS #26 'relock
|
||||||
compilelog$ = tmpdir$ + "compilelog.txt"
|
compilelog$ = tmpdir$ + "compilelog.txt"
|
||||||
OPEN compilelog$ FOR OUTPUT AS #1: CLOSE #1 'Clear log
|
OPEN compilelog$ FOR OUTPUT AS #1: CLOSE #1 'Clear log
|
||||||
|
|
||||||
IF idemode = 0 AND NOT QuietMode THEN
|
IF idemode = 0 AND NOT QuietMode AND NOT VerboseMode THEN
|
||||||
IF ConsoleMode THEN
|
IF ConsoleMode THEN
|
||||||
PRINT "[" + STRING$(maxprogresswidth, ".") + "] 100%"
|
PRINT "[" + STRING$(maxprogresswidth, ".") + "] 100%"
|
||||||
ELSE
|
ELSE
|
||||||
|
@ -11577,58 +11493,27 @@ END IF
|
||||||
'PUT #1, 1, usedVariableList$ 'warning$(1)
|
'PUT #1, 1, usedVariableList$ 'warning$(1)
|
||||||
'CLOSE #1
|
'CLOSE #1
|
||||||
IF NOT IgnoreWarnings THEN
|
IF NOT IgnoreWarnings THEN
|
||||||
IF totalUnusedVariables > 0 THEN
|
totalUnusedVariables = 0
|
||||||
IF idemode = 0 AND NOT QuietMode THEN
|
FOR i = 1 TO totalVariablesCreated
|
||||||
PRINT
|
IF usedVariableList(i).used = 0 THEN
|
||||||
IF ColorVerboseMode THEN COLOR 5
|
totalUnusedVariables = totalUnusedVariables + 1
|
||||||
PRINT "Warning:";
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
PRINT STR$(totalUnusedVariables); " unused variable";
|
|
||||||
IF totalUnusedVariables > 1 THEN PRINT "s";
|
|
||||||
IF VerboseMode THEN
|
|
||||||
PRINT ":"
|
|
||||||
FOR i = 1 TO totalVariablesCreated
|
|
||||||
IF usedVariableList(i).used = 0 THEN
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT SPACE$(4); usedVariableList(i).name; " ("; usedVariableList(i).cname; ", ";
|
|
||||||
IF usedVariableList(i).includeLevel > 0 THEN
|
|
||||||
PRINT "line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(usedVariableList(i).includedLine);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT " in file '";
|
|
||||||
IF ColorVerboseMode THEN COLOR 2
|
|
||||||
PRINT usedVariableList(i).includedFile;
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT "')"
|
|
||||||
ELSE
|
|
||||||
PRINT "line";
|
|
||||||
IF ColorVerboseMode THEN COLOR 15
|
|
||||||
PRINT STR$(usedVariableList(i).linenumber);
|
|
||||||
IF ColorVerboseMode THEN COLOR 8
|
|
||||||
PRINT ")"
|
|
||||||
END IF
|
|
||||||
IF ColorVerboseMode THEN COLOR 7
|
|
||||||
END IF
|
|
||||||
NEXT
|
|
||||||
ELSE
|
|
||||||
PRINT
|
|
||||||
END IF
|
|
||||||
ELSE
|
|
||||||
maxVarNameLen = 0
|
|
||||||
FOR i = 1 TO totalVariablesCreated
|
|
||||||
IF usedVariableList(i).used = 0 THEN
|
|
||||||
IF LEN(usedVariableList(i).name) > maxVarNameLen THEN maxVarNameLen = LEN(usedVariableList(i).name)
|
|
||||||
END IF
|
|
||||||
NEXT
|
|
||||||
|
|
||||||
addWarning 0, 0, 0, "", "Unused variables (" + LTRIM$(STR$(totalUnusedVariables)) + "):"
|
|
||||||
FOR i = 1 TO totalVariablesCreated
|
|
||||||
IF usedVariableList(i).used = 0 THEN
|
|
||||||
addWarning usedVariableList(i).linenumber, usedVariableList(i).includeLevel, usedVariableList(i).includedLine, usedVariableList(i).includedFile, usedVariableList(i).name + SPACE$((maxVarNameLen + 1) - LEN(usedVariableList(i).name)) + " (" + usedVariableList(i).cname + ")"
|
|
||||||
END IF
|
|
||||||
NEXT
|
|
||||||
END IF
|
END IF
|
||||||
|
NEXT
|
||||||
|
|
||||||
|
IF totalUnusedVariables > 0 THEN
|
||||||
|
maxVarNameLen = 0
|
||||||
|
FOR i = 1 TO totalVariablesCreated
|
||||||
|
IF usedVariableList(i).used = 0 THEN
|
||||||
|
IF LEN(usedVariableList(i).name) > maxVarNameLen THEN maxVarNameLen = LEN(usedVariableList(i).name)
|
||||||
|
END IF
|
||||||
|
NEXT
|
||||||
|
|
||||||
|
header$ = "unused variable" 's (" + LTRIM$(STR$(totalUnusedVariables)) + ")"
|
||||||
|
FOR i = 1 TO totalVariablesCreated
|
||||||
|
IF usedVariableList(i).used = 0 THEN
|
||||||
|
addWarning usedVariableList(i).linenumber, usedVariableList(i).includeLevel, usedVariableList(i).includedLine, usedVariableList(i).includedFile, header$, usedVariableList(i).name + SPACE$((maxVarNameLen + 1) - LEN(usedVariableList(i).name)) + " (" + usedVariableList(i).cname + ")"
|
||||||
|
END IF
|
||||||
|
NEXT
|
||||||
END IF
|
END IF
|
||||||
END IF
|
END IF
|
||||||
|
|
||||||
|
@ -21612,7 +21497,7 @@ SUB setrefer (a2$, typ2 AS LONG, e2$, method AS LONG)
|
||||||
END SUB
|
END SUB
|
||||||
|
|
||||||
FUNCTION str2$ (v AS LONG)
|
FUNCTION str2$ (v AS LONG)
|
||||||
str2$ = LTRIM$(RTRIM$(STR$(v)))
|
str2$ = _TRIM$(STR$(v))
|
||||||
END FUNCTION
|
END FUNCTION
|
||||||
|
|
||||||
FUNCTION str2u64$ (v~&&)
|
FUNCTION str2u64$ (v~&&)
|
||||||
|
@ -25270,40 +25155,67 @@ SUB manageVariableList (name$, __cname$, action AS _BYTE)
|
||||||
END IF
|
END IF
|
||||||
usedVariableList(i).cname = cname$
|
usedVariableList(i).cname = cname$
|
||||||
usedVariableList(i).name = name$
|
usedVariableList(i).name = name$
|
||||||
totalUnusedVariables = totalUnusedVariables + 1
|
|
||||||
totalVariablesCreated = totalVariablesCreated + 1
|
totalVariablesCreated = totalVariablesCreated + 1
|
||||||
END IF
|
END IF
|
||||||
CASE ELSE 'find and mark as used
|
CASE ELSE 'find and mark as used
|
||||||
IF found THEN
|
IF found THEN
|
||||||
usedVariableList(i).used = -1
|
usedVariableList(i).used = -1
|
||||||
totalUnusedVariables = totalUnusedVariables - 1
|
|
||||||
END IF
|
END IF
|
||||||
END SELECT
|
END SELECT
|
||||||
END SUB
|
END SUB
|
||||||
|
|
||||||
SUB addWarning (whichLineNumber AS LONG, includeLevel AS LONG, incLineNumber AS LONG, incFileName$, text$)
|
SUB addWarning (whichLineNumber AS LONG, includeLevel AS LONG, incLineNumber AS LONG, incFileName$, header$, text$)
|
||||||
IF NOT IgnoreWarnings THEN
|
warningsissued = -1
|
||||||
warningsissued = -1
|
totalWarnings = totalWarnings + 1
|
||||||
IF whichLineNumber > 0 THEN
|
|
||||||
totalWarnings = totalWarnings + 1
|
IF idemode = 0 AND NOT QuietMode AND VerboseMode THEN
|
||||||
|
thissource$ = getfilepath$(CMDLineFile)
|
||||||
|
thissource$ = MID$(CMDLineFile, LEN(thissource$) + 1)
|
||||||
|
thisincname$ = getfilepath$(incFileName$)
|
||||||
|
thisincname$ = MID$(incFileName$, LEN(thisincname$) + 1)
|
||||||
|
|
||||||
|
IF ColorVerboseMode THEN COLOR 15
|
||||||
|
IF includeLevel > 0 AND incLineNumber > 0 THEN
|
||||||
|
PRINT thisincname$; ":";
|
||||||
|
PRINT str2$(incLineNumber); ": ";
|
||||||
ELSE
|
ELSE
|
||||||
IF lastWarningHeader = text$ THEN
|
PRINT thissource$; ":";
|
||||||
EXIT SUB
|
PRINT str2$(whichLineNumber); ": ";
|
||||||
ELSE
|
|
||||||
lastWarningHeader = text$
|
|
||||||
END IF
|
|
||||||
END IF
|
END IF
|
||||||
|
|
||||||
warningListItems = warningListItems + 1
|
IF ColorVerboseMode THEN COLOR 13
|
||||||
IF warningListItems > UBOUND(warning$) THEN REDIM _PRESERVE warning$(warningListItems + 999)
|
PRINT "warning: ";
|
||||||
IF includeLevel > 0 THEN
|
IF ColorVerboseMode THEN COLOR 7
|
||||||
thisincname$ = getfilepath$(incFileName$)
|
PRINT header$
|
||||||
thisincname$ = MID$(incFileName$, LEN(thisincname$) + 1)
|
|
||||||
warning$(warningListItems) = MKL$(whichLineNumber) + MKL$(includeLevel) + MKL$(incLineNumber) + thisincname$ + CHR$(2) + text$
|
IF LEN(text$) > 0 THEN
|
||||||
ELSE
|
IF ColorVerboseMode THEN COLOR 2
|
||||||
warning$(warningListItems) = MKL$(whichLineNumber) + MKL$(0) + CHR$(2) + text$
|
PRINT SPACE$(4); text$
|
||||||
|
IF ColorVerboseMode THEN COLOR 7
|
||||||
|
END IF
|
||||||
|
ELSEIF idemode THEN
|
||||||
|
IF NOT IgnoreWarnings THEN
|
||||||
|
IF lastWarningHeader <> header$ THEN
|
||||||
|
lastWarningHeader = header$
|
||||||
|
GOSUB increaseWarningCount
|
||||||
|
warning$(warningListItems) = MKL$(0) + CHR$(2) + header$
|
||||||
|
END IF
|
||||||
|
|
||||||
|
GOSUB increaseWarningCount
|
||||||
|
IF includeLevel > 0 THEN
|
||||||
|
thisincname$ = getfilepath$(incFileName$)
|
||||||
|
thisincname$ = MID$(incFileName$, LEN(thisincname$) + 1)
|
||||||
|
warning$(warningListItems) = MKL$(whichLineNumber) + MKL$(includeLevel) + MKL$(incLineNumber) + thisincname$ + CHR$(2) + text$
|
||||||
|
ELSE
|
||||||
|
warning$(warningListItems) = MKL$(whichLineNumber) + MKL$(0) + CHR$(2) + text$
|
||||||
|
END IF
|
||||||
END IF
|
END IF
|
||||||
END IF
|
END IF
|
||||||
|
EXIT SUB
|
||||||
|
increaseWarningCount:
|
||||||
|
warningListItems = warningListItems + 1
|
||||||
|
IF warningListItems > UBOUND(warning$) THEN REDIM _PRESERVE warning$(warningListItems + 999)
|
||||||
|
RETURN
|
||||||
END SUB
|
END SUB
|
||||||
|
|
||||||
'$INCLUDE:'utilities\strings.bas'
|
'$INCLUDE:'utilities\strings.bas'
|
||||||
|
|
Loading…
Reference in a new issue