mirror of
https://github.com/SkinnyMind/libgit2dart.git
synced 2025-05-05 12:49:08 -04:00
feat(commit): add more bindings and API methods (#22)
This commit is contained in:
parent
e6bfdc5a85
commit
5740831bb9
4 changed files with 438 additions and 28 deletions
|
@ -3,7 +3,6 @@ import 'dart:ffi';
|
|||
import 'package:libgit2dart/libgit2dart.dart';
|
||||
import 'package:libgit2dart/src/bindings/commit.dart' as bindings;
|
||||
import 'package:libgit2dart/src/bindings/libgit2_bindings.dart';
|
||||
import 'package:libgit2dart/src/bindings/tree.dart' as tree_bindings;
|
||||
|
||||
class Commit {
|
||||
/// Initializes a new instance of [Commit] class from provided pointer to
|
||||
|
@ -81,6 +80,61 @@ class Commit {
|
|||
);
|
||||
}
|
||||
|
||||
/// Creates a commit and writes it into a buffer.
|
||||
///
|
||||
/// Creates a commit as with [create] but instead of writing it to the
|
||||
/// objectdb, writes the contents of the object into a buffer.
|
||||
///
|
||||
/// [repo] is the repository where to store the commit.
|
||||
///
|
||||
/// [updateRef] is the name of the reference that will be updated to point to
|
||||
/// this commit. If the reference is not direct, it will be resolved to a
|
||||
/// direct reference. Use "HEAD" to update the HEAD of the current branch and
|
||||
/// make it point to this commit. If the reference doesn't exist yet, it will
|
||||
/// be created. If it does exist, the first parent must be the tip of this
|
||||
/// branch.
|
||||
///
|
||||
/// [author] is the signature with author and author time of commit.
|
||||
///
|
||||
/// [committer] is the signature with committer and commit time of commit.
|
||||
///
|
||||
/// [messageEncoding] is the encoding for the message in the commit,
|
||||
/// represented with a standard encoding name. E.g. "UTF-8". If null, no
|
||||
/// encoding header is written and UTF-8 is assumed.
|
||||
///
|
||||
/// [message] is the full message for this commit.
|
||||
///
|
||||
/// [tree] is an instance of a [Tree] object that will be used as the tree
|
||||
/// for the commit. This tree object must also be owned by the given [repo].
|
||||
///
|
||||
/// [parents] is a list of [Commit] objects that will be used as the parents
|
||||
/// for this commit. This array may be empty if parent count is 0
|
||||
/// (root commit). All the given commits must be owned by the [repo].
|
||||
///
|
||||
/// Throws a [LibGit2Error] if error occured.
|
||||
static String createBuffer({
|
||||
required Repository repo,
|
||||
required String updateRef,
|
||||
required Signature author,
|
||||
required Signature committer,
|
||||
String? messageEncoding,
|
||||
required String message,
|
||||
required Tree tree,
|
||||
required List<Commit> parents,
|
||||
}) {
|
||||
return bindings.createBuffer(
|
||||
repoPointer: repo.pointer,
|
||||
updateRef: updateRef,
|
||||
authorPointer: author.pointer,
|
||||
committerPointer: committer.pointer,
|
||||
messageEncoding: messageEncoding,
|
||||
message: message,
|
||||
treePointer: tree.pointer,
|
||||
parentCount: parents.length,
|
||||
parents: parents.map((e) => e.pointer).toList(),
|
||||
);
|
||||
}
|
||||
|
||||
/// Amends an existing commit by replacing only non-null values.
|
||||
///
|
||||
/// This creates a new commit that is exactly the same as the old commit,
|
||||
|
@ -134,12 +188,33 @@ class Commit {
|
|||
/// leading newlines.
|
||||
String get message => bindings.message(_commitPointer);
|
||||
|
||||
/// Returns the short "summary" of the git commit message.
|
||||
///
|
||||
/// The returned message is the summary of the commit, comprising the first
|
||||
/// paragraph of the message with whitespace trimmed and squashed.
|
||||
///
|
||||
/// Throws a [LibGit2Error] if error occured.
|
||||
String get summary => bindings.summary(_commitPointer);
|
||||
|
||||
/// Returns the long "body" of the commit message.
|
||||
///
|
||||
/// The returned message is the body of the commit, comprising everything but
|
||||
/// the first paragraph of the message. Leading and trailing whitespaces are
|
||||
/// trimmed.
|
||||
///
|
||||
/// Returns empty string if message only consists of a summary.
|
||||
String get body => bindings.body(_commitPointer);
|
||||
|
||||
/// [Oid] of a commit.
|
||||
Oid get oid => Oid(bindings.id(_commitPointer));
|
||||
|
||||
/// Commit time (i.e. committer time) of a commit.
|
||||
int get time => bindings.time(_commitPointer);
|
||||
|
||||
/// Commit timezone offset in minutes (i.e. committer's preferred timezone)
|
||||
/// of a commit.
|
||||
int get timeOffset => bindings.timeOffset(_commitPointer);
|
||||
|
||||
/// Committer of a commit.
|
||||
Signature get committer => Signature(bindings.committer(_commitPointer));
|
||||
|
||||
|
@ -162,16 +237,51 @@ class Commit {
|
|||
return parents;
|
||||
}
|
||||
|
||||
/// Tree pointed to by a commit.
|
||||
Tree get tree {
|
||||
return Tree(
|
||||
tree_bindings.lookup(
|
||||
repoPointer: bindings.owner(_commitPointer),
|
||||
oidPointer: bindings.tree(_commitPointer),
|
||||
/// Returns the specified parent of the commit at provided 0-based [position].
|
||||
///
|
||||
/// **IMPORTANT**: Should be freed to release allocated memory.
|
||||
///
|
||||
/// Throws a [LibGit2Error] if error occured.
|
||||
Commit parent(int position) {
|
||||
return Commit(
|
||||
bindings.parent(
|
||||
commitPointer: _commitPointer,
|
||||
position: position,
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
/// Tree pointed to by a commit.
|
||||
Tree get tree => Tree(bindings.tree(_commitPointer));
|
||||
|
||||
/// Oid of the tree pointed to by a commit.
|
||||
Oid get treeOid => Oid(bindings.treeOid(_commitPointer));
|
||||
|
||||
/// Returns an arbitrary header field.
|
||||
///
|
||||
/// Throws a [LibGit2Error] if error occured.
|
||||
String headerField(String field) {
|
||||
return bindings.headerField(commitPointer: _commitPointer, field: field);
|
||||
}
|
||||
|
||||
/// Returns commit object that is the [n]th generation ancestor of the
|
||||
/// commit, following only the first parents.
|
||||
///
|
||||
/// Passing 0 as the generation number returns another instance of the base
|
||||
/// commit itself.
|
||||
///
|
||||
/// **IMPORTANT**: Should be freed to release allocated memory.
|
||||
///
|
||||
/// Throws a [LibGit2Error] if error occured.
|
||||
Commit nthGenAncestor(int n) {
|
||||
return Commit(bindings.nthGenAncestor(commitPointer: _commitPointer, n: n));
|
||||
}
|
||||
|
||||
/// Creates an in-memory copy of a commit.
|
||||
///
|
||||
/// **IMPORTANT**: Should be freed to release allocated memory.
|
||||
Commit duplicate() => Commit(bindings.duplicate(_commitPointer));
|
||||
|
||||
/// Releases memory allocated for commit object.
|
||||
void free() => bindings.free(_commitPointer);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue