Special function for type checking and returning an error in one fell swop
This commit is contained in:
parent
d74f3a40dd
commit
67c94fb0e8
@ -3,7 +3,7 @@ package analyzer
|
||||
import "os"
|
||||
import "fmt"
|
||||
import "path/filepath"
|
||||
// import "git.tebibyte.media/arf/arf/types"
|
||||
import "git.tebibyte.media/arf/arf/file"
|
||||
import "git.tebibyte.media/arf/arf/parser"
|
||||
import "git.tebibyte.media/arf/arf/infoerr"
|
||||
|
||||
@ -213,6 +213,28 @@ func (analyzer *AnalysisOperation) addSection (section Section) {
|
||||
return
|
||||
}
|
||||
|
||||
// typeCheck checks to see if source can fit as an argument into a slot of type
|
||||
// destination. If it can, it retunrs nil. If it can't, it returns an error
|
||||
// explaining why.
|
||||
func (analyzer *AnalysisOperation) typeCheck (
|
||||
location file.Location,
|
||||
source Argument,
|
||||
destination Type,
|
||||
) (
|
||||
err error,
|
||||
) {
|
||||
if !source.canBePassedAs(destination) {
|
||||
err = infoerr.NewError (
|
||||
location,
|
||||
typeMismatchErrorMessage (
|
||||
source.What(),
|
||||
destination),
|
||||
infoerr.ErrorKindError)
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
func doIndent (indent int, input ...any) (output string) {
|
||||
for index := 0; index < indent; index ++ {
|
||||
output += "\t"
|
||||
|
@ -136,6 +136,10 @@ func (literal StringLiteral) canBePassedAs (what Type) (allowed bool) {
|
||||
// types that can be reduced to a variable array pointing to numbers at
|
||||
// a primitive level.
|
||||
|
||||
// we don't check the length of what, becasue when setting a static
|
||||
// array to a string literal, excess data will be cut off (and if it is
|
||||
// shorter, the excess space will be filled with zeros).
|
||||
|
||||
reduced, worked := what.reduce()
|
||||
if worked {
|
||||
if !what.isSingular() { return }
|
||||
|
@ -82,14 +82,11 @@ func (analyzer AnalysisOperation) analyzeTypeSection () (
|
||||
if err != nil { return }
|
||||
|
||||
// type check default value
|
||||
if !outputSection.argument.canBePassedAs(outputSection.what) {
|
||||
err = inputSection.Argument().NewError (
|
||||
typeMismatchErrorMessage (
|
||||
outputSection.argument.What(),
|
||||
outputSection.what),
|
||||
infoerr.ErrorKindError)
|
||||
return
|
||||
}
|
||||
err = analyzer.typeCheck (
|
||||
inputSection.Argument().Location(),
|
||||
outputSection.argument,
|
||||
outputSection.what)
|
||||
if err != nil { return }
|
||||
}
|
||||
|
||||
// TODO: analyze members
|
||||
|
Reference in New Issue
Block a user