Skip to content

Commit

Permalink
Changes to work with pragtical luajit
Browse files Browse the repository at this point in the history
  • Loading branch information
jgmdev committed Sep 28, 2023
1 parent ba5def2 commit 2df66ba
Show file tree
Hide file tree
Showing 6 changed files with 135 additions and 62 deletions.
5 changes: 3 additions & 2 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ jobs:
- name: Create Release(s)
env: { GITHUB_TOKEN: "${{ github.token }}" }
run: |
if [[ `git tag --points-at HEAD | head -c 1` == "v" ]]; then
if git tag --points-at HEAD | tail -n1 | grep "^v"; then
gh release delete -y v$VERSION || true;
gh release create -t v$VERSION v$VERSION *.so *.dll
gh release delete -y latest || true;
Expand All @@ -34,6 +34,7 @@ jobs:
gh release delete -y continuous || true; gh release create -p -t 'Continuous Release' continuous *.so *.dll
build_macos:
permissions: write-all
needs: build_linux_windows
runs-on: macos-11
env:
Expand All @@ -53,7 +54,7 @@ jobs:
BIN=libterminal.x86_64-darwin.so ./build.sh -O3 -DLIBTERMINAL_VERSION='"'$VERSION-x86_64-darwin'"'
BIN=libterminal.aarch64-darwin.so CC=clang CFLAGS="-arch arm64" ./build.sh -O3 -DLIBTERMINAL_VERSION='"'$VERSION-x86_64-darwin'"'
gh release upload continuous *.so
if [[ `git tag --points-at HEAD | head -c 1` == "v" ]]; then
if git tag --points-at HEAD | tail -n1 | grep "^v"; then
gh release upload v$VERSION *.so
gh release upload latest *.so
git branch -f latest HEAD
Expand Down
2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
Copyright (c) 2023 lite-xl Team
Copyright (c) 2023 Pragtical Team

Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
Expand All @@ -17,4 +18,3 @@ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

33 changes: 16 additions & 17 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
# lite-xl-terminal
# pragtical-terminal

`lite-xl-terminal` is a (mostly) fully-featured terminal emulator designed to
slot into lite-xl as a plugin for windows (Windows 10+ only), mac and linux.
`pragtical-terminal` is a (mostly) fully-featured terminal emulator designed to
slot into pragtical as a plugin for windows (Windows 10+ only), mac and linux.

