Skip to content
This repository has been archived by the owner on Mar 25, 2024. It is now read-only.

Commit

Permalink
Merge pull request #23 from jackyzha0/dev
Browse files Browse the repository at this point in the history
  • Loading branch information
jackyzha0 authored Jul 31, 2022
2 parents 8c87fd7 + eec81e4 commit 3c17ec3
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 9 deletions.
2 changes: 1 addition & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ func main() {
ignoreBlobs := getIgnoredFiles(*root)
l, i := walk(*in, ".md", *index, ignoreBlobs)
f := filter(l)
err := write(f, i, *index, *out)
err := write(f, i, *index, *out, *root)
if err != nil {
panic(err)
}
Expand Down
4 changes: 2 additions & 2 deletions walk.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,6 @@ func walk(root, ext string, index bool, ignorePaths map[string]struct{}) (res []
fmt.Printf("[Ignored] %s\n", d.Name())
nPrivate++
} else if filepath.Ext(d.Name()) == ext {
res = append(res, parse(s, root)...)
if index {
text := getText(s)

Expand All @@ -61,12 +60,13 @@ func walk(root, ext string, index bool, ignorePaths map[string]struct{}) (res []
info, _ := os.Stat(s)
source := processSource(trim(s, root, ".md"))

// adjustedPath := UnicodeSanitize(strings.Replace(hugoPathTrim(trim(s, root, ".md")), " ", "-", -1))
// add to content and link index
i[source] = Content{
LastModified: info.ModTime(),
Title: matter.Title,
Content: body,
}
res = append(res, parse(s, root)...)
} else {
fmt.Printf("[Ignored] %s\n", d.Name())
nPrivate++
Expand Down
39 changes: 33 additions & 6 deletions write.go
Original file line number Diff line number Diff line change
@@ -1,16 +1,18 @@
package main

import (
"bufio"
"encoding/json"
"io/ioutil"
"os"
"path"
)

func write(links []Link, contentIndex ContentIndex, toIndex bool, out string) error {
func write(links []Link, contentIndex ContentIndex, toIndex bool, out string, root string) error {
index := index(links)
resStruct := struct {
Index Index `json:"index"`
Links []Link `json:"links"`
Index Index `json:"index"`
Links []Link `json:"links"`
}{
Index: index,
Links: links,
Expand All @@ -25,6 +27,7 @@ func write(links []Link, contentIndex ContentIndex, toIndex bool, out string) er
return writeErr
}

// check whether to index content
if toIndex {
marshalledContentIndex, mcErr := json.MarshalIndent(&contentIndex, "", " ")
if mcErr != nil {
Expand All @@ -35,7 +38,34 @@ func write(links []Link, contentIndex ContentIndex, toIndex bool, out string) er
if writeErr != nil {
return writeErr
}

// write linkmap
writeErr = writeLinkMap(&contentIndex, root)
if writeErr != nil {
return writeErr
}
}

return nil
}

func writeLinkMap(contentIndex *ContentIndex, root string) error {
fp := path.Join(root, "linkmap")
file, err := os.OpenFile(fp, os.O_TRUNC|os.O_CREATE|os.O_WRONLY, 0644)
if err != nil {
return err
}

datawriter := bufio.NewWriter(file)
for path := range *contentIndex {
if path == "/" {
_, _ = datawriter.WriteString("/index.html /\n")
} else {
_, _ = datawriter.WriteString(path + "/$1.{html} " + path + "/$1\n")
}
}
datawriter.Flush()
file.Close()

return nil
}
Expand Down Expand Up @@ -63,6 +93,3 @@ func index(links []Link) (index Index) {
index.Backlinks = backlinkMap
return index
}



0 comments on commit 3c17ec3

Please sign in to comment.