hacker-quotes/models/verb.go

121 lines
2.0 KiB
Go
Raw Normal View History

package models
import (
"fmt"
"strings"
)
type Verb struct {
Id int
Regular bool
// Indefinite form
Word string
//ConjugationsPast []Conjugate
//ConjugationsPresent []Conjugate
//ConjugationsFuture []Conjugate
}
//type Conjugate struct {
// Type ConjugateType
// Form string
//}
type ConjugationType int
const (
CT_Unknown ConjugationType = iota
CT_I
CT_You
CT_It
CT_We
CT_They
)
func (ct ConjugationType) String() string {
switch ct {
case CT_I:
return "I"
case CT_It:
return "It"
case CT_You:
return "You"
case CT_We:
return "We"
case CT_They:
return "They"
default:
return "Unknown"
}
}
type ConjugationTime int
const (
CM_Unknown ConjugationTime = iota
CM_Present
CM_Past
CM_Future
)
func (cm ConjugationTime) String() string {
switch cm {
case CM_Present:
return "Present"
case CM_Past:
return "Past"
case CM_Future:
return "Future"
default:
return "Unknown"
}
}
// TODO: implement inverted
func (v Verb) Conjugate(conjugation ConjugationType, time ConjugationTime, inverted bool ) string {
if !v.Regular {
fmt.Printf("[verb] Irregular verbs not implemented! %q\n", v.Word)
return v.Word
}
//fmt.Printf("[verb] word: %s; type: %s; time: %s\n", v.Word, conjugation, time)
switch time {
case CM_Present:
if conjugation == CT_It {
sfx := []string{"s", "x", "sh", "ch", "ss"}
for _, s := range sfx {
if strings.HasSuffix(v.Word, s) {
return v.Word + "es"
}
}
if strings.HasSuffix(v.Word, "y") && !strings.ContainsAny(string(v.Word[len(v.Word)-2]), "aeiou") {
return v.Word[:len(v.Word)-1] + "ies"
}
return v.Word + "s"
} else {
return v.Word
}
case CM_Past:
if strings.HasSuffix(v.Word, "e") {
return v.Word + "d"
}
if strings.HasSuffix(v.Word, "y") && !strings.ContainsAny(string(v.Word[len(v.Word)-2]), "aeiou") {
return v.Word[:len(v.Word)-1] + "ied"
}
return v.Word + "ed"
case CM_Future:
return "will " + v.Word
}
fmt.Printf("[verb] Unknown ConjugationTime: %d\n", conjugation)
return v.Word
}