Skip to content

Commit

Permalink
website: updates
Browse files Browse the repository at this point in the history
  • Loading branch information
ilg-ul committed Dec 20, 2024
1 parent 79b50c2 commit 8493518
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 39 deletions.
72 changes: 39 additions & 33 deletions website/docs/getting-started/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ import ReleaseSchedule from './_release-schedule.mdx'

## Overview

**xPack GNU bison** is a standalone
cross-platform (GNU/Linux, macOS) binary
**xPack GNU bison** is a
standalone, cross-platform (GNU/Linux, macOS) binary
distribution of GNU bison,
aimed at reproducible builds.

Expand All @@ -48,7 +48,7 @@ aimed at reproducible builds.
To be **reproducible**, an operation must remain stable over time and
across different environments. In other words, if builds are repeated
after some time, possibly on a different machine or platform, the
resulting behavior must be functionally equivalent.
resulting behaviour must be functionally equivalent.

</details>

Expand All @@ -65,7 +65,7 @@ this project also includes the

<UpgradeNotice/>

## What are xpm packages? (xPacks)
## What are xpm packages? (xPacks) {#xpm-packages}

**xpm packages**, abbreviated as **xPacks**, are versatile,
language-neutral software packages. They have been successfully
Expand All @@ -74,16 +74,16 @@ utilised in C/C++ projects.
<details>
<summary>What the heck are xpm packages / xPacks? Please, do not introduce another package format!</summary>

While the initial appearance may seem complex, utilizing
Although the initial appearance may seem complex, utilising
xpm packages is, in fact, straightforward.
The design rationale is to automate frequent
operations that occur during software development, in this case the
operations that occur during software development, such as the
installation of
dependencies, and to ensure reproducibility.

