mirror of
https://github.com/osmarks/mycorrhiza.git
synced 2025-01-07 02:10:26 +00:00
Move backlinks stuff to a separate module
This commit is contained in:
parent
fbcbd0e445
commit
1f36af66a5
@ -1,14 +1,15 @@
|
||||
package hyphae
|
||||
// Package backlinks maintains the index of backlinks and lets you update it and query it.
|
||||
package backlinks
|
||||
|
||||
import (
|
||||
"github.com/bouncepaw/mycomarkup/v3/tools"
|
||||
"os"
|
||||
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae"
|
||||
"github.com/bouncepaw/mycorrhiza/util"
|
||||
"os"
|
||||
|
||||
"github.com/bouncepaw/mycomarkup/v3"
|
||||
"github.com/bouncepaw/mycomarkup/v3/links"
|
||||
"github.com/bouncepaw/mycomarkup/v3/mycocontext"
|
||||
"github.com/bouncepaw/mycomarkup/v3/tools"
|
||||
)
|
||||
|
||||
// Using set here seems like the most appropriate solution
|
||||
@ -22,7 +23,7 @@ func toLinkSet(xs []string) linkSet {
|
||||
return result
|
||||
}
|
||||
|
||||
func fetchText(h *Hypha) string {
|
||||
func fetchText(h *hyphae.Hypha) string {
|
||||
if h.TextPath == "" {
|
||||
return ""
|
||||
}
|
||||
@ -70,7 +71,7 @@ type backlinkIndexDeletion struct {
|
||||
Links []string
|
||||
}
|
||||
|
||||
// Apply changes backlink index respective to the operation data
|
||||
// apply changes backlink index respective to the operation data
|
||||
func (op backlinkIndexDeletion) apply() {
|
||||
for _, link := range op.Links {
|
||||
if lSet, exists := backlinkIndex[link]; exists {
|
||||
@ -105,7 +106,7 @@ var backlinkConveyor = make(chan backlinkIndexOperation, 64)
|
||||
// IndexBacklinks traverses all text hyphae, extracts links from them and forms an initial index
|
||||
func IndexBacklinks() {
|
||||
// It is safe to ignore the mutex, because there is only one worker.
|
||||
src := FilterTextHyphae(YieldExistingHyphae())
|
||||
src := hyphae.FilterTextHyphae(hyphae.YieldExistingHyphae())
|
||||
for h := range src {
|
||||
foundLinks := extractHyphaLinksFromContent(h.Name, fetchText(h))
|
||||
for _, link := range foundLinks {
|
||||
@ -127,7 +128,7 @@ func RunBacklinksConveyor() {
|
||||
}
|
||||
|
||||
// BacklinksCount returns the amount of backlinks to the hypha.
|
||||
func BacklinksCount(h *Hypha) int {
|
||||
func BacklinksCount(h *hyphae.Hypha) int {
|
||||
if _, exists := backlinkIndex[h.Name]; exists {
|
||||
return len(backlinkIndex[h.Name])
|
||||
}
|
||||
@ -135,20 +136,20 @@ func BacklinksCount(h *Hypha) int {
|
||||
}
|
||||
|
||||
// BacklinksOnEdit is a creation/editing hook for backlinks index
|
||||
func BacklinksOnEdit(h *Hypha, oldText string) {
|
||||
func BacklinksOnEdit(h *hyphae.Hypha, oldText string) {
|
||||
oldLinks := extractHyphaLinksFromContent(h.Name, oldText)
|
||||
newLinks := extractHyphaLinks(h)
|
||||
backlinkConveyor <- backlinkIndexEdit{h.Name, oldLinks, newLinks}
|
||||
}
|
||||
|
||||
// BacklinksOnDelete is a deletion hook for backlinks index
|
||||
func BacklinksOnDelete(h *Hypha, oldText string) {
|
||||
func BacklinksOnDelete(h *hyphae.Hypha, oldText string) {
|
||||
oldLinks := extractHyphaLinksFromContent(h.Name, oldText)
|
||||
backlinkConveyor <- backlinkIndexDeletion{h.Name, oldLinks}
|
||||
}
|
||||
|
||||
// BacklinksOnRename is a renaming hook for backlinks index
|
||||
func BacklinksOnRename(h *Hypha, oldName string) {
|
||||
func BacklinksOnRename(h *hyphae.Hypha, oldName string) {
|
||||
actualLinks := extractHyphaLinks(h)
|
||||
backlinkConveyor <- backlinkIndexRenaming{oldName, h.Name, actualLinks}
|
||||
}
|
||||
@ -157,7 +158,7 @@ func BacklinksOnRename(h *Hypha, oldName string) {
|
||||
func YieldHyphaBacklinks(query string) <-chan string {
|
||||
hyphaName := util.CanonicalName(query)
|
||||
out := make(chan string)
|
||||
sorted := PathographicSort(out)
|
||||
sorted := hyphae.PathographicSort(out)
|
||||
go func() {
|
||||
backlinks, exists := backlinkIndex[hyphaName]
|
||||
if exists {
|
||||
@ -171,7 +172,7 @@ func YieldHyphaBacklinks(query string) <-chan string {
|
||||
}
|
||||
|
||||
// extractHyphaLinks extracts hypha links from a desired hypha
|
||||
func extractHyphaLinks(h *Hypha) []string {
|
||||
func extractHyphaLinks(h *hyphae.Hypha) []string {
|
||||
return extractHyphaLinksFromContent(h.Name, fetchText(h))
|
||||
}
|
||||
|
@ -26,8 +26,6 @@ func Index(path string) {
|
||||
h.insert()
|
||||
}
|
||||
}
|
||||
|
||||
IndexBacklinks()
|
||||
log.Println("Indexed", Count(), "hyphae")
|
||||
}
|
||||
|
||||
|
4
main.go
4
main.go
@ -6,6 +6,7 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
"log"
|
||||
"os"
|
||||
|
||||
@ -39,7 +40,8 @@ func main() {
|
||||
|
||||
// Init the subsystems:
|
||||
hyphae.Index(files.HyphaeDir())
|
||||
go hyphae.RunBacklinksConveyor()
|
||||
backlinks.IndexBacklinks()
|
||||
go backlinks.RunBacklinksConveyor()
|
||||
user.InitUserDatabase()
|
||||
history.Start()
|
||||
history.InitGitRepo()
|
||||
|
@ -2,6 +2,7 @@ package shroom
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
|
||||
"github.com/bouncepaw/mycorrhiza/history"
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae"
|
||||
@ -25,7 +26,7 @@ func DeleteHypha(u *user.User, h *hyphae.Hypha, lc *l18n.Localizer) (hop *histor
|
||||
WithUser(u).
|
||||
Apply()
|
||||
if !hop.HasErrors() {
|
||||
hyphae.BacklinksOnDelete(h, originalText)
|
||||
backlinks.BacklinksOnDelete(h, originalText)
|
||||
h.Delete()
|
||||
}
|
||||
return hop, ""
|
||||
|
@ -3,6 +3,7 @@ package shroom
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
"regexp"
|
||||
|
||||
"github.com/bouncepaw/mycorrhiza/history"
|
||||
@ -74,7 +75,7 @@ func RenameHypha(h *hyphae.Hypha, newHypha *hyphae.Hypha, recursive bool, u *use
|
||||
h.TextPath = replaceName(h.TextPath)
|
||||
h.BinaryPath = replaceName(h.BinaryPath)
|
||||
h.Unlock()
|
||||
hyphae.BacklinksOnRename(h, oldName)
|
||||
backlinks.BacklinksOnRename(h, oldName)
|
||||
}
|
||||
}
|
||||
return hop, ""
|
||||
|
@ -4,6 +4,7 @@ import (
|
||||
"bytes"
|
||||
"errors"
|
||||
"fmt"
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
"io"
|
||||
"log"
|
||||
"mime/multipart"
|
||||
@ -105,7 +106,7 @@ func uploadHelp(h *hyphae.Hypha, hop *history.Op, ext string, data []byte, u *us
|
||||
}
|
||||
*originalFullPath = fullPath
|
||||
if hop.Type == history.TypeEditText {
|
||||
hyphae.BacklinksOnEdit(h, originalText)
|
||||
backlinks.BacklinksOnEdit(h, originalText)
|
||||
}
|
||||
return hop.WithFiles(fullPath).WithUser(u).Apply(), ""
|
||||
}
|
||||
|
@ -1,5 +1,6 @@
|
||||
{% import "net/http" %}
|
||||
{% import "strings" %}
|
||||
{% import "github.com/bouncepaw/mycorrhiza/hyphae/backlinks" %}
|
||||
{% import "github.com/bouncepaw/mycorrhiza/l18n" %}
|
||||
{% import "github.com/bouncepaw/mycorrhiza/user" %}
|
||||
{% import "github.com/bouncepaw/mycorrhiza/hyphae" %}
|
||||
@ -16,7 +17,7 @@
|
||||
{% code
|
||||
u := user.FromRequest(rq)
|
||||
lc := l18n.FromRequest(rq)
|
||||
backs := hyphae.BacklinksCount(h)
|
||||
backs := backlinks.BacklinksCount(h)
|
||||
%}
|
||||
<nav class="hypha-info">
|
||||
<ul class="hypha-info__list">
|
||||
|
@ -11,268 +11,271 @@ import "net/http"
|
||||
import "strings"
|
||||
|
||||
//line views/nav.qtpl:3
|
||||
import "github.com/bouncepaw/mycorrhiza/l18n"
|
||||
import "github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
|
||||
//line views/nav.qtpl:4
|
||||
import "github.com/bouncepaw/mycorrhiza/user"
|
||||
import "github.com/bouncepaw/mycorrhiza/l18n"
|
||||
|
||||
//line views/nav.qtpl:5
|
||||
import "github.com/bouncepaw/mycorrhiza/user"
|
||||
|
||||
//line views/nav.qtpl:6
|
||||
import "github.com/bouncepaw/mycorrhiza/hyphae"
|
||||
|
||||
//line views/nav.qtpl:7
|
||||
//line views/nav.qtpl:8
|
||||
import (
|
||||
qtio422016 "io"
|
||||
|
||||
qt422016 "github.com/valyala/quicktemplate"
|
||||
)
|
||||
|
||||
//line views/nav.qtpl:7
|
||||
//line views/nav.qtpl:8
|
||||
var (
|
||||
_ = qtio422016.Copy
|
||||
_ = qt422016.AcquireByteBuffer
|
||||
)
|
||||
|
||||
//line views/nav.qtpl:7
|
||||
//line views/nav.qtpl:8
|
||||
func streamhyphaInfoEntry(qw422016 *qt422016.Writer, h *hyphae.Hypha, u *user.User, action, displayText string) {
|
||||
//line views/nav.qtpl:7
|
||||
//line views/nav.qtpl:8
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:8
|
||||
//line views/nav.qtpl:9
|
||||
if u.CanProceed(action) {
|
||||
//line views/nav.qtpl:8
|
||||
//line views/nav.qtpl:9
|
||||
qw422016.N().S(`
|
||||
<li class="hypha-info__entry hypha-info__entry_`)
|
||||
//line views/nav.qtpl:9
|
||||
//line views/nav.qtpl:10
|
||||
qw422016.E().S(action)
|
||||
//line views/nav.qtpl:9
|
||||
//line views/nav.qtpl:10
|
||||
qw422016.N().S(`">
|
||||
<a class="hypha-info__link" href="/`)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.E().S(action)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.N().S(`/`)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.E().S(h.Name)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.N().S(`">`)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.E().S(displayText)
|
||||
//line views/nav.qtpl:10
|
||||
//line views/nav.qtpl:11
|
||||
qw422016.N().S(`</a>
|
||||
</li>
|
||||
`)
|
||||
//line views/nav.qtpl:12
|
||||
//line views/nav.qtpl:13
|
||||
}
|
||||
//line views/nav.qtpl:12
|
||||
//line views/nav.qtpl:13
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
func writehyphaInfoEntry(qq422016 qtio422016.Writer, h *hyphae.Hypha, u *user.User, action, displayText string) {
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
qw422016 := qt422016.AcquireWriter(qq422016)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
streamhyphaInfoEntry(qw422016, h, u, action, displayText)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
qt422016.ReleaseWriter(qw422016)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
func hyphaInfoEntry(h *hyphae.Hypha, u *user.User, action, displayText string) string {
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
qb422016 := qt422016.AcquireByteBuffer()
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
writehyphaInfoEntry(qb422016, h, u, action, displayText)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
qs422016 := string(qb422016.B)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
qt422016.ReleaseByteBuffer(qb422016)
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
return qs422016
|
||||
//line views/nav.qtpl:13
|
||||
//line views/nav.qtpl:14
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:15
|
||||
//line views/nav.qtpl:16
|
||||
func streamhyphaInfo(qw422016 *qt422016.Writer, rq *http.Request, h *hyphae.Hypha) {
|
||||
//line views/nav.qtpl:15
|
||||
//line views/nav.qtpl:16
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:17
|
||||
//line views/nav.qtpl:18
|
||||
u := user.FromRequest(rq)
|
||||
lc := l18n.FromRequest(rq)
|
||||
backs := hyphae.BacklinksCount(h)
|
||||
backs := backlinks.BacklinksCount(h)
|
||||
|
||||
//line views/nav.qtpl:20
|
||||
//line views/nav.qtpl:21
|
||||
qw422016.N().S(`
|
||||
<nav class="hypha-info">
|
||||
<ul class="hypha-info__list">
|
||||
`)
|
||||
//line views/nav.qtpl:23
|
||||
//line views/nav.qtpl:24
|
||||
streamhyphaInfoEntry(qw422016, h, u, "history", lc.Get("ui.history_link"))
|
||||
//line views/nav.qtpl:23
|
||||
//line views/nav.qtpl:24
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:24
|
||||
//line views/nav.qtpl:25
|
||||
streamhyphaInfoEntry(qw422016, h, u, "rename-ask", lc.Get("ui.rename_link"))
|
||||
//line views/nav.qtpl:24
|
||||
//line views/nav.qtpl:25
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:25
|
||||
//line views/nav.qtpl:26
|
||||
streamhyphaInfoEntry(qw422016, h, u, "delete-ask", lc.Get("ui.delete_link"))
|
||||
//line views/nav.qtpl:25
|
||||
//line views/nav.qtpl:26
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:26
|
||||
//line views/nav.qtpl:27
|
||||
streamhyphaInfoEntry(qw422016, h, u, "text", lc.Get("ui.text_link"))
|
||||
//line views/nav.qtpl:26
|
||||
//line views/nav.qtpl:27
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:27
|
||||
//line views/nav.qtpl:28
|
||||
streamhyphaInfoEntry(qw422016, h, u, "attachment", lc.Get("ui.attachment_link"))
|
||||
//line views/nav.qtpl:27
|
||||
//line views/nav.qtpl:28
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:28
|
||||
//line views/nav.qtpl:29
|
||||
streamhyphaInfoEntry(qw422016, h, u, "backlinks", lc.GetPlural("ui.backlinks_link", backs))
|
||||
//line views/nav.qtpl:28
|
||||
//line views/nav.qtpl:29
|
||||
qw422016.N().S(`
|
||||
</ul>
|
||||
</nav>
|
||||
`)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
func writehyphaInfo(qq422016 qtio422016.Writer, rq *http.Request, h *hyphae.Hypha) {
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
qw422016 := qt422016.AcquireWriter(qq422016)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
streamhyphaInfo(qw422016, rq, h)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
qt422016.ReleaseWriter(qw422016)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
func hyphaInfo(rq *http.Request, h *hyphae.Hypha) string {
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
qb422016 := qt422016.AcquireByteBuffer()
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
writehyphaInfo(qb422016, rq, h)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
qs422016 := string(qb422016.B)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
qt422016.ReleaseByteBuffer(qb422016)
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
return qs422016
|
||||
//line views/nav.qtpl:31
|
||||
//line views/nav.qtpl:32
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:33
|
||||
//line views/nav.qtpl:34
|
||||
func streamsiblingHyphaeHTML(qw422016 *qt422016.Writer, siblings string, lc *l18n.Localizer) {
|
||||
//line views/nav.qtpl:33
|
||||
//line views/nav.qtpl:34
|
||||
qw422016.N().S(`
|
||||
<aside class="sibling-hyphae layout-card">
|
||||
<h2 class="sibling-hyphae__title layout-card__title">`)
|
||||
//line views/nav.qtpl:35
|
||||
//line views/nav.qtpl:36
|
||||
qw422016.E().S(lc.Get("ui.sibling_hyphae"))
|
||||
//line views/nav.qtpl:35
|
||||
//line views/nav.qtpl:36
|
||||
qw422016.N().S(`</h2>
|
||||
`)
|
||||
//line views/nav.qtpl:36
|
||||
//line views/nav.qtpl:37
|
||||
qw422016.N().S(siblings)
|
||||
//line views/nav.qtpl:36
|
||||
//line views/nav.qtpl:37
|
||||
qw422016.N().S(`
|
||||
</aside>
|
||||
`)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
func writesiblingHyphaeHTML(qq422016 qtio422016.Writer, siblings string, lc *l18n.Localizer) {
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
qw422016 := qt422016.AcquireWriter(qq422016)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
streamsiblingHyphaeHTML(qw422016, siblings, lc)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
qt422016.ReleaseWriter(qw422016)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
func siblingHyphaeHTML(siblings string, lc *l18n.Localizer) string {
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
qb422016 := qt422016.AcquireByteBuffer()
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
writesiblingHyphaeHTML(qb422016, siblings, lc)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
qs422016 := string(qb422016.B)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
qt422016.ReleaseByteBuffer(qb422016)
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
return qs422016
|
||||
//line views/nav.qtpl:38
|
||||
//line views/nav.qtpl:39
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:40
|
||||
//line views/nav.qtpl:41
|
||||
func StreamSubhyphaeHTML(qw422016 *qt422016.Writer, subhyphae string, lc *l18n.Localizer) {
|
||||
//line views/nav.qtpl:40
|
||||
//line views/nav.qtpl:41
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:41
|
||||
//line views/nav.qtpl:42
|
||||
if strings.TrimSpace(subhyphae) != "" {
|
||||
//line views/nav.qtpl:41
|
||||
//line views/nav.qtpl:42
|
||||
qw422016.N().S(`
|
||||
<section class="subhyphae">
|
||||
<h2 class="subhyphae__title">`)
|
||||
//line views/nav.qtpl:43
|
||||
//line views/nav.qtpl:44
|
||||
qw422016.E().S(lc.Get("ui.subhyphae"))
|
||||
//line views/nav.qtpl:43
|
||||
//line views/nav.qtpl:44
|
||||
qw422016.N().S(`</h2>
|
||||
<nav class="subhyphae__nav">
|
||||
<ul class="subhyphae__list">
|
||||
`)
|
||||
//line views/nav.qtpl:46
|
||||
//line views/nav.qtpl:47
|
||||
qw422016.N().S(subhyphae)
|
||||
//line views/nav.qtpl:46
|
||||
//line views/nav.qtpl:47
|
||||
qw422016.N().S(`
|
||||
</ul>
|
||||
</nav>
|
||||
</section>
|
||||
`)
|
||||
//line views/nav.qtpl:50
|
||||
//line views/nav.qtpl:51
|
||||
}
|
||||
//line views/nav.qtpl:50
|
||||
//line views/nav.qtpl:51
|
||||
qw422016.N().S(`
|
||||
`)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
func WriteSubhyphaeHTML(qq422016 qtio422016.Writer, subhyphae string, lc *l18n.Localizer) {
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
qw422016 := qt422016.AcquireWriter(qq422016)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
StreamSubhyphaeHTML(qw422016, subhyphae, lc)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
qt422016.ReleaseWriter(qw422016)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
}
|
||||
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
func SubhyphaeHTML(subhyphae string, lc *l18n.Localizer) string {
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
qb422016 := qt422016.AcquireByteBuffer()
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
WriteSubhyphaeHTML(qb422016, subhyphae, lc)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
qs422016 := string(qb422016.B)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
qt422016.ReleaseByteBuffer(qb422016)
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
return qs422016
|
||||
//line views/nav.qtpl:51
|
||||
//line views/nav.qtpl:52
|
||||
}
|
||||
|
@ -1,12 +1,12 @@
|
||||
package web
|
||||
|
||||
import (
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
"io"
|
||||
"net/http"
|
||||
|
||||
"github.com/gorilla/mux"
|
||||
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae"
|
||||
"github.com/bouncepaw/mycorrhiza/l18n"
|
||||
"github.com/bouncepaw/mycorrhiza/user"
|
||||
"github.com/bouncepaw/mycorrhiza/util"
|
||||
@ -26,7 +26,7 @@ func handlerBacklinks(w http.ResponseWriter, rq *http.Request) {
|
||||
)
|
||||
util.HTTP200Page(w, views.BaseHTML(
|
||||
lc.Get("ui.backlinks_title", &l18n.Replacements{"query": util.BeautifulName(hyphaName)}),
|
||||
views.BacklinksHTML(hyphaName, hyphae.YieldHyphaBacklinks, lc),
|
||||
views.BacklinksHTML(hyphaName, backlinks.YieldHyphaBacklinks, lc),
|
||||
lc,
|
||||
user.FromRequest(rq)))
|
||||
}
|
||||
@ -36,6 +36,6 @@ func handlerBacklinksJSON(w http.ResponseWriter, rq *http.Request) {
|
||||
w.WriteHeader(http.StatusOK)
|
||||
_, _ = io.WriteString(
|
||||
w,
|
||||
views.TitleSearchJSON(hyphaName, hyphae.YieldHyphaBacklinks),
|
||||
views.TitleSearchJSON(hyphaName, backlinks.YieldHyphaBacklinks),
|
||||
)
|
||||
}
|
||||
|
@ -2,6 +2,7 @@ package web
|
||||
|
||||
// stuff.go is used for meta stuff about the wiki or all hyphae at once.
|
||||
import (
|
||||
"github.com/bouncepaw/mycorrhiza/hyphae/backlinks"
|
||||
"io"
|
||||
"log"
|
||||
"math/rand"
|
||||
@ -109,6 +110,7 @@ func handlerReindex(w http.ResponseWriter, rq *http.Request) {
|
||||
hyphae.ResetCount()
|
||||
log.Println("Reindexing hyphae in", files.HyphaeDir())
|
||||
hyphae.Index(files.HyphaeDir())
|
||||
backlinks.IndexBacklinks()
|
||||
http.Redirect(w, rq, "/", http.StatusSeeOther)
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user