2024-10-10 10:34:36 -04:00
<!DOCTYPE html>
< html >
< head >
< meta charset = "UTF-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< title > Everest Linux - Docs< / title >
< link type = "text/css" rel = "stylesheet" href = "../css/nord.css" / >
< / head >
< body >
<!-- Navbar -->
< div class = "sidenav" >
< img src = "../img/everest-nord.svg" alt = "everest-logo" >
< a href = "../index.html" > Home< / a >
< a href = "../about.html" > About< / a >
< a href = "../install.html" > Install< / a >
< a href = "../packages.html" > Packages< / a >
< a href = "../download.html" > Downloads< / a >
< a href = "home.html" > Docs< / a >
< a href = "../errata.html" > Errata< / a >
< a href = "https://git.everestlinux.org" > Git ↗< / a >
< / div >
<!-- Rest of page -->
< div class = "main" >
< button onclick = "window.location.href='home.html';" >
Back to home
< / button >
< h2 > 1 - Introduction< / h2 >
< p > < cil > libglacier< / cil > is the backend library for Glacier. It simplifies many functions and allows users to extend Glacier's functionality.< / p >
< h2 > 2 - Installation< / h2 >
< p > In order to install < cil > libglacier< / cil > , the following libraries must be installed:< / p >
< ul >
< li > < p > libcolor< / p > < / li >
< li > < p > libconfig< / p > < / li >
< / ul >
< p > Once these libraries are installed, clone the < cil > libglacier< / cil > repository:< / p >
< p > < code > $ git clone https://git.everestlinux.org/EverestLinux/libglacier< / code > < / p >
< p > Enter the repository and edit the make configuration file:< / p >
< p > < code > $ cd libglacier< / code > < / p >
< p > < code > $ ${EDITOR} config.mk< / code > < / p >
< cautionhead > < strong > CAUTION< / strong > < / cautionhead >
< div class = "caution" >
< p > Before proceeding with ANY other step, make sure you define < cil-inv > PREFIX< / cil-inv > in config.mk.< / p >
< p > By default this variable is not defined. Results will be unexpected if the library is compiled without < cil-inv > PREFIX< / cil-inv > defined.< / p >
< / div >
< p > Build the library:< / p >
< p > < code > $ make lib< / code > < / p >
< notehead > < strong > NOTE< / strong > < / notehead >
< div class = "note" >
< p > < cil-inv > libglacier< / cil-inv > is provided as a static library only.< / p >
< p > If you wish to compile a shared library instead, you must edit the Makefile< / p >
< / div >
2024-11-11 15:05:34 -05:00
< h2 > 3 - Using libglacier in a program< / h2 >
< p > To use < cil > libglacier< / cil > in a program, include the relevant header files:< / p >
< bigcodehead > < strong > CODE:< / strong > Including libglacier header files< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_config.h> < / p >
< p > #include < glacier_data.h> < / p >
< p > #include < glacier_log.h> < / p >
< p > #include < glacier_pkgops.h> < / p >
< p > #include < glacier_runtime.h> < / p >
2024-12-15 11:57:40 -05:00
< p > #include < glacier_security.h> < / p >
2024-11-11 15:05:34 -05:00
< / div >
< p > < / p >
2024-12-15 11:57:40 -05:00
< p > To compile < cil > libglacier< / cil > into your program, add the flag < cil > -lglacier< / cil > to your build process.< / p >
< p > < code > $ gcc program.c -lglacier -o program< / code > < / p >
2024-11-11 15:05:34 -05:00
< p > < / p >
< h2 > 4 - Configuration Functions< / h2 >
< p > < cil > libglacier< / cil > supplies functions for parsing and getting values from libconfig-syntax configuration files. While only three are present, more are planned for the future.< / p >
< p > < strong > 4.1< / strong > init_config< / p >
2024-12-15 11:57:40 -05:00
< p > < cil > init_config< / cil > initializes the libconfig library, and allows configuration files to be parsed.< / p >
2024-11-11 15:05:34 -05:00
< p > No parameters are accepted by < cil > init_config< / cil > .< / p >
< bigcodehead > < strong > CODE:< / strong > init_config used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_config.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
2024-12-15 11:57:40 -05:00
< p > if (init_config() != 0) {< / p >
< p > errlog("failed to initialize libconfig");
< p > return(EXIT_FAILURE);< / p >
< p > }< / p >
< p > else {< / p >
< p > successlog("Initialized libconfig");
< p > }
2024-11-11 15:05:34 -05:00
< p > }< / p >
< / div >
< p > < cil > init_config< / cil > returns 0 on success, and 1 on failure.< / p >
2024-12-15 11:57:40 -05:00
< hr >
2024-11-11 15:05:34 -05:00
< p > < strong > 4.2< / strong > die_config< / p >
< p > < cil > die_config< / cil > unloads the libconfig library. You should always run this when you're finished with libconfig in order to free memory.< / p >
< p > No parameters are accepted by < cil > die_config< / cil > .< / p >
< bigcodehead > < strong > CODE:< / strong > die_config used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_config.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > die_config();< / p >
< p > }< / p >
< / div >
< p > < cil > die_config< / cil > returns 0 on success, and 1 on failure.< / p >
< p > < strong > 4.3< / strong > load_all_from_config< / p >
< p > < cil > load_all_from_config< / cil > loads all expected settings from /etc/glacier.cfg.< / p >
< p > No parameters are accepted by < cil > load_all_from_config< / cil > .< / p >
< bigcodehead > < strong > CODE:< / strong > load_all_from_config used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_config.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > init_config();< / p >
< p > }< / p >
< / div >
< h2 > 5 - Data structure functions< / h2 >
< p > Since Glacier is a package manager, < cil > libglacier< / cil > provides functions for creating and handling dependency trees.< / p >
< p > < strong > 5.1< / strong > create_node< / p >
< p > < cil > create_node< / cil > creates a node for a dependency tree.< / p >
< p > < cil > create_node< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > char *data< / cil > (the name of the node to create)< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > create_node used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_data.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > struct node package = create_node("Package");< / p >
< p > }< / p >
< / div >
< p > < strong > 5.2< / strong > add_child< / p >
< p > < cil > add_child< / cil > adds a specified child node to a parent node.< / p >
< p > < cil > add_child< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > struct node *parent< / cil > (the parent node which the child will be added to)< / p > < / li >
< li > < p > < cil > struct node *child< / cil > (the child node which will be added to the parent node)< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > add_child used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_data.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
2024-12-15 11:57:40 -05:00
< p > < span class = "tab" > < / span > struct node pack = create_node("pack");
< p > < span class = "tab" > < / span > struct node dep1 = create_node("dep1");
< p > < span class = "tab" > < / span > add_child(pack, dep1);< / p >
2024-11-11 15:05:34 -05:00
< p > }< / p >
< / div >
< p > < strong > 5.3< / strong > print_tree< / p >
< p > < cil > print_tree< / cil > prints a dependency tree specified at its root node.< / p >
< p > < cil > print_tree< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > struct node *root< / cil > (the root node of the tree to print< / p > < / li >
< li > < p > < cil > int level< / cil > (the number of levels to descend)< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > print_tree used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_data.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
2024-12-15 11:57:40 -05:00
< p > < span class = "tab" > < / span > struct node pack = create_node("pack");< / p >
< p > < span class = "tab" > < / span > struct node dep1 = create_node("dep1");< / p >
< p > < span class = "tab" > < / span > add_child(pack, dep1);< / p >
< p > < span class = "tab" > < / span > print_tree(pack, 0);< / p >
2024-11-11 15:05:34 -05:00
< p > }< / p >
< / div >
2024-12-15 11:57:40 -05:00
< p > < strong > 5.4< / strong > init_queue< / p >
< p > < cil > init_queue< / cil > initializes a queue data structure.< / p >
< p > < cil > init_queue< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > queue *q< / cil > (the name of the queue to initialize< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > init_queue used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_data.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > < span class = "tab" > < / span > hi< / p >
< / div >
2024-11-11 15:05:34 -05:00
< p > < / p >
< h2 > 6 - Logging Functions< / h2 >
< p > The logging functions < cil > libglacier< / cil > provides are designed to allow a uniform style of output. < / p >
< p > The following logging functions are included:< / p >
< ul >
< li > < p > < cil > infolog< / cil > < / p > < / li >
< li > < p > < cil > warnlog< / cil > < / p > < / li >
< li > < p > < cil > errlog< / cil > < / p > < / li >
< li > < p > < cil > successlog< / cil > < / p > < / li >
< / ul >
< p > These four functions accept the following parameters:< / p >
< ul >
< li > < p > < cil > char MSG< / cil > (the message to output< / p > < / li >
< / ul >
< p > < / p >
< notehead > < strong > NOTE:< / strong > < / notehead >
< div class = "note" >
< p > Logging functions do not require a newline character ('\n'), they will automatically place one after the message.< / p >
< / div >
< p > < / p >
< bigcodehead > < strong > CODE:< / strong > Logging functions used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_log.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > infolog("This is an info message");< / p >
< p > warnlog("This is a warning message");< / p >
< p > errlog("This is an error message");< / p >
< p > successlog("This is a success message");< / p >
< p > }< / p >
< / div >
< p > < / p >
< h2 > 7 - Package Operation Functions< / h2 >
< p > This section describes the numerous functions related to operations on packages.< / p >
< p > < strong > 7.1< / strong > mkworkspace< / p >
< p > < cil > mkworkspace< / cil > creates a Glacier workspace at < cil > /tmp/glacier-workspace< / cil > .< / p >
< p > < cil > mkworkspace< / cil > accepts no parameters.< / p >
< p > < cil > mkworkspace< / cil > returns the following values:< / p >
< ul >
< li > < p > 0 on success< / p > < / li >
< li > < p > 2 on library error< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > mkworkspace used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_pkgops.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > mkworkspace();< / p >
< p > }< / p >
< / div >
< p > < strong > 7.2< / strong > prepare_pkg< / p >
< p > < cil > prepare_pkg< / cil > copies a package archive from the local package database to the workspace, and untars it.< / p >
< p > < cil > prepare_pkg< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > char PACKAGE[]< / cil > (the package file to prepare)< / p > < / li >
< / ul >
< p > < cil > prepare_pkg< / cil > returns the following values:< / p >
< ul >
< li > < p > 0 on success< / p > < / li >
< li > < p > 1 on package does not exist, or error untarring< / p > < / li >
< / ul >
< bigcodehead > < strong > CODE:< / strong > prepare_pkg used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_pkgops.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > prepare_pkg("/glacier/localdb/epkgs-x86_64-musl/foo.tar");< / p >
< p > }< / p >
< / div >
< p > < / p >
< cautionhead > < strong > CAUTION:< / strong > < / cautionhead >
< div class = "caution" >
< p > This example presented is not the best. Instead of manually specifying the package directory, you should be calling the system profile.< / p >
< / div >
< p > < strong > 7.3< / strong > run_make_task< / p >
< p > < cil > run_make_task< / cil > runs a specified make task in a package's current working directory.< / p >
< p > < cil > run_make_task< / cil > accepts the following parameters:< / p >
< ul >
< li > < p > < cil > char TASK[]< / cil > (the make task to run< / p > < / li >
< / ul >
< p > < cil > run_make_task< / cil > returns the following values:< / p >
< ul >
< li > < p > 0 on success< / p > < / li >
< li > < p > 1 on failure< / p > < / li >
< / ul >
2024-12-15 11:57:40 -05:00
< bigcodehead > < strong > CODE:< / strong > run_make_task used in a program< / bigcodehead >
2024-11-11 15:05:34 -05:00
< div class = "bigcode" >
< p > #include < glacier_pkgops.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > prepare_pkg("/glacier/localdb/epkgs-x86_64-musl/foo.tar");< / p >
< p > run_make_task("installpkg");< / p >
2024-10-10 10:34:36 -04:00
2024-11-11 15:05:34 -05:00
< p > }< / p >
< / div >
< h2 > 8 - Runtime Functions< / h2 >
< p > The functions described here are used for various runtime checks.< / p >
< p > < strong > 8.1< / strong > runtime_exists< / p >
< p > < cil > runtime_exists< / cil > checks if necessary runtime files exist and are in their correct locations.< / p >
< p > < cil > runtime_exists< / cil > accepts no parameters.
< p > < cil > runtime_exists< / cil > returns no values.< / p >
< bigcodehead > < strong > CODE:< / strong > runtime_exists used in a program< / bigcodehead >
< div class = "bigcode" >
< p > #include < glacier_runtime.h> < / p >
< p > < / p >
< p > int< / p >
< p > main()< / p >
< p > {< / p >
< p > runtime_exists();< / p >
< p > }< / p >
< / div >
< p > < strong > 8.2< / strong >
2024-10-10 10:34:36 -04:00
< / div >
< footer >
< p > Page last updated MM/DD/YY @ HH:MM< / p >
< p > Page licensed under GNU Free Documentation License 1.3 or later< / p >
< p > --------------------< / p >
2024-11-11 15:05:34 -05:00
< p > Copyright (C) 2021-2023 Everest Linux< / p > d
2024-10-10 10:34:36 -04:00
< p > Linux (R) is a registered trademark of Linus Torvalds.< / p >
< p > Everest Linux is provided AS IS, WITHOUT WARRANTY.< / p >
< / footer >