Поскольку нет примера копирования-вставки для создания коммита без использования файлов на диске с libgit2 насколько я могу судить Я думал, что я должен добавить один.
Не забывайте, что в настоящее время libgit2 находится в полной разработке (март 2013 года), поэтому посмотрите официальную документацию и исходный код, так как новые функции добавляются ежедневно:
bool addGitCommit (
git_repository * repo, git_signature * sign,
const char * content, int content_sz,
const char * message )
{
int rc; /* return code for git_ functions */
git_oid oid_blob; /* the SHA1 for our blob in the tree */
git_oid oid_tree; /* the SHA1 for our tree in the commit */
git_oid oid_commit; /* the SHA1 for our initial commit */
git_blob * blob; /* our blob in the tree */
git_tree * tree_cmt; /* our tree in the commit */
git_treebuilder * tree_bld; /* tree builder */
bool b = false;
/* create a blob from our buffer */
rc = git_blob_create_frombuffer(
&oid_blob,
repo,
content,
content_sz );
if ( rc == 0 ) { /* blob created */
rc = git_blob_lookup( &blob, repo, &oid_blob );
if ( rc == 0 ) { /* blob created and found */
rc = git_treebuilder_create( &tree_bld, NULL );
if ( rc == 0 ) { /* a new tree builder created */
rc = git_treebuilder_insert(
NULL,
tree_bld,
"name-of-the-file.txt",
&oid_blob,
GIT_FILEMODE_BLOB );
if ( rc == 0 ) { /* blob inserted in tree */
rc = git_treebuilder_write(
&oid_tree,
repo,
tree_bld );
if ( rc == 0 ) { /* the tree was written to the database */
rc = git_tree_lookup(
&tree_cmt, repo, &oid_tree );
if ( rc == 0 ) { /*we've got the tree pointer */
rc = git_commit_create(
&oid_commit, repo, "HEAD",
sign, sign, /* same author and commiter */
NULL, /* default UTF-8 encoding */
message,
tree_cmt, 0, NULL );
if ( rc == 0 ) {
b = true;
}
git_tree_free( tree_cmt );
}
}
}
git_treebuilder_free( tree_bld );
}
git_blob_free( blob );
}
}
return b;
}
Хранилище приходит из git_repository_init()
или же git_repository_open()
,
Подпись исходит от git_signature_now()
или же git_signature_new()
,
Функция обновляет ГОЛОВКУ для текущей ветви.
Если вы делаете git status
после выполнения функции вы заметите, что файл name-of-the-file.txt
отображается как удаляемый. Это потому, что функция не создает фактический файл, а только запись в базе данных git.
Также обратите внимание на последние аргументы git_commit_create()
, 0 и NULL означает, что это первый (корневой) коммит. Для всех остальных должен быть указан хотя бы родительский коммит, возможно полученный с использованием git_commit_lookup()
,
Я только учусь этим вещам. Пожалуйста, улучшите этот ответ, если вы знаете лучше.
Других решений пока нет …