Temp files are now stored in system temp dir

This commit is contained in:
bradley.richins
2020-10-20 14:47:04 -06:00
parent 84df8142c6
commit 230cefb85d
2 changed files with 46 additions and 70 deletions

View File

@@ -24,6 +24,14 @@ func CreateBanner(portalhex string, savename string, vopt int) {
var err error var err error
var GlyphHex [12]int64 var GlyphHex [12]int64
var glyphImg [12]string var glyphImg [12]string
// Setup temp dir
tempdir, err := ioutil.TempDir("", ".gotemp")
if err != nil {
panic(err)
}
defer os.RemoveAll(tempdir)
// verify len of portalhex // verify len of portalhex
if len(portalhex) == 12 { if len(portalhex) == 12 {
// get hex value from each digit in given string to an array of int64 // get hex value from each digit in given string to an array of int64
@@ -35,7 +43,7 @@ func CreateBanner(portalhex string, savename string, vopt int) {
} }
// assign image location of its glyph hex value to an array of strings // assign image location of its glyph hex value to an array of strings
for j := 0; j < len(glyphImg); j++ { for j := 0; j < len(glyphImg); j++ {
glyphImg[j] = fmt.Sprintf("tmp.nmslib/glyphs/GLYPH-%X.png", GlyphHex[j]) glyphImg[j] = fmt.Sprintf("glyphs/GLYPH-%X.png", GlyphHex[j])
} }
// pull images need from glyph.go and saved them to ./glyphs/ // pull images need from glyph.go and saved them to ./glyphs/
for k := 0; k < len(glyphImg); k++ { for k := 0; k < len(glyphImg); k++ {
@@ -43,24 +51,25 @@ func CreateBanner(portalhex string, savename string, vopt int) {
if err != nil { if err != nil {
panic(err) panic(err)
} }
_, err2 := os.Stat("tmp.nmslib/glyphs") _, err2 := os.Stat(tempdir + "/glyphs/")
if os.IsNotExist(err2) { if os.IsNotExist(err2) {
errDir := os.MkdirAll("tmp.nmslib/glyphs", 0755) errDir := os.MkdirAll(tempdir+"/glyphs", 0755)
if errDir != nil { if errDir != nil {
panic(errDir) panic(errDir)
} }
} }
err = ioutil.WriteFile(glyphImg[k], []byte(data), 0644)
err = ioutil.WriteFile(tempdir+"/"+glyphImg[k], []byte(data), 0644)
} }
} }
// load images for processing using github.com/ozankasikci/go-image-merge // load images for processing using github.com/ozankasikci/go-image-merge
grids := []*gim.Grid{ grids := []*gim.Grid{
{ImageFilePath: glyphImg[0]}, {ImageFilePath: glyphImg[1]}, {ImageFilePath: tempdir + "/" + glyphImg[0]}, {ImageFilePath: tempdir + "/" + glyphImg[1]},
{ImageFilePath: glyphImg[2]}, {ImageFilePath: glyphImg[3]}, {ImageFilePath: tempdir + "/" + glyphImg[2]}, {ImageFilePath: tempdir + "/" + glyphImg[3]},
{ImageFilePath: glyphImg[4]}, {ImageFilePath: glyphImg[5]}, {ImageFilePath: tempdir + "/" + glyphImg[4]}, {ImageFilePath: tempdir + "/" + glyphImg[5]},
{ImageFilePath: glyphImg[6]}, {ImageFilePath: glyphImg[7]}, {ImageFilePath: tempdir + "/" + glyphImg[6]}, {ImageFilePath: tempdir + "/" + glyphImg[7]},
{ImageFilePath: glyphImg[8]}, {ImageFilePath: glyphImg[9]}, {ImageFilePath: tempdir + "/" + glyphImg[8]}, {ImageFilePath: tempdir + "/" + glyphImg[9]},
{ImageFilePath: glyphImg[10]}, {ImageFilePath: glyphImg[11]}, {ImageFilePath: tempdir + "/" + glyphImg[10]}, {ImageFilePath: tempdir + "/" + glyphImg[11]},
} }
if vopt == 1 { if vopt == 1 {
// Merge images horizontally // Merge images horizontally
@@ -83,9 +92,4 @@ func CreateBanner(portalhex string, savename string, vopt int) {
file, err := os.Create(savename) file, err := os.Create(savename)
err = png.Encode(file, rgba) err = png.Encode(file, rgba)
} }
// remove glyphs folder to keep it clean
errDir := os.RemoveAll("tmp.nmslib/glyphs")
if errDir != nil {
panic(errDir)
}
} }

82
lang.go
View File

@@ -8,71 +8,53 @@ import (
"strings" "strings"
) )
/* // KorvaxWord - set up structure of a word iteration
KorvaxWord - set up structure of a word iteration type korvaxWord struct {
*/
type KorvaxWord struct {
english string english string
korvax string korvax string
kwcaps string kwcaps string
kwallcaps string kwallcaps string
} }
/*
Korvax2Eng - Translate a Korvax word to English
*/
func Korvax2Eng(kvwrd string) string { func Korvax2Eng(kvwrd string) string {
data, err := Asset("tmp.nmslib/korvax-lang.csv") tempdir, err := ioutil.TempDir("", ".gotemp")
if err != nil { if err != nil {
panic(err) panic(err)
} }
_, err2 := os.Stat("tmp.nmslib/") defer os.RemoveAll(tempdir)
if os.IsNotExist(err2) {
errDir := os.MkdirAll("tmp.nmslib/", 0755) data, err := Asset("korvax-lang.csv")
if errDir != nil { if err != nil {
panic(errDir) panic(err)
} }
} err = ioutil.WriteFile(tempdir+"/korvax-lang.csv", []byte(data), 0644)
err = ioutil.WriteFile("tmp.nmslib/korvax-lang.csv", []byte(data), 0644) csvFile, err := os.Open(tempdir + "/korvax-lang.csv")
csvFile, err := os.Open("tmp.nmslib/korvax-lang.csv")
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
} }
defer csvFile.Close() defer csvFile.Close()
CsvLines, err := csv.NewReader(csvFile).ReadAll() csvlines, err := csv.NewReader(csvFile).ReadAll()
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
} }
for _, line := range CsvLines { for _, line := range csvlines {
klang := KorvaxWord{ klang := korvaxWord{
english: line[0], english: line[0],
korvax: line[1], korvax: line[1],
kwcaps: line[2], kwcaps: line[2],
kwallcaps: line[3], kwallcaps: line[3],
} }
if kvwrd == klang.korvax { if kvwrd == klang.korvax {
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return klang.english return klang.english
} else if kvwrd == klang.korvax { } else if kvwrd == klang.korvax {
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return strings.Title(strings.ToLower(klang.english)) return strings.Title(strings.ToLower(klang.english))
} else if kvwrd == klang.kwallcaps { } else if kvwrd == klang.kwallcaps {
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return strings.ToUpper(klang.english) return strings.ToUpper(klang.english)
} }
} }
// remove recource folder to keep it clean
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return "*\\Kzzzzzzt\\*" // word not found default return "*\\Kzzzzzzt\\*" // word not found default
} }
@@ -80,46 +62,36 @@ func Korvax2Eng(kvwrd string) string {
Eng2Korvax - Convert (some) english words to Korvax Eng2Korvax - Convert (some) english words to Korvax
*/ */
func Eng2Korvax(enwrd string) string { func Eng2Korvax(enwrd string) string {
data, err := Asset("tmp.nmslib/korvax-lang.csv") tempdir, err := ioutil.TempDir("", ".gotemp")
if err != nil { if err != nil {
panic(err) panic(err)
} }
_, err2 := os.Stat("tmp.nmslib/") defer os.RemoveAll(tempdir)
if os.IsNotExist(err2) {
errDir := os.MkdirAll("tmp.nmslib/", 0755) data, err := Asset("korvax-lang.csv")
if errDir != nil { if err != nil {
panic(errDir) panic(err)
} }
} err = ioutil.WriteFile(tempdir+"/korvax-lang.csv", []byte(data), 0644)
err = ioutil.WriteFile("tmp.nmslib/korvax-lang.csv", []byte(data), 0644) csvFile, err := os.Open(tempdir + "/korvax-lang.csv")
csvFile, err := os.Open("tmp.nmslib/korvax-lang.csv")
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
} }
defer csvFile.Close() defer csvFile.Close()
CsvLines, err := csv.NewReader(csvFile).ReadAll() csvlines, err := csv.NewReader(csvFile).ReadAll()
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
} }
for _, line := range CsvLines { for _, line := range csvlines {
klang := KorvaxWord{ klang := korvaxWord{
english: line[0], english: line[0],
korvax: line[1], korvax: line[1],
kwcaps: line[2], kwcaps: line[2],
kwallcaps: line[3], kwallcaps: line[3],
} }
if enwrd == klang.english { if enwrd == klang.english {
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return klang.korvax return klang.korvax
} }
} }
// remove recource folder to keep it clean
errDir := os.RemoveAll("tmp.nmslib")
if errDir != nil {
panic(errDir)
}
return "*\\Kzzzzzzt\\*" // word not found default return "*\\Kzzzzzzt\\*" // word not found default
} }