2012-07-18 20:59:03 +02:00
|
|
|
#pragma once
|
2004-02-06 15:57:10 +01:00
|
|
|
|
2006-09-05 12:32:47 +02:00
|
|
|
#include <time.h>
|
2020-05-19 16:54:39 +02:00
|
|
|
|
2020-05-27 22:56:34 +02:00
|
|
|
#include "libstore/pathlocks.hh"
|
|
|
|
#include "libutil/types.hh"
|
2006-09-04 23:06:23 +02:00
|
|
|
|
|
|
|
namespace nix {
|
2004-02-06 15:57:10 +01:00
|
|
|
|
2004-02-06 17:03:27 +01:00
|
|
|
struct Generation {
|
|
|
|
int number;
|
|
|
|
Path path;
|
|
|
|
time_t creationTime;
|
2004-02-08 15:07:43 +01:00
|
|
|
Generation() { number = -1; }
|
|
|
|
operator bool() const { return number != -1; }
|
2004-02-06 17:03:27 +01:00
|
|
|
};
|
|
|
|
|
2020-05-24 23:29:21 +02:00
|
|
|
typedef std::list<Generation> Generations;
|
2004-02-06 17:03:27 +01:00
|
|
|
|
|
|
|
/* Returns the list of currently present generations for the specified
|
|
|
|
profile, sorted by generation number. */
|
2020-05-20 23:58:43 +02:00
|
|
|
Generations findGenerations(const Path& profile, int& curGen);
|
2015-05-21 16:26:03 +02:00
|
|
|
|
2016-06-02 13:33:49 +02:00
|
|
|
class LocalFSStore;
|
Eliminate the "store" global variable
Also, move a few free-standing functions into StoreAPI and Derivation.
Also, introduce a non-nullable smart pointer, ref<T>, which is just a
wrapper around std::shared_ptr ensuring that the pointer is never
null. (For reference-counted values, this is better than passing a
"T&", because the latter doesn't maintain the refcount. Usually, the
caller will have a shared_ptr keeping the value alive, but that's not
always the case, e.g., when passing a reference to a std::thread via
std::bind.)
2016-02-04 14:28:26 +01:00
|
|
|
|
2020-05-20 23:58:43 +02:00
|
|
|
Path createGeneration(const ref<LocalFSStore>& store, const Path& profile,
|
|
|
|
const Path& outPath);
|
2004-02-06 15:57:10 +01:00
|
|
|
|
2004-09-10 15:32:08 +02:00
|
|
|
void deleteGeneration(const Path& profile, unsigned int gen);
|
|
|
|
|
2015-05-21 16:26:03 +02:00
|
|
|
void deleteGenerations(const Path& profile,
|
|
|
|
const std::set<unsigned int>& gensToDelete, bool dryRun);
|
|
|
|
|
2016-05-19 21:42:54 +02:00
|
|
|
void deleteGenerationsGreaterThan(const Path& profile, const int max,
|
|
|
|
bool dryRun);
|
2016-01-07 02:15:19 +01:00
|
|
|
|
2015-05-21 16:26:03 +02:00
|
|
|
void deleteOldGenerations(const Path& profile, bool dryRun);
|
|
|
|
|
|
|
|
void deleteGenerationsOlderThan(const Path& profile, time_t t, bool dryRun);
|
|
|
|
|
2020-05-24 23:29:21 +02:00
|
|
|
void deleteGenerationsOlderThan(const Path& profile,
|
|
|
|
const std::string& timeSpec, bool dryRun);
|
2015-05-21 16:26:03 +02:00
|
|
|
|
2020-05-20 23:58:43 +02:00
|
|
|
void switchLink(const Path& link, Path target);
|
2004-02-06 15:57:10 +01:00
|
|
|
|
2010-04-21 17:08:58 +02:00
|
|
|
/* 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. */
|
2020-05-24 23:29:21 +02:00
|
|
|
std::string optimisticLockProfile(const Path& profile);
|
2004-02-06 15:57:10 +01:00
|
|
|
|
2006-09-04 23:06:23 +02:00
|
|
|
} // namespace nix
|