Difference between revisions of "Ubuntu Snap"

From FreeCAD Documentation
Jump to navigation Jump to search
m (Updated the bash 1 liners (removed the cut command pipe))
m (Converted ppd to official snap)
Line 49: Line 49:
 
</translate>
 
</translate>
 
{{Code|lang=bash|code=
 
{{Code|lang=bash|code=
sudo snap install --edge freecad-ppd
+
sudo snap install --edge freecad
 
}}
 
}}
 
<translate>
 
<translate>
Line 69: Line 69:
 
</translate>
 
</translate>
 
{{Code|lang=bash|code=
 
{{Code|lang=bash|code=
snap install --edge freecad-ppd
+
snap install --edge freecad
 
}}
 
}}
 
<translate>
 
<translate>
Line 80: Line 80:
 
</translate>
 
</translate>
 
{{Code|lang=bash|code=
 
{{Code|lang=bash|code=
snap info freecad-ppd
+
snap info freecad
 
}}
 
}}
 
<translate>
 
<translate>
Line 87: Line 87:
  
 
<!--T:20-->
 
<!--T:20-->
The following commands are geared towards users that are familiar with git and have a locally cloned repository of the upstream FreeCAD repository.
+
The following commands are geared towards users that are familiar with {{incode|git}} and have a locally cloned repository of the upstream FreeCAD repository.
  
 
</translate>
 
</translate>
Line 111: Line 111:
 
</translate>
 
</translate>
 
{{Code|lang=bash|code=
 
{{Code|lang=bash|code=
snap info freecad-ppd <nowiki>|</nowiki>\
+
snap info freecad <nowiki>|</nowiki>\
 
grep -e '^\s\+latest/edge' <nowiki>|</nowiki>\
 
grep -e '^\s\+latest/edge' <nowiki>|</nowiki>\
 
awk -F ' ' '{ print $2 }' <nowiki>|</nowiki>\
 
awk -F ' ' '{ print $2 }' <nowiki>|</nowiki>\
Line 129: Line 129:
 
</translate>
 
</translate>
 
{{Code|lang=bash|code=
 
{{Code|lang=bash|code=
snap info freecad-ppd <nowiki>|</nowiki>\
+
snap info freecad <nowiki>|</nowiki>\
 
grep -e '^\s\+latest/edge' <nowiki>|</nowiki>\
 
grep -e '^\s\+latest/edge' <nowiki>|</nowiki>\
 
awk -F ' ' '{ print $2 }' <nowiki>|</nowiki>\
 
awk -F ' ' '{ print $2 }' <nowiki>|</nowiki>\
Line 143: Line 143:
 
<!--T:12-->
 
<!--T:12-->
 
More information about the current efforts to deal with Snaps:
 
More information about the current efforts to deal with Snaps:
* [https://forum.freecadweb.org/viewtopic.php?f=4&t=46044 0.19 Snap Preview needs "testers"], older Snap by {{Emphasis|vejmarie}}.
+
* [https://forum.freecadweb.org/viewtopic.php?f=4&t=46044 0.19 Snap Preview needs "testers"], older Snap by {{Emphasis|vejmarie}}. (deprecated)
* [https://forum.freecadweb.org/viewtopic.php?f=42&t=46853 Discussion: State of the snap (Snap Packaging)], newer version of the Snap by {{Emphasis|ppd}}.
+
* [https://forum.freecadweb.org/viewtopic.php?f=42&t=46853 Discussion: State of the snap (Snap Packaging)], newer version of the Snap by {{Emphasis|ppd}}. (deprecated)
  
 
<!--T:24-->
 
<!--T:24-->

Revision as of 12:13, 27 May 2022

Other languages:
Deutsch • ‎English • ‎español • ‎français • ‎italiano • ‎polski • ‎português do Brasil • ‎русский

Introduction

An Ubuntu Snap package, or just Snap is a distribution format similar to AppImage in that it is intended to be a "universal installable package" to deploy software on Linux systems. Snaps were introduced by Ubuntu but they are intended to run on all Linux distributions as long as the Snap daemon, or snapd, is available on the target system.

A Snap package has two main characteristics:

  • Programs are sandboxed so they do not interfere with the rest of the operating system.
  • Programs are updated automatically in the background in order to get the newest version of the application.

For other ways of installing the software, see Installing on Linux.

Installation

The use of Snaps is experimental. The current Snaps are generated and hosted by volunteers.

On all systems where Snaps are to be installed, the Snap daemon must be installed first. The package is normally called snapd.

Debian/Ubuntu

For Debian/Ubuntu and similar systems which use the APT manager the daemon is installed as follows:

sudo apt install snapd

To install the stable version of the Snap use:

sudo snap install freecad

To install the development version of the Snap use:

sudo snap install --edge freecad

Manjaro

To install the stable version of the Snap use:

snap install freecad

To install the development version of the Snap use:

snap install --edge freecad

Notes

To figure out which development version is installed type the following in the Command-line interface:

snap info freecad

Advanced

The following commands are geared towards users that are familiar with git and have a locally cloned repository of the upstream FreeCAD repository.

git clone https://github.com/FreeCAD/FreeCAD
cd FreeCAD/

To find out the latest upstream revision number (also known as 'HEAD'):

git pull upstream master  # first make sure we have the most up-to-date commits
git rev-list --count HEAD # 'HEAD' refers to the current commit you are viewing (tip of the master branch)

To translate the current snap development version in to a revision number (make sure you're within your cloned FreeCAD repository as mentioned above):

snap info freecad |\
grep -e '^\s\+latest/edge' |\
awk -F ' ' '{ print $2 }' |\
xargs -I{} git rev-list --count {}

Note: the above bash script 1 liner assumes user has 'edge' (nightly) installed

The difference between HEAD and the snap edge revision numbers indicates the amount of revisions trailing behind upstream the snap development (edge) is.

Taking it a step further, if you want a short summary of the commits between the current snap edge and HEAD:

snap info freecad |\
grep -e '^\s\+latest/edge' |\
awk -F ' ' '{ print $2 }' |\
xargs -I{} git log --oneline --ancestry-path {}..HEAD

Note: The output will indicate what commits are not in the current 'edge' (but will be on the next nightly update).

Links

More information about the current efforts to deal with Snaps:

  • AppImage - another self-contained 'binary' like format to run FreeCAD
  • Flatpak