修改SQL对比算法

This commit is contained in:
GoEdgeLab
2020-11-16 23:30:47 +08:00
parent 8f92d0c518
commit 7b7e5cf982
21 changed files with 588 additions and 1512 deletions

77
cmd/sql-dump/main.go Normal file
View File

@@ -0,0 +1,77 @@
package main
import (
"encoding/json"
"github.com/TeaOSLab/EdgeAPI/internal/setup"
_ "github.com/iwind/TeaGo/bootstrap"
"github.com/iwind/TeaGo/dbs"
"github.com/iwind/TeaGo/logs"
"go/format"
"io/ioutil"
"os"
"path/filepath"
"strconv"
)
func main() {
db, err := dbs.Default()
if err != nil {
logs.Println("[ERROR]" + err.Error())
return
}
results, err := setup.NewSQLDump().Dump(db)
if err != nil {
logs.Println("[ERROR]" + err.Error())
return
}
resultsJSON, err := json.Marshal(results)
if err != nil {
logs.Println("[ERROR]" + err.Error())
return
}
dir, _ := os.Getwd()
var sqlFile string
for i := 0; i < 5; i++ {
lookupFile := dir + "/internal/setup/sql.go"
_, err = os.Stat(lookupFile)
if err != nil {
dir = filepath.Dir(dir)
continue
}
sqlFile = lookupFile
}
if len(sqlFile) == 0 {
logs.Println("[ERROR]can not find sql.go")
return
}
content := []byte(`package setup
import (
"encoding/json"
"github.com/iwind/TeaGo/logs"
)
// 最新的SQL语句
// 由sql-dump/main.go自动生成
func init() {
err := json.Unmarshal([]byte(` + strconv.Quote(string(resultsJSON)) + `), LatestSQLResult)
if err != nil {
logs.Println("[ERROR]load sql failed: " + err.Error())
}
}
`)
dst, err := format.Source(content)
if err != nil {
logs.Println("[ERROR]format code failed: " + err.Error())
return
}
err = ioutil.WriteFile(sqlFile, dst, 0666)
if err != nil {
logs.Println("[ERROR]write file failed: " + err.Error())
return
}
logs.Println("ok")
}

View File

@@ -1,103 +0,0 @@
package main
import (
"bytes"
"flag"
"fmt"
"github.com/iwind/TeaGo/Tea"
_ "github.com/iwind/TeaGo/bootstrap"
"github.com/iwind/TeaGo/logs"
"go/format"
"io/ioutil"
"os"
"path/filepath"
"strings"
)
func main() {
var dir string
flag.StringVar(&dir, "dir", "", "SQL dir")
flag.Parse()
if len(dir) == 0 {
fmt.Println("[ERROR]'dir' should not be empty")
return
}
sourceDir := filepath.Dir(Tea.Root)
// full
fullSQLFile := dir + "/full.sql"
_, err := os.Stat(fullSQLFile)
if err != nil {
if os.IsNotExist(err) {
fmt.Println("[ERROR]'full.sql' not found")
return
}
fmt.Println("[ERROR]checking 'full.sql' failed: " + err.Error())
return
}
matches, err := filepath.Glob(dir + "/*.sql")
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
versionsCode := "// generated\npackage sqls\n\nvar SQLVersions = []map[string]string{"
for _, match := range matches {
baseName := filepath.Base(match)
logs.Println("reading " + baseName + " ...")
data, err := ioutil.ReadFile(match)
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
version := baseName[:strings.LastIndex(baseName, ".")]
versionsCode += "\n" + `{ "version": "` + version + `", "sql": SQL_` + version + ` },`
code := "// generated\npackage sqls \n\n"
lines := bytes.Split(data, []byte{'\n'})
for index, line := range lines {
if index == 0 {
code += "var SQL_" + version + " = "
}
code += `"` + string(line) + `\n"`
if index != len(lines)-1 {
code += "+"
}
code += "\n"
}
code += "\n"
codeBytes, err := format.Source([]byte(code))
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
fmt.Println("writing sql_" + version + ".go ...")
err = ioutil.WriteFile(sourceDir+"/internal/setup/sqls/sql_"+version+".go", codeBytes, 0666)
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
fmt.Println("ok")
}
versionsCode += "\n}"
versionsCodeBytes, err := format.Source([]byte(versionsCode))
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
fmt.Println("writing sqls.go ...")
err = ioutil.WriteFile(sourceDir+"/internal/setup/sqls/sqls.go", versionsCodeBytes, 0666)
if err != nil {
fmt.Println("[ERROR]" + err.Error())
return
}
fmt.Println("ok")
}