{lib,flake}: convert to fixed-point and modify flake for compat

This commit is contained in:
alfarel 2025-10-16 23:18:10 +00:00
commit 1627e4dddc
No known key found for this signature in database
18 changed files with 68 additions and 83 deletions

View file

@ -4,16 +4,8 @@
flake-parts,
self,
...
} @ inputs: let
# Call the extended library with `inputs`.
# inputs is used to get the original standard library, and to pass inputs
# to the plugin autodiscovery function
lib = import ./lib/stdlib-extended.nix {inherit inputs self;};
in
flake-parts.lib.mkFlake {
inherit inputs;
specialArgs = {inherit lib;};
} {
} @ inputs:
flake-parts.lib.mkFlake {inherit inputs;} {
# Allow users to bring their own systems.
# «https://github.com/nix-systems/nix-systems»
systems = import inputs.systems;
@ -24,16 +16,19 @@
./flake/develop.nix
];
flake = {
flake = {lib, ...}: let
# inputs is passed for the plugin autodiscovery function
nvf-lib = lib.fixedPoints.makeExtensible (import ./lib {inherit inputs self;});
in {
lib = {
inherit (lib) nvim;
inherit (lib.nvim) neovimConfiguration;
nvim = nvf-lib;
inherit (nvf-lib) neovimConfiguration;
};
inherit (lib.importJSON ./npins/sources.json) pins;
homeManagerModules = {
nvf = import ./flake/modules/home-manager.nix {inherit lib inputs;};
nvf = import ./flake/modules/home-manager.nix {inherit inputs;};
default = self.homeManagerModules.nvf;
neovim-flake =
lib.warn ''
@ -44,7 +39,7 @@
};
nixosModules = {
nvf = import ./flake/modules/nixos.nix {inherit lib inputs;};
nvf = import ./flake/modules/nixos.nix {inherit inputs;};
default = self.nixosModules.nvf;
neovim-flake =
lib.warn ''

View file

@ -1,4 +1,4 @@
{lib, ...}: {
{self, ...}: {
perSystem = {
pkgs,
config,
@ -20,7 +20,7 @@
packages.dev = let
configuration = {};
customNeovim = lib.nvim.neovimConfiguration {
customNeovim = self.lib.nvim.neovimConfiguration {
inherit pkgs;
modules = [configuration];
};

View file

@ -1,9 +1,7 @@
# Home Manager module
{
inputs,
lib,
}: {
{inputs}: {
config,
lib,
pkgs,
...
}: let

View file

@ -1,9 +1,7 @@
# NixOS module
{
inputs,
lib,
}: {
{inputs}: {
config,
lib,
pkgs,
...
}: let

View file

@ -1,4 +1,4 @@
{lib}: let
_: let
inherit (builtins) listToAttrs;
in {
mapListToAttrs = f: list: listToAttrs (map f list);

View file

@ -1,4 +1,4 @@
{lib}: let
{lib, ...}: let
inherit (lib.options) mkOption;
inherit (lib.modules) mkIf mkDefault;
inherit (lib.types) nullOr str;

View file

@ -1,4 +1,4 @@
{lib}: let
{lib, ...}: let
inherit (lib.options) mkOption;
inherit (lib.types) bool;
inherit (lib.modules) mkRenamedOptionModule;

View file

@ -7,11 +7,15 @@
#
# - the addition of the function `entryBefore` indicating a "wanted
# by" relationship.
{lib}: let
{
lib,
nvf-lib,
...
}: let
inherit (builtins) isAttrs attrValues attrNames elem all head tail length toJSON isString removeAttrs;
inherit (lib.attrsets) filterAttrs mapAttrs;
inherit (lib.lists) toposort;
inherit (lib.nvim.dag) empty isEntry entryBetween entryAfter entriesBetween entryAnywhere topoSort;
inherit (nvf-lib.dag) empty isEntry entryBetween entryAfter entriesBetween entryAnywhere topoSort;
in {
empty = {};

View file

@ -1,16 +1,22 @@
{
self,
inputs,
lib,
...
}: {
types = import ./types {inherit lib self;};
config = import ./config.nix {inherit lib;};
binds = import ./binds.nix {inherit lib;};
dag = import ./dag.nix {inherit lib;};
languages = import ./languages.nix {inherit lib;};
lists = import ./lists.nix {inherit lib;};
attrsets = import ./attrsets.nix {inherit lib;};
lua = import ./lua.nix {inherit lib;};
neovimConfiguration = import ../modules {inherit self inputs lib;};
self,
}: final: let
# Modeled after nixpkgs' lib.
callLibs = file:
import file {
nvf-lib = final;
inherit inputs self;
inherit (inputs.nixpkgs) lib;
};
in {
types = callLibs ./types;
config = callLibs ./config.nix;
binds = callLibs ./binds.nix;
dag = callLibs ./dag.nix;
languages = callLibs ./languages.nix;
lists = callLibs ./lists.nix;
attrsets = callLibs ./attrsets.nix;
lua = callLibs ./lua.nix;
neovimConfiguration = callLibs ../modules;
}

View file

@ -1,9 +1,13 @@
{lib}: let
{
lib,
nvf-lib,
...
}: let
inherit (builtins) isString getAttr;
inherit (lib.options) mkOption;
inherit (lib.types) listOf bool str submodule attrsOf anything either nullOr uniq;
inherit (lib.nvim.attrsets) mapListToAttrs;
inherit (lib.nvim.types) luaInline;
inherit (nvf-lib.attrsets) mapListToAttrs;
inherit (nvf-lib.types) luaInline;
in {
# TODO: remove
diagnosticsToLua = {

View file

@ -1,4 +1,4 @@
{lib}: let
{lib, ...}: let
inherit (lib.lists) elem all;
in {
/*

View file

@ -1,5 +1,5 @@
# Helpers for converting values to lua
{lib}: let
{lib, ...}: let
isLuaInline = object: (object._type or null) == "lua-inline";
toLuaObject = args:

View file

@ -1,21 +0,0 @@
# Convenience function that returns the given Nixpkgs standard library
# extended with our functions using `lib.extend`.
{inputs, ...} @ args:
inputs.nixpkgs.lib.extend (self: super: {
# WARNING: New functions should not be added here, but to files
# imported by `./default.nix` under their own categories. If your
# function does not fit to any of the existing categories, create
# a new file and import it in `./default.nix.`
# Makes our custom functions available under `lib.nvim` where stdlib-extended.nix is imported
# with the appropriate arguments. For end-users, a `lib` output will be accessible from the flake.
# E.g. for an input called `nvf`, `inputs.nvf.lib.nvim` will return the set
# below.
nvim = import ./. {
inherit (args) inputs self;
lib = self;
};
# For forward compatibility.
literalExpression = super.literalExpression or super.literalExample;
})

View file

@ -1,4 +1,4 @@
{lib}: let
{lib, ...}: let
inherit (lib.options) mergeEqualOption;
inherit (lib.lists) singleton;
inherit (lib.strings) isString stringLength match;

View file

@ -1,6 +1,7 @@
# From home-manager: https://github.com/nix-community/home-manager/blob/master/modules/lib/types-dag.nix
# Used for ordering configuration text.
{lib}: let
{lib, ...}: let
# TODO: inherit from subgroups
inherit
(lib)
defaultFunctor

View file

@ -1,11 +1,8 @@
{
lib,
self,
}: let
typesDag = import ./dag.nix {inherit lib;};
typesPlugin = import ./plugins.nix {inherit lib self;};
typesLanguage = import ./languages.nix {inherit lib;};
customTypes = import ./custom.nix {inherit lib;};
args: let
typesDag = import ./dag.nix args;
typesPlugin = import ./plugins.nix args;
typesLanguage = import ./languages.nix args;
customTypes = import ./custom.nix args;
in {
inherit (typesDag) dagOf;
inherit (typesPlugin) pluginsOpt extraPluginType mkPluginSetupOption luaInline pluginType borderType;

View file

@ -1,4 +1,4 @@
{lib}: let
{lib, ...}: let
inherit (lib.options) mkOption mkPackageOption;
inherit (lib.attrsets) attrNames;
inherit (lib.types) listOf either enum submodule package;

View file

@ -1,11 +1,14 @@
{
lib,
nvf-lib,
self,
...
}: let
inherit (lib.options) mkOption;
inherit (lib.attrsets) attrNames mapAttrs' filterAttrs nameValuePair;
inherit (lib.strings) hasPrefix removePrefix;
inherit (lib.types) submodule either package enum str lines anything listOf nullOr;
inherit (lib.types) submodule either package enum str lines anything listOf nullOr mkOptionType;
inherit (nvf-lib.lua) isLuaInline;
# Get the names of all flake inputs that start with the given prefix.
fromInputs = {
@ -64,9 +67,9 @@ in {
type = pluginsType;
};
luaInline = lib.mkOptionType {
luaInline = mkOptionType {
name = "luaInline";
check = x: lib.nvim.lua.isLuaInline x;
check = x: isLuaInline x;
};
/*