mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-11 09:18:20 +03:00
42edb6f91b
Signed-off-by: Giuseppe Scrivano <gscrivan@redhat.com>
133 lines
2.9 KiB
Markdown
133 lines
2.9 KiB
Markdown
OSTree is a tool for managing bootable, immutable, versioned
|
|
filesystem trees. While it takes over some of the roles of traditional
|
|
"package managers" like dpkg and rpm, it is not a package system; nor
|
|
is it a tool for managing full disk images. Instead, it sits between
|
|
those levels, offering a blend of the advantages (and disadvantages)
|
|
of both.
|
|
|
|
For more information, see:
|
|
|
|
https://live.gnome.org/Projects/OSTree
|
|
|
|
Submitting patches
|
|
------------------
|
|
|
|
You can:
|
|
|
|
1. Send mail to ostree-list@gnome.org, with the patch attached
|
|
1. Submit a pull request against https://github.com/GNOME/ostree
|
|
1. Attach them to https://bugzilla.gnome.org/
|
|
|
|
Please look at "git log" and match the commit log style.
|
|
|
|
Running the test suite
|
|
----------------------
|
|
|
|
Currently, ostree uses https://wiki.gnome.org/GnomeGoals/InstalledTests
|
|
To run just ostree's tests:
|
|
|
|
./configure ... --enable-installed-tests
|
|
gnome-desktop-testing-runner -p 0 ostree/
|
|
|
|
Also, there is a regular:
|
|
|
|
make check
|
|
|
|
That runs a different set of tests.
|
|
|
|
Coding style
|
|
------------
|
|
|
|
Indentation is GNU. Files should start with the appropriate mode lines.
|
|
|
|
Use GCC `__attribute__((cleanup))` wherever possible. If interacting
|
|
with a third party library, try defining local cleanup macros.
|
|
|
|
Use GError and GCancellable where appropriate.
|
|
|
|
Prefer returning `gboolean` to signal success/failure, and have output
|
|
values as parameters.
|
|
|
|
Prefer linear control flow inside functions (aside from standard
|
|
loops). In other words, avoid "early exits" or use of `goto` besides
|
|
`goto out;`.
|
|
|
|
This is an example of an "early exit":
|
|
|
|
static gboolean
|
|
myfunc (...)
|
|
{
|
|
gboolean ret = FALSE;
|
|
|
|
/* some code */
|
|
|
|
/* some more code */
|
|
|
|
if (condition)
|
|
return FALSE;
|
|
|
|
/* some more code */
|
|
|
|
ret = TRUE;
|
|
out:
|
|
return ret;
|
|
}
|
|
|
|
If you must shortcut, use:
|
|
|
|
if (condition)
|
|
{
|
|
ret = TRUE;
|
|
goto out;
|
|
}
|
|
|
|
A consequence of this restriction is that you are encouraged to avoid
|
|
deep nesting of loops or conditionals. Create internal static helper
|
|
functions, particularly inside loops. For example, rather than:
|
|
|
|
while (condition)
|
|
{
|
|
/* some code */
|
|
if (condition)
|
|
{
|
|
for (i = 0; i < somevalue; i++)
|
|
{
|
|
if (condition)
|
|
{
|
|
/* deeply nested code */
|
|
}
|
|
|
|
/* more nested code */
|
|
}
|
|
}
|
|
}
|
|
|
|
Instead do this:
|
|
|
|
static gboolean
|
|
helperfunc (..., GError **error)
|
|
{
|
|
if (condition)
|
|
{
|
|
/* deeply nested code */
|
|
}
|
|
|
|
/* more nested code */
|
|
|
|
return ret;
|
|
}
|
|
|
|
while (condition)
|
|
{
|
|
/* some code */
|
|
if (!condition)
|
|
continue;
|
|
|
|
for (i = 0; i < somevalue; i++)
|
|
{
|
|
if (!helperfunc (..., i, error))
|
|
goto out;
|
|
}
|
|
}
|
|
|