From d28c9e5527beaaf7e861bb5f3edb066ed3ddbc6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9D=A8=E7=BA=A2=E5=B2=A9?= Date: Fri, 21 Jul 2023 18:27:51 +0800 Subject: [PATCH] U: gen libbin --- common/tools/genbinres/README.md | 21 ++++++++++++++ common/tools/genbinres/main.go | 47 ++++++++++++++++++++------------ 2 files changed, 51 insertions(+), 17 deletions(-) create mode 100644 common/tools/genbinres/README.md diff --git a/common/tools/genbinres/README.md b/common/tools/genbinres/README.md new file mode 100644 index 0000000..ac1c673 --- /dev/null +++ b/common/tools/genbinres/README.md @@ -0,0 +1,21 @@ +### 生成 liblcl 到 xx.go 字节数组发版包 +已规定好的命名规则和文件目录 +1. 压缩包 +2. 文件目录 + +### 目录 +当前系统用户目录/golcl/ + +### 命名 +#### 文件 +所属目录: /xxx/用户目录/golcl/ + + 规则 + +| liblcl 文件目录 | Go 字节数组 | +|----------------------------|----------------------------| +| win32/liblcl.dll | liblcl_windows_386.go | +| win64/liblcl.dll | liblcl_windows_amd64.go | +| macos64-cocoa/liblcl.dylib | liblcl_darwin_amd64.go | +| linux64-gtk3/liblcl.so | liblcl_gtk3_linux_amd64.go | +| linux64-gtk2/liblcl.so | liblcl_gtk2_linux_amd64.go | \ No newline at end of file diff --git a/common/tools/genbinres/main.go b/common/tools/genbinres/main.go index 3095293..968462a 100644 --- a/common/tools/genbinres/main.go +++ b/common/tools/genbinres/main.go @@ -1,3 +1,13 @@ +//---------------------------------------- +// +// Copyright © yanghy. All Rights Reserved. +// +// Licensed under Apache License Version 2.0, January 2004 +// +// https://www.apache.org/licenses/LICENSE-2.0 +// +//---------------------------------------- + package main import ( @@ -60,37 +70,37 @@ func main() { for _, ff := range zz.File { //fmt.Println(ff.Name) switch ff.Name { - //case "linux64-gtk2/liblcl.so": - // genresByte(readZipData(ff), filepath.Join(libLCLBinResDir, "liblcl_linux_amd64.go")) - case "linux64-gtk3/liblcl.so": - genresByte(readZipData(ff), filepath.Join(libLCLBinResDir, "liblcl_linux_amd64.go")) case "win32/liblcl.dll": - genresByte(readZipData(ff), filepath.Join(libLCLBinResDir, "liblcl_windows_386.go")) + genresByte(readZipData(ff), "windows", filepath.Join(libLCLBinResDir, "liblcl_windows_386.go")) case "win64/liblcl.dll": - genresByte(readZipData(ff), filepath.Join(libLCLBinResDir, "liblcl_windows_amd64.go")) + genresByte(readZipData(ff), "windows", filepath.Join(libLCLBinResDir, "liblcl_windows_amd64.go")) case "macos64-cocoa/liblcl.dylib": - genresByte(readZipData(ff), filepath.Join(libLCLBinResDir, "liblcl_darwin_amd64.go")) + genresByte(readZipData(ff), "darwin", filepath.Join(libLCLBinResDir, "liblcl_darwin_amd64.go")) + case "linux64-gtk3/liblcl.so": + genresByte(readZipData(ff), "linux && gtk3", filepath.Join(libLCLBinResDir, "liblcl_gtk3_linux_amd64.go")) + case "linux64-gtk2/liblcl.so": + genresByte(readZipData(ff), "linux && gtk2", filepath.Join(libLCLBinResDir, "liblcl_gtk2_linux_amd64.go")) } } } else { // windows 32 - genresFile(filepath.Join(liblclPath, "win32", "liblcl.dll"), filepath.Join(libLCLBinResDir, "liblcl_windows_386.go")) + genresFile(filepath.Join(liblclPath, "win32", "liblcl.dll"), "windows", filepath.Join(libLCLBinResDir, "liblcl_windows_386.go")) // windows 64 - genresFile(filepath.Join(liblclPath, "win64", "liblcl.dll"), filepath.Join(libLCLBinResDir, "liblcl_windows_amd64.go")) - // linux 64 gtk2 - //genresFile(filepath.Join(liblclPath, "linux64-gtk2", "liblcl.so"), filepath.Join(libLCLBinResDir, "liblcl_linux_amd64.go")) - // linux 64 gtk3 - genresFile(filepath.Join(liblclPath, "linux64-gtk3", "liblcl.so"), filepath.Join(libLCLBinResDir, "liblcl_linux_amd64.go")) + genresFile(filepath.Join(liblclPath, "win64", "liblcl.dll"), "windows", filepath.Join(libLCLBinResDir, "liblcl_windows_amd64.go")) // macos cocoa - genresFile(filepath.Join(liblclPath, "macos64-cocoa", "liblcl.dylib"), filepath.Join(libLCLBinResDir, "liblcl_darwin_amd64.go")) + genresFile(filepath.Join(liblclPath, "macos64-cocoa", "liblcl.dylib"), "darwin", filepath.Join(libLCLBinResDir, "liblcl_darwin_amd64.go")) + // linux 64 gtk3 + genresFile(filepath.Join(liblclPath, "linux64-gtk3", "liblcl.so"), "linux && gtk3", filepath.Join(libLCLBinResDir, "liblcl_gtk3_linux_amd64.go")) + // linux 64 gtk2 + genresFile(filepath.Join(liblclPath, "linux64-gtk2", "liblcl.so"), "linux && gtk2", filepath.Join(libLCLBinResDir, "liblcl_gtk2_linux_amd64.go")) } } // 生成字节的单元 -func genresFile(fileName, newFileName string) { +func genresFile(fileName, tags, newFileName string) { bs, err := ioutil.ReadFile(fileName) if err == nil { - genresByte(bs, newFileName) + genresByte(bs, tags, newFileName) } else { fmt.Println("生成字节Go文件:", newFileName, "Error:", err) } @@ -137,7 +147,7 @@ func zlibCompress(input []byte) ([]byte, error) { return in.Bytes(), nil } -func genresByte(input []byte, newFileName string) { +func genresByte(input []byte, tags, newFileName string) { fmt.Println("genFile: ", newFileName) if len(input) == 0 { fmt.Println("000000") @@ -152,6 +162,9 @@ func genresByte(input []byte, newFileName string) { panic(err) } code := bytes.NewBuffer(nil) + code.WriteString("//go:build ") + code.WriteString(tags) + code.WriteString("\r\n\r\n") code.WriteString("package liblclbinres") code.WriteString("\r\n\r\n") code.WriteString(fmt.Sprintf("const CRC32Value uint32 = 0x%x\r\n\r\n", crc32Val)) -- GitLab