mirror of https://github.com/Hilbis/Hilbish
Compare commits
2 Commits
0a225ac847
...
229fe4c6bb
Author | SHA1 | Date |
---|---|---|
James Dugan | 229fe4c6bb | |
sammyette | 16b39fe157 |
|
@ -1,5 +1,9 @@
|
|||
# 🎀 Changelog
|
||||
|
||||
## Unreleased
|
||||
### Added
|
||||
- `cat` command now reads files in chunks, allowing for reading large files
|
||||
|
||||
## [2.2.2] - 2024-04-16
|
||||
### Fixed
|
||||
- Line refresh fixes (less flicker)
|
||||
|
|
11
api.go
11
api.go
|
@ -712,5 +712,14 @@ func hlhinter(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
|
|||
// #example
|
||||
// #param line string
|
||||
func hlhighlighter(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
|
||||
return c.Next(), nil
|
||||
if err := c.Check1Arg(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
line, err := c.StringArg(0)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return c.PushingNext1(t.Runtime, rt.StringValue(line)), nil
|
||||
}
|
||||
|
|
|
@ -9,6 +9,8 @@ commander.register('cat', function(args, sinks)
|
|||
usage: cat [file]...]]
|
||||
end
|
||||
|
||||
local chunk_size = 2^13 -- 8K buffer size
|
||||
|
||||
for _, fName in ipairs(args) do
|
||||
local f = io.open(fName)
|
||||
if f == nil then
|
||||
|
@ -17,7 +19,12 @@ usage: cat [file]...]]
|
|||
goto continue
|
||||
end
|
||||
|
||||
sinks.out:writeln(f:read '*a')
|
||||
while true do
|
||||
local block = f:read(chunk_size)
|
||||
if not block then break end
|
||||
sinks.out:write(block)
|
||||
end
|
||||
sinks.out:writeln("")
|
||||
::continue::
|
||||
end
|
||||
io.flush()
|
||||
|
|
13
rl.go
13
rl.go
|
@ -70,11 +70,8 @@ func newLineReader(prompt string, noHist bool) *lineReader {
|
|||
hooks.Emit("hilbish.vimAction", actionStr, args)
|
||||
}
|
||||
rl.HintText = func(line []rune, pos int) []rune {
|
||||
if hinter == nil {
|
||||
return []rune{}
|
||||
}
|
||||
|
||||
retVal, err := rt.Call1(l.MainThread(), rt.FunctionValue(hinter),
|
||||
hinter := hshMod.Get(rt.StringValue("hinter"))
|
||||
retVal, err := rt.Call1(l.MainThread(), hinter,
|
||||
rt.StringValue(string(line)), rt.IntValue(int64(pos)))
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
|
@ -89,10 +86,8 @@ func newLineReader(prompt string, noHist bool) *lineReader {
|
|||
return []rune(hintText)
|
||||
}
|
||||
rl.SyntaxHighlighter = func(line []rune) string {
|
||||
if highlighter == nil {
|
||||
return string(line)
|
||||
}
|
||||
retVal, err := rt.Call1(l.MainThread(), rt.FunctionValue(highlighter),
|
||||
highlighter := hshMod.Get(rt.StringValue("highlighter"))
|
||||
retVal, err := rt.Call1(l.MainThread(), highlighter,
|
||||
rt.StringValue(string(line)))
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
|
|
Loading…
Reference in New Issue