Skip to content

Commit

Permalink
Make README.md slim
Browse files Browse the repository at this point in the history
  • Loading branch information
kwankyu committed Jan 2, 2025
1 parent c9dd1e8 commit 2b4d00b
Show file tree
Hide file tree
Showing 12 changed files with 1,243 additions and 1,223 deletions.
744 changes: 173 additions & 571 deletions README.md

Large diffs are not rendered by default.

4 changes: 2 additions & 2 deletions build/bin/sage-print-system-package-command
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ do
PROMPT="${1#--prompt=}"
;;
--prompt)
PROMPT=' $ '
CONTINUATION=' '
PROMPT='$ '
CONTINUATION=''
;;
--continuation=*)
CONTINUATION="${1#--continuation=}"
Expand Down
74 changes: 37 additions & 37 deletions src/doc/bootstrap
Original file line number Diff line number Diff line change
Expand Up @@ -35,48 +35,48 @@ for SYSTEM in arch debian fedora homebrew opensuse void; do
RECOMMENDED_SYSTEM_PACKAGES=
DEVELOP_SYSTEM_PACKAGES=
for PKG_BASE in $(sage-package list --has-file distros/$SYSTEM.txt); do
PKG_SCRIPTS=build/pkgs/$PKG_BASE
PKG_TYPE=$(cat $PKG_SCRIPTS/type)
PKG_SYSTEM_PACKAGES=$(sage-get-system-packages $SYSTEM $PKG_BASE)
if [ -n "PKG_SYSTEM_PACKAGES" ]; then
if [ -f $PKG_SCRIPTS/spkg-configure.m4 ]; then
case "$PKG_BASE:$PKG_TYPE" in
*:standard)
SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
$DEVELOP_SPKG_PATTERN:*)
DEVELOP_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
$RECOMMENDED_SPKG_PATTERN:*)
RECOMMENDED_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*)
OPTIONAL_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
esac
else
case "$PKG_BASE:$PKG_TYPE" in
$DEVELOP_SPKG_PATTERN:*)
DEVELOP_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*:standard)
SAGELIB_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*)
SAGELIB_OPTIONAL_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
esac
fi
fi
PKG_SCRIPTS=build/pkgs/$PKG_BASE
PKG_TYPE=$(cat $PKG_SCRIPTS/type)
PKG_SYSTEM_PACKAGES=$(sage-get-system-packages $SYSTEM $PKG_BASE)
if [ -n "$PKG_SYSTEM_PACKAGES" ]; then
if [ -f $PKG_SCRIPTS/spkg-configure.m4 ]; then
case "$PKG_BASE:$PKG_TYPE" in
*:standard)
SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
$DEVELOP_SPKG_PATTERN:*)
DEVELOP_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
$RECOMMENDED_SPKG_PATTERN:*)
RECOMMENDED_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*)
OPTIONAL_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
esac
else
case "$PKG_BASE:$PKG_TYPE" in
$DEVELOP_SPKG_PATTERN:*)
DEVELOP_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*:standard)
SAGELIB_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
*)
SAGELIB_OPTIONAL_SYSTEM_PACKAGES+=" $PKG_SYSTEM_PACKAGES"
;;
esac
fi
fi
done

if [ "${BOOTSTRAP_QUIET}" = "no" ]; then
echo >&2 $0:$LINENO: installing "$OUTPUT_DIR"/$SYSTEM"*.txt"
fi
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo $(echo $SYSTEM_PACKAGES | xargs -n 1 echo | sort | uniq)))" > "$OUTPUT_DIR"/$SYSTEM.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo $(echo $OPTIONAL_SYSTEM_PACKAGES | xargs -n 1 echo | sort | uniq)))" > "$OUTPUT_DIR"/$SYSTEM-optional.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo $(echo $RECOMMENDED_SYSTEM_PACKAGES | xargs -n 1 echo | sort | uniq)))" > "$OUTPUT_DIR"/$SYSTEM-recommended.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo $(echo $DEVELOP_SYSTEM_PACKAGES | xargs -n 1 echo | sort | uniq)))" > "$OUTPUT_DIR"/$SYSTEM-develop.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo "$SYSTEM_PACKAGES" | xargs -n 1 echo | sort | uniq))" > "$OUTPUT_DIR"/$SYSTEM.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo "$OPTIONAL_SYSTEM_PACKAGES" | xargs -n 1 echo | sort | uniq))" > "$OUTPUT_DIR"/$SYSTEM-optional.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo "$RECOMMENDED_SYSTEM_PACKAGES" | xargs -n 1 echo | sort | uniq))" > "$OUTPUT_DIR"/$SYSTEM-recommended.txt
echo "$(sage-print-system-package-command $SYSTEM --prompt --wrap --sudo install $(echo "$DEVELOP_SYSTEM_PACKAGES" | xargs -n 1 echo | sort | uniq))" > "$OUTPUT_DIR"/$SYSTEM-develop.txt
done

