diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index 17d19a494d..c43c603352 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -21,30 +21,30 @@ jobs: run: | rm -f README.md mv content/* . - mv etc/* . + mv cover_small.jpg . + mv cover_square.png . + mv cover.jpg . + mv custom.css . + mv main.go . + mv robots.txt . npm install -g gitbook-cli - mv ./book.json ./book.json.template gitbook install cd ~/.gitbook/versions/3.2.3 && npm i npm@5 cd ${{ github.workspace }} - mv ./book.json.template ./book.json + mv book.json . gitbook install - go run fix-webbook.go -type=pre + go run main.go -mode=webbook -adjustment=pre gitbook build - go run fix-webbook.go -type=post + go run main.go -mode=webbook -adjustment=post cd _book echo '
' > 404.html - rm -rf LICENSE - rm -rf book* - rm -rf .git - rm -rf .gitignore - rm -rf .github + rm -rf in-progress rm -rf *.md - rm -rf *.sh - rm -rf *.psd - rm -rf *.go - rm -rf *.css - rm -rf *.js + rm -rf .gitmodules + rm -rf crowdin.yml + rm -rf LICENSE + rm -rf package-lock.json + rm -rf package.json.js - name: 'Deploying' uses: peaceiris/actions-gh-pages@v3 with: @@ -72,8 +72,8 @@ jobs: mv content/* . mv etc/* . rm -f book.json - go run fix-ebook.go -type=pre mkdir _book + go run main.go -mode=ebook -adjustment=pre gitbook install - name: 'Generating ebook in pdf' run: gitbook pdf ./ ./_book/dasarpemrogramangolang.pdf diff --git a/etc/fix-ebook.go b/etc/fix-ebook.go deleted file mode 100644 index ac9bd6c1b0..0000000000 --- a/etc/fix-ebook.go +++ /dev/null @@ -1,89 +0,0 @@ -package main - -import ( - "flag" - "fmt" - "log" - "os" - "path/filepath" - "strings" - "time" -) - -var ( - baseVersion = 3 - bookName = "Dasar Pemrograman Golang" - ga4tagId = "G-MZ74P74K72" - now = time.Now() -) - -func main() { - flagAdjustment := flag.String("type", "", "adjustment type (pre/post)") - flag.Parse() - - switch *flagAdjustment { - case "pre": - preAdjustment() - default: - break - } -} - -func preAdjustment() { - basePath, _ := os.Getwd() - readmePath := filepath.Join(basePath, "README.md") - - buf, err := os.ReadFile(readmePath) - if err != nil { - log.Fatal(err.Error()) - } - mdString := string(buf) - - // ==== adjust version - versionToFind := `((VERSION))` - mdString = strings.ReplaceAll(mdString, versionToFind, getVersion()) - - err = os.WriteFile(readmePath, []byte(mdString), 0644) - if err != nil { - log.Fatal(err.Error()) - } - - // ==== adjust content - err = filepath.Walk(basePath, func(path string, info os.FileInfo, err error) error { - if err != nil { - return err - } - if info.IsDir() { - return nil - } - if filepath.Ext(info.Name()) != ".md" { - return nil - } - - buf, err := os.ReadFile(path) - if err != nil { - return err - } - htmlString := string(buf) - - // ==== remove substack embed - substackEmbedToRemove := `` - htmlString = strings.ReplaceAll(htmlString, substackEmbedToRemove, "") - - // ==== update file - err = os.WriteFile(path, []byte(strings.TrimSpace(htmlString)), info.Mode()) - if err != nil { - return err - } - - fmt.Println(" ==>", path) - return nil - }) - if err != nil { - log.Fatal(err.Error()) - } -} - -func getVersion() string { - return fmt.Sprintf("%d.%s", baseVersion, now.Format("2006.01.02.150405")) -} diff --git a/etc/fix-webbook.go b/etc/main.go similarity index 73% rename from etc/fix-webbook.go rename to etc/main.go index 2a306602b5..c688080a78 100644 --- a/etc/fix-webbook.go +++ b/etc/main.go @@ -19,20 +19,37 @@ var ( ) func main() { - flagAdjustment := flag.String("type", "", "adjustment type (pre/post)") + flagMode := flag.String("mode", "", "mode (webbook/ebook)") + flagAdjustment := flag.String("adjustment", "", "adjustment type (pre/post)") flag.Parse() - switch *flagAdjustment { - case "pre": - preAdjustment() - case "post": - postAdjustment() + switch *flagMode { + case "webbook": + switch *flagAdjustment { + case "pre": + webbookPreAdjustment() + case "post": + webbookPostAdjustment() + default: + log.Fatalf("unrecognized flag -adjustment") + } + case "ebook": + switch *flagAdjustment { + case "pre": + ebookPreAdjustment() + default: + log.Fatalf("unrecognized flag -adjustment") + } default: - break + log.Fatalf("unrecognized flag -mode") } } -func preAdjustment() { +func getVersion() string { + return fmt.Sprintf("%d.%s", baseVersion, now.Format("2006.01.02.150405")) +} + +func webbookPreAdjustment() { basePath, _ := os.Getwd() readmePath := filepath.Join(basePath, "README.md") @@ -52,7 +69,7 @@ func preAdjustment() { } } -func postAdjustment() { +func webbookPostAdjustment() { basePath, _ := os.Getwd() bookPath := filepath.Join(basePath, "_book") @@ -149,7 +166,12 @@ func postAdjustment() { // ==== inject github stars button buttonToFind := `