These packages are managed by **[xpm](https://xpack.github.io/xpm/)**
(the xPack Project Manager),
a program that complements the **[npm](https://docs.npmjs.com/cli/)** CLI
a programme that complements the **[npm](https://docs.npmjs.com/cli/)** CLI
(the popular JavaScript package manager), with new language-neutral features.

The xPacks Framework **does NOT introduce a new package format**; instead,
Expand All @@ -98,34 +98,40 @@ are extracted into separate folders within the project.

Based on the content, there are two types of xpm packages:

- **source packages** (that install source files, usually libraries) and
- **binary packages** (that install executables/binary files, usually tools).
- packages with source libraries (**source** xpm packages)
- packages with executables, usually platform-specific binary
tools (**binary** xpm packages)

Binary packages include references to archives with the platform specific
binaries (such as `.tar.gz` for Unix or `.zip` for Windows).
**Source xpm packages** are regular npm packages that include **library
source files**, typically in **C/C++**, though there are no language
restrictions.

These archives are also expanded along the package metadata. Since they
include executables, links/forwarders to
**Binary xpm packages** are also regular npm packages, but with minimal
content, typically just the `package.json` file. Since these packages
provide executables for multiple platforms, some of which are quite
large, it is not practical to include all binaries within the npm
package itself. Instead, the `package.json` file contains references
(URLs) to platform-specific binary archives (e.g., `.tar.gz` for Unix or
`.zip` for Windows).

These archives are also expanded along with the package metadata.
Links/forwarders to
these executables are created in a `.bin` folder,
eliminating the need to add multiple folders to the `PATH`.

Given that some binary packages, such as toolchains, can have very large
archives, the packages are extracted only once into a user global location to
conserve space. In projects, instead of duplicating the content of these
archives, symbolic links are created.

Simply put, xpm packages can be used to further automate the
installation of source libraries and tools.
In summary, xpm packages can enhance and automate the installation
process for source libraries and tools.

</details>

## Features

All binaries are:

- **self-contained** (include all required libraries)
- **file-system relocatable** (can be installed in any location)
- built on slightly older systems (to make them run on both old and new systems)
- **Self-contained** (include all required libraries).
- **File-system relocatable** (can be installed in any location).
- Built on slightly older systems (to ensure compatibility with both
old and new systems).

<details>
<summary>Compatibility with older systems</summary>
Expand Down Expand Up @@ -154,17 +160,17 @@ location, including in user folders.

The main advantages of using the **xPack GNU bison** are:

- a convenient, uniform and portable install/uninstall/upgrade
- A convenient, uniform and portable install/uninstall/upgrade
procedure; the same procedure is used for all major
platforms (**x64 GNU/Linux**, **arm64 GNU/Linux**, **arm GNU/Linux**, **x64 macOS**, **arm64 macOS**)
- multiple versions of the same package can be installed at the same time on
the same system
- no need to worry about dependent libraries, they are all included
- not affected by system updates that
might change the versions of the dependent libraries
- significantly lighter and easier to use than Docker images that provide
similar functionality and are GNU/Linux centric
- projects can be tied to specific tools versions; this provides a good
platforms (**x64 GNU/Linux**, **arm64 GNU/Linux**, **arm GNU/Linux**, **x64 macOS**, **arm64 macOS**).
- Multiple versions of the same package can be installed at the same time on
the same system.
- No need to worry about dependent libraries, they are all included.
- Not affected by system updates that
might change the versions of the dependent libraries.
- Significantly lighter and easier to use than Docker images that provide
similar functionality and are GNU/Linux centric.
- Projects can be tied to specific tools versions; this provides a good
reproducibility, especially useful in **CI/CD** environments.

<OtherBenefits/>
Expand Down
10 changes: 5 additions & 5 deletions website/docs/install/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -63,22 +63,22 @@ as <a href={`https://www.npmjs.com/package/@xpack-dev-tools/bison`}><code>@xpack
the [`npmjs.com`](https://www.npmjs.com) registry.

<details>
<summary>xPacks refresher</summary>
<summary>xpm packages (xPacks) refresher</summary>

xPacks (short for xpm packages) are general-purpose,
**xpm packages**, abbreviated as **xPacks**, are general-purpose,
language-neutral software packages.
They use **the same format as npm packages**,
which is a collection of files/folders
and a `package.json` file with the package metadata.

**xpm** can install source and binary packages.
Binary xPacks include references to regular archives with the platform
Binary packages include references to regular archives with the platform
specific binaries (such as `.tar.gz` for Unix or `.zip` for Windows).
These archives are unpacked and links/forwarders to
the executables are created in a `.bin` folder.

For more details, please see the previous explanation in the
[Getting Started](/docs/getting-started/#xpacks) page.
[Getting Started](/docs/getting-started/#xpm-packages) page.

</details>

Expand Down Expand Up @@ -395,7 +395,7 @@ install the packages globally will fail with _already installed_.
<details>
<summary>PATH setup</summary>

In order to access the GNU RISC-V Embedded GCC binaries installed in
In order to access the GNU bison binaries installed in
the user global xPacks store,
the project build configurations need a PATH adjustment:

Expand Down
2 changes: 1 addition & 1 deletion website/docs/user/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
# DO NOT EDIT!
# Automatically generated from xbb-helper/templates/docusaurus/common.

title: User Information
title: User's Guide
description: User information, including the versioning scheme, usage of shared libraries, and RPATH configuration on GNU/Linux.
keywords:
- xpack
Expand Down
3 changes: 3 additions & 0 deletions website/docusaurus.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -102,9 +102,12 @@ const config: Config = {
organizationName: 'xpack-dev-tools', // Usually your GitHub org/user name.
projectName: 'bison-xpack', // Usually your repo name.

onBrokenAnchors: 'throw',
onBrokenLinks: 'throw',
onBrokenMarkdownLinks: 'throw',

onDuplicateRoutes: 'throw',

// Useful for the sitemap.xml, to avoid redirects, since
// GitHub redirects all to trailing slash.
trailingSlash: true,
Expand Down

0 comments on commit 8493518

Please sign in to comment.