OUTPUT_DIR="src/doc/en/reference/spkg"
Expand Down
54 changes: 39 additions & 15 deletions src/doc/en/installation/binary.rst
Original file line number Diff line number Diff line change
@@ -1,33 +1,57 @@
.. _sec-installation-from-binaries:

Install from Pre-Built Binaries
===============================
Install from Prebuilt Binaries
==============================

.. _sec-installation-linux:

Linux
-----

SageMath used to provide pre-built binaries for several Linux flavors.
This has been discontinued, as most major Linux distributions have
up-to-date distribution packages providing SageMath.
See :ref:`sec-GNU-Linux` for information.
Sage is available from various distributions and can be installed
by package managers.

As of Sage 10.2, we can recommend the following distributions, which
provide well-maintained and up-to-date Sage packages:
`Arch Linux <https://archlinux.org/>`_
and `Void Linux <https://voidlinux.org/>`_.

Gentoo users might want to give a try to
`sage-on-gentoo <https://github.com/cschwan/sage-on-gentoo>`_.

**Do not install a version of Sage older than 9.5.**
If you are on an older version of your distribution and a recent
version of Sage is only available on a newer version of the
distribution, consider upgrading your distribution.

See `the _sagemath dummy package <../reference/spkg/_sagemath.html>`_
for the names of packages that provide a standard installation of
Sage, including documentation and Jupyter. See also `repology.org: sagemath
<https://repology.org/project/sagemath/versions>`_ for information
about versions of Sage packages in various distributions.

The `GitHub wiki page Distribution <https://github.com/sagemath/sage/wiki/Distribution>`_
collects information regarding packaging and distribution of Sage.

.. _sec-installation-mac:

macOS
-----

macOS binaries are available `from the 3-manifolds project
<https://github.com/3-manifolds/Sage_macOS/releases/>`_. These
have been signed and notarized, eliminating various errors caused by
Apple's gatekeeper antimalware protections.
macOS binaries are available from `the 3-manifolds project <https://github.com/3-manifolds/Sage_macOS/releases/>`_.
It is a signed and notarized app, which works for macOS 10.12 and newer. It is
completely self-contained and provides the standard Sage distribution together
with many optional packages. Additional optional Python packages can be
installed with the ``%pip`` magic command and will go into your ``~/.sage``
directory.

SageMath used to provide pre-built binaries for macOS on its mirrors.
Sage used to provide prebuilt binaries for macOS on its mirrors.
This has been discontinued, and the old binaries that are still available
there are no longer supported.

Windows
-------

Microsoft Windows
-----------------

SageMath used to provide pre-built binaries for Windows based on Cygwin.
Sage used to provide prebuilt binaries for Windows based on Cygwin.
This has been discontinued, and the old binaries that can be found
are no longer supported. Use Windows Subsystem for Linux instead.
13 changes: 7 additions & 6 deletions src/doc/en/installation/conda.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
Install from conda-forge
========================

SageMath can be installed on Linux and macOS via Conda from the
`conda-forge <https://conda-forge.org>`_ conda channel.
Sage can be installed via Conda from the `conda-forge
<https://conda-forge.org>`_ conda channel.

Both the ``x86_64`` (Intel) architecture and the ``arm64``/``aarch64``
architectures (including Apple Silicon, M1, M2, M3, M4) are supported.
Expand Down Expand Up @@ -33,10 +33,11 @@ which uses a faster dependency solver than ``conda``.

.. _sec-installation-conda-binary:

Installing all of SageMath from conda (not for development)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Installing all of Sage from conda
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Create a new conda environment containing SageMath, either with ``mamba`` or ``conda``:
This is a quick way to install Sage for non-developer users. Create a new conda
environment containing Sage, either with ``mamba`` or ``conda``:

.. tab:: mamba

Expand All @@ -55,7 +56,7 @@ where ``X`` is version of Python, e.g. ``3.9``.
To use Sage from there,

* Enter the new environment: ``conda activate sage``
* Start SageMath: ``sage``
* Start Sage: ``sage``

If there are any installation failures, please report them to
the conda-forge maintainers by opening a `GitHub Issue for
Expand Down
Loading

0 comments on commit 2b4d00b

Please sign in to comment.