mirror of https://github.com/Hilbis/Hilbish
Compare commits
2 Commits
a7767d9853
...
e1177b5a04
Author | SHA1 | Date |
---|---|---|
sammyette | e1177b5a04 | |
sammyette | 0f97abef0f |
|
@ -4,24 +4,15 @@ on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
- docs-refactor
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
gen:
|
gen:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
with:
|
|
||||||
submodules: true
|
|
||||||
- uses: actions/setup-go@v2
|
- uses: actions/setup-go@v2
|
||||||
- name: Download Task
|
|
||||||
run: 'sh -c "$(curl --location https://taskfile.dev/install.sh)" -- -d'
|
|
||||||
- name: Build
|
|
||||||
run: ./bin/task
|
|
||||||
- name: Run docgen
|
- name: Run docgen
|
||||||
run: go run cmd/docgen/docgen.go
|
run: go run cmd/docgen/docgen.go
|
||||||
- name: Run lua docgen
|
|
||||||
run: ./hilbish cmd/docgen/docgen.lua
|
|
||||||
- name: Commit new docs
|
- name: Commit new docs
|
||||||
uses: stefanzweifel/git-auto-commit-action@v4
|
uses: stefanzweifel/git-auto-commit-action@v4
|
||||||
with:
|
with:
|
||||||
|
|
8
api.go
8
api.go
|
@ -1,6 +1,14 @@
|
||||||
// the core Hilbish API
|
// the core Hilbish API
|
||||||
// The Hilbish module includes the core API, containing
|
// The Hilbish module includes the core API, containing
|
||||||
// interfaces and functions which directly relate to shell functionality.
|
// interfaces and functions which directly relate to shell functionality.
|
||||||
|
// #field ver The version of Hilbish
|
||||||
|
// #field user Username of the user
|
||||||
|
// #field host Hostname of the machine
|
||||||
|
// #field dataDir Directory for Hilbish data files, including the docs and default modules
|
||||||
|
// #field interactive Is Hilbish in an interactive shell?
|
||||||
|
// #field login Is Hilbish the login shell?
|
||||||
|
// #field vimMode Current Vim input mode of Hilbish (will be nil if not in Vim input mode)
|
||||||
|
// #field exitCode xit code of the last executed command
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
|
|
@ -70,16 +70,11 @@ var prefix = map[string]string{
|
||||||
"terminal": "term",
|
"terminal": "term",
|
||||||
}
|
}
|
||||||
|
|
||||||
func setupDoc(mod string, fun *doc.Func) *docPiece {
|
func getTagsAndDocs(docs string) (map[string][]tag, []string) {
|
||||||
docs := strings.TrimSpace(fun.Doc)
|
|
||||||
inInterface := strings.HasPrefix(docs, "#interface")
|
|
||||||
if (!strings.HasPrefix(fun.Name, prefix[mod]) && !inInterface) || (strings.ToLower(fun.Name) == "loader" && !inInterface) {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
pts := strings.Split(docs, "\n")
|
pts := strings.Split(docs, "\n")
|
||||||
parts := []string{}
|
parts := []string{}
|
||||||
tags := make(map[string][]tag)
|
tags := make(map[string][]tag)
|
||||||
|
|
||||||
for _, part := range pts {
|
for _, part := range pts {
|
||||||
if strings.HasPrefix(part, "#") {
|
if strings.HasPrefix(part, "#") {
|
||||||
tagParts := strings.Split(strings.TrimPrefix(part, "#"), " ")
|
tagParts := strings.Split(strings.TrimPrefix(part, "#"), " ")
|
||||||
|
@ -109,6 +104,30 @@ func setupDoc(mod string, fun *doc.Func) *docPiece {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return tags, parts
|
||||||
|
}
|
||||||
|
|
||||||
|
func docPieceTag(tagName string, tags map[string][]tag) []docPiece {
|
||||||
|
dps := []docPiece{}
|
||||||
|
for _, tag := range tags[tagName] {
|
||||||
|
dps = append(dps, docPiece{
|
||||||
|
FuncName: tag.id,
|
||||||
|
Doc: tag.fields,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return dps
|
||||||
|
}
|
||||||
|
|
||||||
|
func setupDoc(mod string, fun *doc.Func) *docPiece {
|
||||||
|
docs := strings.TrimSpace(fun.Doc)
|
||||||
|
inInterface := strings.HasPrefix(docs, "#interface")
|
||||||
|
if (!strings.HasPrefix(fun.Name, prefix[mod]) && !inInterface) || (strings.ToLower(fun.Name) == "loader" && !inInterface) {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
tags, parts := getTagsAndDocs(docs)
|
||||||
|
|
||||||
var interfaces string
|
var interfaces string
|
||||||
funcsig := parts[0]
|
funcsig := parts[0]
|
||||||
doc := parts[1:]
|
doc := parts[1:]
|
||||||
|
@ -121,22 +140,8 @@ func setupDoc(mod string, fun *doc.Func) *docPiece {
|
||||||
}
|
}
|
||||||
em := emmyPiece{FuncName: funcName}
|
em := emmyPiece{FuncName: funcName}
|
||||||
|
|
||||||
// manage fields
|
fields := docPieceTag("field", tags)
|
||||||
fields := []docPiece{}
|
properties := docPieceTag("property", tags)
|
||||||
for _, tag := range tags["field"] {
|
|
||||||
fields = append(fields, docPiece{
|
|
||||||
FuncName: tag.id,
|
|
||||||
Doc: tag.fields,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
properties := []docPiece{}
|
|
||||||
for _, tag := range tags["property"] {
|
|
||||||
properties = append(properties, docPiece{
|
|
||||||
FuncName: tag.id,
|
|
||||||
Doc: tag.fields,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, d := range doc {
|
for _, d := range doc {
|
||||||
if strings.HasPrefix(d, "---") {
|
if strings.HasPrefix(d, "---") {
|
||||||
|
@ -245,7 +250,7 @@ func main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
descParts := strings.Split(strings.TrimSpace(p.Doc), "\n")
|
tags, descParts := getTagsAndDocs(strings.TrimSpace(p.Doc))
|
||||||
shortDesc := descParts[0]
|
shortDesc := descParts[0]
|
||||||
desc := descParts[1:]
|
desc := descParts[1:]
|
||||||
filteredPieces := []docPiece{}
|
filteredPieces := []docPiece{}
|
||||||
|
@ -279,6 +284,8 @@ func main() {
|
||||||
ShortDescription: shortDesc,
|
ShortDescription: shortDesc,
|
||||||
Description: strings.Join(desc, "\n"),
|
Description: strings.Join(desc, "\n"),
|
||||||
HasInterfaces: hasInterfaces,
|
HasInterfaces: hasInterfaces,
|
||||||
|
Properties: docPieceTag("property", tags),
|
||||||
|
Fields: docPieceTag("field", tags),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,70 +0,0 @@
|
||||||
local fs = require 'fs'
|
|
||||||
local emmyPattern = '^%-%-%- (.+)'
|
|
||||||
local pieces = {}
|
|
||||||
|
|
||||||
local files = fs.readdir 'nature'
|
|
||||||
for _, fname in ipairs(files) do
|
|
||||||
local isScript = fname:match'%.lua$'
|
|
||||||
if not isScript then goto continue end
|
|
||||||
|
|
||||||
local f = io.open(string.format('nature/%s', fname))
|
|
||||||
local header = f:read '*l'
|
|
||||||
if not header:match(emmyPattern) then goto continue end
|
|
||||||
|
|
||||||
print(fname)
|
|
||||||
|
|
||||||
local iface = header:match(emmyPattern)
|
|
||||||
pieces[iface] = {}
|
|
||||||
|
|
||||||
local docPiece = {}
|
|
||||||
for line in f:lines() do
|
|
||||||
if line == header then goto continue2 end
|
|
||||||
if not line:match(emmyPattern) then
|
|
||||||
if line:match '^function' then
|
|
||||||
local pattern = (string.format('^function %s.', iface) .. '(%w+)')
|
|
||||||
local funcName = line:match(pattern)
|
|
||||||
pieces[iface][funcName] = docPiece
|
|
||||||
end
|
|
||||||
docPiece = {}
|
|
||||||
goto continue2
|
|
||||||
end
|
|
||||||
|
|
||||||
table.insert(docPiece, line)
|
|
||||||
::continue2::
|
|
||||||
end
|
|
||||||
::continue::
|
|
||||||
end
|
|
||||||
|
|
||||||
for iface, dps in pairs(pieces) do
|
|
||||||
local mod = iface:match '(%w+)%.'
|
|
||||||
local path = string.format('docs/api/%s/%s.md', mod, iface)
|
|
||||||
local f <close> = io.open(path, 'a+')
|
|
||||||
|
|
||||||
print(mod, path)
|
|
||||||
|
|
||||||
for func, docs in pairs(dps) do
|
|
||||||
local params = table.filter(docs, function(t)
|
|
||||||
return t:match '^%-%-%- @param'
|
|
||||||
end)
|
|
||||||
f:write(string.format('## %s(', func))
|
|
||||||
for i, str in ipairs(params) do
|
|
||||||
if i ~= 1 then
|
|
||||||
f:write ', '
|
|
||||||
end
|
|
||||||
f:write(str:match '^%-%-%- @param ([%w]+) ')
|
|
||||||
end
|
|
||||||
f:write(')\n')
|
|
||||||
|
|
||||||
for _, str in ipairs(docs) do
|
|
||||||
if not str:match '^%-%-%- @' then
|
|
||||||
f:write(str:match '^%-%-%- (.+)' .. '\n')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
f:write('\n')
|
|
||||||
end
|
|
||||||
f:flush()
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,16 @@ menu:
|
||||||
The Hilbish module includes the core API, containing
|
The Hilbish module includes the core API, containing
|
||||||
interfaces and functions which directly relate to shell functionality.
|
interfaces and functions which directly relate to shell functionality.
|
||||||
|
|
||||||
|
## Interface fields
|
||||||
|
- `ver`: The version of Hilbish
|
||||||
|
- `user`: Username of the user
|
||||||
|
- `host`: Hostname of the machine
|
||||||
|
- `dataDir`: Directory for Hilbish data files, including the docs and default modules
|
||||||
|
- `interactive`: Is Hilbish in an interactive shell?
|
||||||
|
- `login`: Is Hilbish the login shell?
|
||||||
|
- `vimMode`: Current Vim input mode of Hilbish (will be nil if not in Vim input mode)
|
||||||
|
- `exitCode`: xit code of the last executed command
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
### alias(cmd, orig)
|
### alias(cmd, orig)
|
||||||
Sets an alias of `cmd` to `orig`
|
Sets an alias of `cmd` to `orig`
|
||||||
|
|
Loading…
Reference in New Issue