![image](https://github.com/adamharrison/lite-xl-terminal/assets/1034518/eb8a72a0-ff61-4b95-b009-364ac2725f70)
![image](https://github.com/adamharrison/lite-xl-terminal/assets/1034518/6b8003da-d4c1-4227-8fc9-3d2b1ae89bf2)

## Description

Expand Down Expand Up @@ -52,43 +52,43 @@ More shells should work, but are not tested outright.

## Installation

The easiest way to install `lite-xl-terminal` is to use
[`lpm`](https://github.com/lite-xl/lite-xl-plugin-manager), and then run the
The easiest way to install `pragtical-terminal` is to use
[`ppm`](https://github.com/pragtical/plugin-manager), and then run the
following command:

```
lpm install terminal
ppm install terminal
```

If you want to simply try it out, you can use `lpm`'s `run` command:
If you want to simply try it out, you can use `ppm`'s `run` command:

```
lpm run terminal
ppm run terminal
```

If you want to grab it directly, and build it from the repo, on Linux, Mac
or MSYS on Windows you can do:

```
git clone --depth=1 https://github.com/adamharrison/lite-xl-terminal.git \
--recurse-submodules --shallow-submodules && cd lite-xl-terminal && \
./build.sh && cp -R plugins/terminal ~/.config/lite-xl/plugins && \
cp libterminal.so ~/.config/lite-xl/plugins/terminal
git clone --depth=1 https://github.com/pragtical/terminal.git \
--recurse-submodules --shallow-submodules && cd terminal && \
./build.sh && cp -R plugins/terminal ~/.config/pragtical/plugins && \
cp libterminal.so ~/.config/pragtical/plugins/terminal
```

If you want to install on Windows, but don't have MSYS, you can download
the files directly from our [release](https://github.com/adamharrison/lite-xl-terminal/releases/tag/latest)
the files directly from our [release](https://github.com/pragtical/terminal/releases/tag/latest)
page, download `libterminal.x86_64-windows.dll`, as well as the Source Code,
and place both the dll, and the `plugins/terminal/init.lua` from the source
code archive into your lite-xl plugins directory as `plugins/terminal/init.lua`
code archive into your pragtical plugins directory as `plugins/terminal/init.lua`
and `plugins/terminal/libterminal.x86_64-windows.dll`.

### Stanalone

If you want to use terminal as a standalone terminal, here's a handy script you can use:

```
LITE_SCALE=1 lpm run terminal --config 'config.plugins.treeview=false config.plugins.workspace=false config.always_show_tabs=false local _,_,x,y = system.get_window_size() system.set_window_size(800, 500, x, y) local TerminalView = require "plugins.terminal".class local old_close = TerminalView.close function TerminalView:close() old_close(self) os.exit(0) end core.add_thread(function() command.perform("terminal:open-tab") local node = core.root_view.root_node:get_node_for_view(core.status_view) node:close_view(core.root_view.root_node, core.status_view) end)'
PRAGTICAL_SCALE=1 ppm run terminal --config 'config.plugins.treeview=false config.plugins.workspace=false config.always_show_tabs=false local _,_,x,y = system.get_window_size() system.set_window_size(800, 500, x, y) local TerminalView = require "plugins.terminal".class local old_close = TerminalView.close function TerminalView:close() old_close(self) os.exit(0) end core.add_thread(function() command.perform("terminal:open-tab") local node = core.root_view.root_node:get_node_for_view(core.status_view) node:close_view(core.root_view.root_node, core.status_view) end)'
```

## Status
Expand All @@ -112,4 +112,3 @@ dependencies other than the native OS libraries for each OS.
```
CC=x86_64-w64-mingw32-gcc BIN=libterminal.dll ./build.sh -g
```

53 changes: 23 additions & 30 deletions manifest.json
Original file line number Diff line number Diff line change
@@ -1,32 +1,25 @@
{
"addons" : [
{
"description" : "An integrated terminal for lite-xl.",
"files" : [
{
"arch" : "x86_64-linux",
"checksum" : "0b463b4a6fc54cbe19f63431a5c592a6a99e21843d5b8af3ca88f599f7c6a10f",
"url" : "https://github.com/adamharrison/lite-xl-terminal/releases/download/v1.0/libterminal.x86_64-linux.so"
},
{
"arch" : "x86_64-darwin",
"checksum" : "c453965bbaa9f3f749c43d42e5607b254c9972f878e84b2e832f67b98882874d",
"url" : "https://github.com/adamharrison/lite-xl-terminal/releases/download/v1.0/libterminal.x86_64-darwin.so"
},
{
"arch" : "aarch64-darwin",
"checksum" : "1f906b567b32b6761757a91aaec0d9569e59d0ca46b3ef6933dd753a008690f6",
"url" : "https://github.com/adamharrison/lite-xl-terminal/releases/download/v1.0/libterminal.aarch64-darwin.so"
},
{
"arch" : "x86_64-windows",
"checksum" : "d95b64465f69b6be847efd09cb6d304a40bb06945e856d09f78e1e7402d97cf1",
"url" : "https://github.com/adamharrison/lite-xl-terminal/releases/download/v1.0/libterminal.x86_64-windows.dll"
}
],
"id" : "terminal",
"path" : "plugins/terminal",
"version" : "1.0"
}
]
"addons": [{
"id": "terminal",
"description": "An integrated terminal for pragtical.",
"version": "1.0",
"path": "plugins/terminal",
"files": [{
"url": "https://github.com/pragtical/terminal/releases/download/latest/libterminal.x86_64-linux.so",
"arch": "x86_64-linux",
"checksum": "SKIP"
}, {
"url": "https://github.com/pragtical/terminal/releases/download/latest/libterminal.x86_64-darwin.so",
"arch": "x86_64-darwin",
"checksum": "SKIP"
}, {
"url": "https://github.com/pragtical/terminal/releases/download/latest/libterminal.aarch64-darwin.so",
"arch": "aarch64-darwin",
"checksum": "SKIP"
}, {
"url": "https://github.com/pragtical/terminal/releases/download/latest/libterminal.x86_64-windows.dll",
"arch": "x86_64-windows",
"checksum": "SKIP"
}]
}]
}
100 changes: 89 additions & 11 deletions plugins/terminal/init.lua
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,79 @@ config.plugins.terminal = common.merge({
[245] = { common.color "#8a8a8a" }, [246] = { common.color "#949494" }, [247] = { common.color "#9e9e9e" }, [248] = { common.color "#a8a8a8" }, [249] = { common.color "#b2b2b2" },
[250] = { common.color "#bcbcbc" }, [251] = { common.color "#c6c6c6" }, [252] = { common.color "#d0d0d0" }, [253] = { common.color "#dadada" }, [254] = { common.color "#e4e4e4" },
[255] = { common.color "#eeeeee" }
},
config_spec = {
name = "Terminal",
{
label = "Shell",
description = "Path to the shell binary.",
path = "shell",
type = "file",
exists = true,
default = default_shell
},
{
label = "Drawer Height",
description = "Default height of the console drawer.",
path = "drawer_height",
type = "number",
default = 300,
min = 10
},
{
label = "Scrollback Limit",
description = "Amount of lines you can emit before we start cutting them off.",
path = "scrollback_limit",
type = "number",
default = 10000
},
{
label = "Background Color",
description = "Default background color if not explicitly set by the shell.",
path = "background",
type = "color",
default = { common.color "#000000" },
},
{
label = "Foreground Color",
description = "Default foreground color if not explicitly set by the shell.",
path = "text",
type = "color",
default = { common.color "#FFFFFF" },
},
{
label = "Font",
description = "The font and fallbacks used on the terminal.",
path = "font",
type = "font",
default = {
fonts = {
{
name = "JetBrains Mono Regular",
path = DATADIR .. "/fonts/JetBrainsMono-Regular.ttf"
}
},
options = {
size = 15,
antialiasing = "subpixel",
hinting = "slight"
}
}
},
{
label = "Bold Text in Bright Colors",
description = "Whether to use bright colors for bold text.",
path = "bold_text_in_bright_colors",
type = "toggle",
default = true
},
{
label = "Debug",
description = "Outputs a terminal.log file of all the output of your shell.",
path = "debug",
type = "toggle",
default = false
}
}
}, config.plugins.terminal)
if not config.plugins.terminal.bold_font then config.plugins.terminal.bold_font = config.plugins.terminal.font:copy(style.code_font:get_size(), { smoothing = true }) end
Expand Down Expand Up @@ -219,20 +292,25 @@ function TerminalView:set_target_size(axis, value)
end

function TerminalView:convert_color(int, target, should_bright)
local attributes = int >> 24
local type = (attributes & 0x7)
local attributes = bit.rshift(int, 24)
local type = bit.band(attributes, 0x7)
if type == 0 then
if target == "foreground" then return self.options.text, attributes end
return self.options.background, attributes
elseif type == 1 then
if target == "foreground" then return self.options.background, attributes end
return self.options.text, attributes
elseif type == 2 then
local index = (int >> 16) & 0xFF
if index < 8 and should_bright and (((attributes >> 3) & 0x1) ~= 0) then index = index + 8 end
return self.options.colors[index], attributes
local index = bit.band(bit.rshift(int, 16), 0xFF)
if index < 8 and should_bright and (bit.band(bit.rshift(attributes, 3), 0x1) ~= 0) then index = index + 8 end
return self.options.colors[tonumber(index)], attributes
elseif type == 3 then
return { ((int >> 16) & 0xFF), ((int >> 8) & 0xFF), ((int >> 0) & 0xFF), 255 }, attributes
return {
tonumber(bit.band(bit.rshift(int, 16), 0xFF)),
tonumber(bit.band(bit.rshift(int, 8), 0xFF)),
tonumber(bit.band(bit.rshift(int, 0), 0xFF)),
255
}, attributes
end
return nil
end
Expand Down Expand Up @@ -274,9 +352,10 @@ function TerminalView:draw()
local offset = 0
local foreground, background, text_style
for i = 1, #line, 2 do
background = self:convert_color(line[i] & 0xFFFFFFFF, "background")
foreground, text_style = self:convert_color(line[i] >> 32, "foreground", self.options.bold_text_in_bright_colors)
local font = (((text_style >> 3) & 0x1) ~= 0) and self.options.bold_font or self.options.font
line[i] = math.tointeger(line[i])
background = self:convert_color(bit.band(line[i], 0xFFFFFFFF), "background")
foreground, text_style = self:convert_color(bit.rshift(line[i], 32), "foreground", self.options.bold_text_in_bright_colors)
local font = (bit.band(bit.rshift(text_style, 3), 0x1) ~= 0) and self.options.bold_font or self.options.font
local text = line[i+1]
local length = text:ulen()
local valid_utf8 = length ~= nil
Expand Down Expand Up @@ -652,6 +731,7 @@ end, {
command.add(nil, {
["terminal:toggle-drawer"] = function()
if not core.terminal_view then
system.chdir(core.root_project().path)
core.terminal_view = TerminalView(config.plugins.terminal)
core.root_view:get_active_node_default():split("down", core.terminal_view, { y = true }, true)
core.set_active_view(core.terminal_view)
Expand Down Expand Up @@ -802,5 +882,3 @@ end
return {
class = TerminalView
}


4 changes: 3 additions & 1 deletion src/libterminal.c
Original file line number Diff line number Diff line change
Expand Up @@ -1238,7 +1238,9 @@ static void output_line(lua_State* L, buffer_char_t* start, buffer_char_t* end,
((uint64_t)style.background.g << 8) |
((uint64_t)style.background.b << 0)
);
lua_pushinteger(L, packed);
char hex_string[24];
sprintf(hex_string, "%lu", packed);
lua_pushstring(L, hex_string);
lua_rawseti(L, -2, ++group);
lua_pushlstring(L, text_buffer, last_nonzero_codepoint);
if (!overflows && start >= end) {
Expand Down

0 comments on commit 2df66ba

Please sign in to comment.