Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(platforms): add generation for platform files #161

Draft
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

DOD-101
Copy link
Collaborator

@DOD-101 DOD-101 commented Jan 5, 2025

I have ported Tokonights extra-generation system to work for nordic.nvim.

I have adjusted the code to make it more well suited for nordic.nvim, mainly simplifying it, since nordic.nvim doesn't have mutliple flavors, but reversing this to work for multiple flavors in the future wouldn't be a significant challange.

Why?

This would allow for easier creation of additional platforms, as well as help reduce inconsistencies between the different handwritten themes.

To-Do:

The one problem currently is that we would need to find a way to convert the hex color values to work for iTerm2 and Konsole since they use other formats.

However, I don't think this will be a significant blocker.

  • Port the generation system
  • Port all existing themes to the new system
    • Create conversion functions for iTerm2 and Konsole
  • Add CI to update /platforms on each addition / change of one of the template files
  • Update docs

Note on Licensing

Since Tokyonight is licensed under Apache License 2.0 we need to make sure we are in compliance with their License. I have added a note to the top of platforms/init.lua, but I am not sure if this is all that we require.

It might be a good idea to add a NOTICE file.

@DOD-101
Copy link
Collaborator Author

DOD-101 commented Jan 5, 2025

I'm more than willing to implement all the steps listed above, but I would first like to get this approved, before I take the time to implement the rest.

@5-pebbles
Copy link
Collaborator

5-pebbles commented Jan 5, 2025

I am in support of this PR, I think it would make updating the color palate much easier and help keep thing in sync. It would also make vetting new extras faster (no more checking hex codes).

I think the simplest approach for CI would be to just add the generation to the docs_and_format workflow.

If I remember right, we used to have color conversion stuff in utils but then I deleted it all... I will see if I can fish that back up.

Edit: It looks like we still have some of them. I am not near a device with a working nvim config, but something like this should work:

local U = require("nordic.utils")
local r, g, b = U.hex_to_rgb(hex)
return string.format("%d,%d,%d", r, g, b)

I would define that function in the individual themes, because I doubt we will find iTerm2's system anywhere else.

What do you think @AlexvZyl?

@5-pebbles 5-pebbles requested a review from AlexvZyl January 5, 2025 19:06
lua/nordic/platforms/foot.lua Outdated Show resolved Hide resolved
lua/nordic/platforms/init.lua Outdated Show resolved Hide resolved
lua/nordic/platforms/init.lua Outdated Show resolved Hide resolved
lua/nordic/utils.lua Outdated Show resolved Hide resolved
platforms.sh Show resolved Hide resolved
5-pebbles
5-pebbles previously approved these changes Jan 5, 2025
Copy link
Collaborator

@5-pebbles 5-pebbles left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That looks great!

@AlexvZyl
Copy link
Owner

Yeah this is very nice, thanks @DOD-101.

Copy link
Collaborator

@5-pebbles 5-pebbles left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am noticing we have a lot of colors, in the platforms, that aren't used anywhere else... If you can keep those close to their original value, but of course, use values actually in our palette.

Also, thanks for doing this, I didn't realize what a mess it was until now.

I do not personally use all of the platforms and plugins in the list, so if something is not right, or you have a suggestion, please open a PR!
## Contributing a new Platform

All of the platform files are generated using a template system. Have a look at the files in [this directory](https://github.com/AlexvZyl/nordic.nvim/tree/main/lua/nordic/platforms) to see how it works.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This feels a little cumbersome to read:

Suggested change
All of the platform files are generated using a template system. Have a look at the files in [this directory](https://github.com/AlexvZyl/nordic.nvim/tree/main/lua/nordic/platforms) to see how it works.
All of the platform files are generated using a template system. Have a look at [this directory](https://github.com/AlexvZyl/nordic.nvim/tree/main/lua/nordic/platforms) to see how it works.

-- stylua: ignore
---@type table<string, {ext: string, url:string, subdir?: string}>
M.platforms = {
-- fish = { ext = "theme", url = "https://fishshell.com/docs/current/index.html" },
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this supposed to be here?

Comment on lines +104 to +147
---Simple string interpolation.
---
---Example template: "${name} is ${age}"
---
--- This function is taken from tokyonight.
--- For more information see `platforms/init.lua`
---@param str string template string
---@param table table key value pairs to replace in the string
function M.template(str, table)
return (
str:gsub('($%b{})', function(w)
return vim.tbl_get(table, unpack(vim.split(w:sub(3, -2), '.', { plain = true }))) or w
end)
)
end

---Remove the hash (#) from the beginning of all color values in a table
---@param colors table
function M.removeHash(colors)
local output_colors = {}
for k, v in pairs(colors) do
if type(v) == 'string' then
output_colors[k] = v:gsub('^#', '')
elseif type(v) == 'table' then
output_colors[k] = M.removeHash(v)
end
end

return output_colors
end

---Write a file and its contents to disk
---
--- This function is taken from tokyonight.
--- For more information see `platforms/init.lua`
---@param path string
---@param contents string
function M.write(path, contents)
vim.fn.mkdir(vim.fn.fnamemodify(path, ':h'), 'p')
local fd = assert(io.open(path, 'w+'))
fd:write(contents)
fd:close()
end

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ugh, my eyes!
There should be a space between the comment marker and the text...

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the annotations are fine, though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants