lix-website/content/about.md

68 lines
3.6 KiB
Markdown
Raw Normal View History

2024-04-28 00:33:52 +00:00
---
title: "About Lix"
description: "A strictly-better implementation of the Nix language."
date: "2024-04-27"
author: "Lix Team"
---
2024-04-27 03:39:10 +00:00
2024-04-28 00:33:52 +00:00
**Lix** is an implementation of the Nix _functional package management_ language. Originally
2024-04-28 01:20:05 +00:00
codified by [CppNix](https://github.com/NixOS/nix/), the Nix language allows you to create
2024-04-28 00:33:52 +00:00
packages that can be used for anything from **putting configuration files into place** to
**declaratively managing an entire system**.
2024-04-27 03:39:10 +00:00
2024-04-28 00:33:52 +00:00
That means that, with a few well-written Nix expressions, one
can easily configure a system into a known state -- and the packages that are created this
way are guaranteed to run _exactly the same way_ on any system of the same architecture.
2024-04-27 03:39:10 +00:00
2024-04-28 01:20:05 +00:00
As a fork of CppNix, Lix is designed to be fully compatible with the original CppNix
2024-04-28 00:33:52 +00:00
implementation -- but also designed to allow evolution of the language and tooling, so
its developers can improve usability and ergonomics without sacrificing correctness.
2024-04-27 03:39:10 +00:00
2024-04-28 00:33:52 +00:00
### Why use Nix?
2024-04-27 03:39:10 +00:00
2024-04-28 00:33:52 +00:00
If you're not familiar with the Nix approach, we recommend checking out some of the
[writing on the subject](https://nixos.org/guides/nix-pills/01-why-you-should-give-it-a-try.html).
2024-04-27 03:39:10 +00:00
2024-04-28 00:33:52 +00:00
## Why Lix?
The **Nix language** is used for a variety of applications ranging from individual computers
to clusters of critical infrastructure. With this in mind, the Lix team has been working to
2024-04-28 01:20:05 +00:00
provide a collection of necessary improvements over CppNix:
2024-04-28 00:33:52 +00:00
- **Built for a community, not for a corporation.**
Lix is built by a team of open-source volunteers -- and exists to provide a alternative to the
2024-04-28 01:20:05 +00:00
commercial interests that have long plagued both upstream CppNix and corporate-authored forks.
2024-04-28 05:05:13 +00:00
We're proud to stand by our open [conflict of interest statements](/team#conflict-of-interest-statements),
2024-04-28 00:33:52 +00:00
and proud to listen to community voices on issues of sponsorship, direction, and moderation.
- **A safe community for developers of all backgrounds.**
Lix is developed by a diverse group of users -- and accordingly is committed to providing a
space that's safe for users and developers typically underrepresented in technical projects.
We take moderation seriously, and are committed to preventing bad actors from driving out
marginalized groups.
- **A correct implementation of the Nix language.**
2024-04-28 01:20:05 +00:00
Recent versions of the CppNix project have introduced significant regressions -- so much so
2024-04-28 00:33:52 +00:00
that the upstream [Nixpkgs](https://github.com/nixos/nixpkgs) team has opted to remain several
2024-04-28 01:20:05 +00:00
versions behind. Lix is forked from the last truly-stable version of CppNix -- but has both
2024-04-28 00:33:52 +00:00
introduced new features and backported a number of features from newer versions without
sacrificing correctness.
- **A more modern implementation of Nix.**
Lix is designed for evolution of its codebase. Lix already uses the more modern
[meson build system](https://mesonbuild.com/), which improves developer usability and decreases build times.
Plans include a gradual, piecewise introduction of the memory-safe [Rust](https://www.rust-lang.org/)
programming language -- to both supplement and replace sections of the current C++ codebase.
- **A language with room to grow.**
Unlike upstream Nix, Lix intends to be an evolving language -- a robust [language versioning](/roadmap)
system will allow the language to grow and evolve without sacrificing backwards-compatibility or correctness.
And room to grow means room for [usability and ergonomics improvements](#) -- both in the langauge and in
tooling.
2024-05-02 00:38:46 +00:00
## Community, Team & Governance
**Looking for information about the people behind the project?**
Check out our [community](/community) and [team](/team) pages.