nix-super/src/libstore/profiles.hh

109 lines
2.8 KiB
C++
Raw Normal View History

#pragma once
///@file
2004-02-06 16:57:10 +02:00
#include "types.hh"
#include "pathlocks.hh"
2004-02-06 16:57:10 +02:00
2006-09-05 13:32:47 +03:00
#include <time.h>
namespace nix {
2004-02-06 16:57:10 +02:00
2020-09-03 12:06:56 +03:00
class StorePath;
2004-02-06 16:57:10 +02:00
2021-09-14 20:05:28 +03:00
typedef uint64_t GenerationNumber;
2020-07-16 16:14:22 +03:00
struct Generation
{
2020-07-16 16:14:22 +03:00
GenerationNumber number;
Path path;
time_t creationTime;
};
2020-07-16 16:14:22 +03:00
typedef std::list<Generation> Generations;
/**
* Returns the list of currently present generations for the specified
* profile, sorted by generation number. Also returns the number of
* the current generation.
*/
2020-07-16 16:14:22 +03:00
std::pair<Generations, std::optional<GenerationNumber>> findGenerations(Path profile);
class LocalFSStore;
2020-09-03 12:06:56 +03:00
Path createGeneration(ref<LocalFSStore> store, Path profile, StorePath outPath);
2004-02-06 16:57:10 +02:00
2020-07-16 16:14:22 +03:00
void deleteGeneration(const Path & profile, GenerationNumber gen);
2020-07-16 16:14:22 +03:00
void deleteGenerations(const Path & profile, const std::set<GenerationNumber> & gensToDelete, bool dryRun);
2020-07-16 16:14:22 +03:00
void deleteGenerationsGreaterThan(const Path & profile, GenerationNumber max, bool dryRun);
void deleteOldGenerations(const Path & profile, bool dryRun);
void deleteGenerationsOlderThan(const Path & profile, time_t t, bool dryRun);
void deleteGenerationsOlderThan(const Path & profile, std::string_view timeSpec, bool dryRun);
2004-02-06 16:57:10 +02:00
void switchLink(Path link, Path target);
/**
* Roll back a profile to the specified generation, or to the most
* recent one older than the current.
*/
2021-09-14 20:05:28 +03:00
void switchGeneration(
const Path & profile,
std::optional<GenerationNumber> dstGen,
bool dryRun);
/**
* Ensure exclusive access to a profile. Any command that modifies
* the profile first acquires this lock.
*/
void lockProfile(PathLocks & lock, const Path & profile);
/**
* Optimistic locking is used by long-running operations like `nix-env
* -i'. Instead of acquiring the exclusive lock for the entire
* duration of the operation, we just perform the operation
* optimistically (without an exclusive lock), and check at the end
* whether the profile changed while we were busy (i.e., the symlink
* target changed). If so, the operation is restarted. Restarting is
* generally cheap, since the build results are still in the Nix
* store. Most of the time, only the user environment has to be
* rebuilt.
*/
std::string optimisticLockProfile(const Path & profile);
2004-02-06 16:57:10 +02:00
/**
* Create and return the path to a directory suitable for storing the users
* profiles.
*/
Path profilesDir();
/**
* Return the path to the profile directory for root (but don't try creating it)
*/
Path rootProfilesDir();
/**
* Create and return the path to the file used for storing the users's channels
*/
Path defaultChannelsDir();
/**
* Return the path to the channel directory for root (but don't try creating it)
*/
Path rootChannelsDir();
/**
* Resolve the default profile (~/.nix-profile by default,
* $XDG_STATE_HOME/nix/profile if XDG Base Directory Support is enabled),
* and create if doesn't exist
*/
2020-03-24 15:26:13 +02:00
Path getDefaultProfile();
}