Был произведен рефакторинг вызовов git.

Необходимо доработать create, так как при создании коммита в одной ветви проиходит "проброс" ненужных файлов в вышестоящие коммиты, следующих истории коммитов.
This commit is contained in:
Alexander Zhirov 2025-05-25 01:27:24 +03:00
parent fe55e8680f
commit dd5d57c75b
Signed by: alexander
GPG key ID: C8D8BE544A27C511

View file

@ -28,32 +28,28 @@ class Snag {
_config = config; _config = config;
} }
private auto git(string[] command, string message, string separator = ":\n") {
auto result = execute(_baseCommand ~ command);
if (result.status)
throw new SnagException(
message ~ separator ~ result.output
);
return result;
}
void initialize() { void initialize() {
auto result = execute(_baseCommand ~ "init"); git(
if (result.status) ["init"],
throw new SnagException( "A Git repository initialization error occurred"
"A Git repository initialization error occurred:\n"
~ result.output
);
result = execute(
_baseCommand ~ ["config", "user.email", _config.email]
); );
if (result.status) git(
throw new SnagException( ["config", "user.email", _config.email],
"A Git repository initialization error occurred:\n" "A Git repository initialization error occurred"
~ result.output );
); git(
["config", "user.name", _config.user],
result = execute( "A Git repository initialization error occurred"
_baseCommand ~ ["config", "user.name", _config.user]
); );
if (result.status)
throw new SnagException(
"A Git repository initialization error occurred:\n"
~ result.output
);
writeln( writeln(
"The Git repository has been initialized successfully: " "The Git repository has been initialized successfully: "
~ _config.git ~ _config.git
@ -61,50 +57,36 @@ class Snag {
} }
void status() { void status() {
auto result = execute( auto result = git(
_baseCommand ~ ["status", "--porcelain"] ["status", "--porcelain"],
"An error occurred while checking the file tracking status"
); );
if (result.status)
throw new SnagException(
"An error occurred while checking the file tracking status:\n"
~ result.output
);
writeln("The following list of files requires backup:"); writeln("The following list of files requires backup:");
/**
* Цепочка выполняет разбивку по переводу на новую строку,
* отсеивает пустые строки, перебирает в цикле имеющиеся строки,
* выводит только вторую часть строки (разделенную по пробелу)
*/
result.output.split('\n').filter!(e => !e.strip.empty).each!((e) { result.output.split('\n').filter!(e => !e.strip.empty).each!((e) {
writefln("\t/%s", e.strip.split[1]); writefln("\t/%s", e.strip.split[1]);
}); });
} }
void create() { void create() {
/** auto result = git(
* Проверка файлов на состояние изменения ["status", "--porcelain"],
*/ "An error occurred while checking the file tracking status"
auto result = execute(
_baseCommand ~ ["status", "--porcelain"]
); );
if (result.status)
throw new SnagException(
"An error occurred while checking the file tracking status:\n"
~ result.output
);
if (!result.output.length) if (!result.output.length)
throw new SnagException( throw new SnagException(
"Current file state doesn't need to be archived again" "Current file state doesn't need to be archived again"
); );
result = execute( result = execute(_baseCommand ~ ["rev-parse", "--short", "HEAD"]);
_baseCommand ~ [ if (result.status == 128) {
"rev-parse", "--short", "HEAD" git(["add", "."], "Failed to prepare files for archiving");
] git(["commit", "-m", "test"], "Failed to create a backup");
); writeln("Backup was created successfully");
if (result.status) return;
} else if (result.status != 0)
throw new SnagException( throw new SnagException(
"Failed to retrieve current snapshot information:\n" "Failed to retrieve current snapshot information:\n"
~ result.output ~ result.output
@ -112,113 +94,67 @@ class Snag {
string currentSnapshot = result.output.strip('\n'); string currentSnapshot = result.output.strip('\n');
result = execute( git(
_baseCommand ~ [ ["checkout", "-b", "mod", currentSnapshot ],
"checkout", "Failed to create a branch from the current state"
"-b", );
"mod", git(
currentSnapshot ["add", "."],
] "Failed to prepare files for archiving"
);
git(
["commit", "-m", "test"],
"Failed to create a backup"
);
git(
["checkout", "master"],
"Failed to perform intermediate state switching"
);
git(
["rebase", "--onto", "mod", currentSnapshot, "master", "-X", "theirs"],
"Ошибка при rebase"
); );
result = execute( result = git(
_baseCommand ~ ["add", "."] ["rev-parse", "--short", "mod"],
"An error occurred while checking the file tracking status"
); );
if (result.status)
throw new SnagException(
"Failed to prepare files for archiving:\n"
~ result.output
);
result = execute( string newSnapshot = result.output.strip('\n');
_baseCommand ~ ["commit", "-m", "test"]
git(
["checkout", newSnapshot],
"Failed to perform intermediate state switching"
); );
if (result.status) git(
throw new SnagException( ["branch", "-D", "mod"],
"Failed to create a backup:\n" "Error while deleting temporary intermediate snapshot"
~ result.output
);
result = execute(
_baseCommand ~ ["checkout", "master"]
); );
if (result.status)
throw new SnagException(
"Failed to perform intermediate state switching:\n"
~ result.output
);
result = execute(
_baseCommand ~ [
"merge",
"-X",
"theirs",
"--squash",
"mod"
]
);
if (result.status)
throw new SnagException(
"Failed to retrieve changes from the new intermediate snapshot:\n"
~ result.output
);
result = execute(
_baseCommand ~ ["commit", "-m", "test"]
);
if (result.status)
throw new SnagException(
"Failed to create backup after acquiring new intermediate snapshot:\n"
~ result.output
);
result = execute(
_baseCommand ~ ["branch", "-D", "mod"]
);
if (result.status)
throw new SnagException(
"Error while deleting temporary intermediate snapshot:\n"
~ result.output
);
writeln("Backup was created successfully"); writeln("Backup was created successfully");
} }
void list() { void list() {
auto result = execute( auto result = git(
_baseCommand ~ [ ["rev-parse", "--short", "HEAD"],
"rev-parse", "--short", "HEAD" "Failed to retrieve current snapshot information"
]
); );
if (result.status)
throw new SnagException(
"Failed to retrieve current snapshot information:\n"
~ result.output
);
string current = result.output.strip('\n'); string current = result.output.strip('\n');
result = execute( result = git(
_baseCommand ~ [ [
"log", "log",
"--all", "--all",
"--date=format:%Y.%m.%d %H:%M", "--date=format:%Y.%m.%d %H:%M",
"--pretty=format:%ad\t%h" "--pretty=format:%ad\t%h"
] ],
"Failed to retrieve the list of snapshots"
); );
if (result.status)
throw new SnagException(
"Failed to retrieve the list of snapshots:\n"
~ result.output
);
result.output.split('\n').each!((e) { result.output.split('\n').map!(line => line.split('\t')).array
auto eArray = e.split('\t'); .sort!((a, b) => a[0] > b[0]).each!(e =>
if (current == eArray[1]) writefln("%s\t%s\t%s", current == e[1] ? " >" : "", e[0], e[1])
writefln(" >\t%s\t%s", eArray[0], eArray[1]); );
else
writefln("\t%s\t%s", eArray[0], eArray[1]);
});
} }
void restore(string hash) { void restore(string hash) {
@ -227,48 +163,25 @@ class Snag {
"Invalid snapshot hash provided" "Invalid snapshot hash provided"
); );
auto result = execute( auto result = git(
_baseCommand ~ ["status", "--porcelain"] ["status", "--porcelain"],
"An error occurred while checking the file tracking status"
); );
if (result.status)
throw new SnagException( if (result.output.length)
"An error occurred while checking the file tracking status:\n" git(
~ result.output ["restore", "."],
"Failed to reset file changes state"
); );
if (result.output.length) { git(
result = execute( ["rev-parse", hash],
_baseCommand ~ ["restore", "."] "This snapshot is not available in the archive"
);
if (result.status)
throw new SnagException(
"Failed to reset file changes state:\n"
~ result.output
);
}
result = execute(
_baseCommand ~ [
"rev-parse", hash
]
); );
if (result.status) git(
throw new SnagException( ["checkout", hash],
"This snapshot is not available in the archive:\n" "Failed to restore the snapshot state " ~ hash
~ result.output.split('\n')[0]
);
result = execute(
_baseCommand ~ [
"checkout", hash
]
); );
if (result.status)
throw new SnagException(
"Failed to restore the snapshot state %s:\n"
.format(hash, result.output)
);
writeln("Backup was restored successfully"); writeln("Backup was restored successfully");
} }
} }