public interface CommitService
Modifier and Type | Method and Description |
---|---|
Page<Change> |
getChanges(ChangesRequest request,
PageRequest pageRequest)
Retrieves a page of
changes between two commits. |
Page<Changeset> |
getChangesets(ChangesetsRequest request,
PageRequest pageRequest)
Retrieves changesets for each of the requested
ChangesetsRequest.getCommitIds() commits}, including the
first page of changes between each commit and its first parent. |
Commit |
getCommit(CommitRequest request)
Retrieves a commit based on te provided
request . |
Page<Commit> |
getCommits(CommitsRequest request,
PageRequest pageRequest)
Retrieves a page of commits, starting from a given branch, tag or commit, optionally filtered to only return
commits which modify one or more paths.
|
Page<Commit> |
getCommitsBetween(CommitsBetweenRequest request,
PageRequest pageRequest)
Retrieves a page of commits between the
included commits and the
excluded commits . |
Optional<MinimalCommit> |
getCommonAncestor(CommonAncestorRequest request)
Retrieves the common ancestor for the provided commits
|
CommitDiscussion |
getDiscussion(CommitDiscussionRequest request)
Retrieve a
commit discussion matching the provided request. |
void |
streamChanges(ChangesRequest request,
ChangeCallback callback)
|
void |
streamCommits(BulkCommitsRequest request,
BulkCommitCallback callback)
Stream an arbitrary set of commits from an arbitrary number of repositories.
|
void |
streamCommits(CommitsRequest request,
CommitCallback callback)
Streams commits, starting from a given branch, tag or commit, optionally filtered to only include commits which
modify one or more paths.
|
void |
streamCommitsBetween(CommitsBetweenRequest request,
CommitCallback callback)
Streams commits between the
included commits and the
excluded commits . |
void |
streamDiff(DiffRequest request,
DiffContentCallback callback)
Streams diff output for the specified
paths at the specified commit. |
void |
streamDiff(DiffRequest request,
TypeAwareOutputSupplier outputSupplier)
Streams diff output for the specified
request . |
void |
streamLastModified(LastModifiedRequest request,
LastModifiedCallback callback)
|
void |
traverse(TraversalRequest request,
TraversalCallback callback)
Traverse the graph of commits in topological order, optionally supplying included commits to start from
and excluded commits to ignore.
|
@Nonnull Page<Change> getChanges(@Nonnull ChangesRequest request, @Nonnull PageRequest pageRequest)
changes
between two commits. If the since
commit is not specified, the until
commit's first parent is used.
Note: The implementation will apply a hard cap (page.max.changes
) and it is not
possible to request subsequent content when that cap is exceeded.
request
- describes the two commits to retrieve changes between and the repository which contains
both commitspageRequest
- the start and limit for the page being requested@Nonnull Page<Changeset> getChangesets(@Nonnull ChangesetsRequest request, @Nonnull PageRequest pageRequest)
ChangesetsRequest.getCommitIds()
commits}, including the
first page of changes between each commit and its first parent.
If the page size
is less than the size of the collection of IDs, a subset of the
collection will be returned. Otherwise, changesets for all IDs in the requested collection are returned.
request
- request parameters, specifying the repository and the desired commitspageRequest
- the start and limit of the page being requestNoSuchCommitException
- if ignoreMissing
is not set and any
of the requested commits cannot be found@Nonnull Commit getCommit(@Nonnull CommitRequest request)
request
.
If only a commit ID
is specified, that commit will be returned if it exists.
If a path
is also provided, the first commit starting from the specified
commit ID which modifies that path is returned. If the specified commit does not exist, or if no commit in the
ancestry of that commit modifies the specified path, a NoSuchCommitException
is thrown.
When retrieving a commit, extra properties
can also be loaded.
Properties are metadata associated with commits by CommitIndexer
s. Until 4.0, the extra properties
requested also control the attributes that are loaded. Attributes will be removed in 4.0.
request
- describes the commit to retrieve, and the repository to retrieve it fromNoSuchCommitException
- if no matching commit can be found@Nonnull Page<Commit> getCommits(@Nonnull CommitsRequest request, @Nonnull PageRequest pageRequest)
CommitsRequest.getCommitId()
, unless one or more paths
are provided.
Then the first commit returned, if any are returned, will be the first commit in the ancestry of the specified
starting commit which modifies at least one of the specified files.
This service call may be used to:
When retrieving commits, extra properties
can also be loaded.
Properties are metadata associated with commits by CommitIndexer
s. Until 4.0, the extra properties
requested also control the attributes that are loaded. Attributes will be removed in 4.0.
Note: If any of the provided paths is renamed at some point in its history, commits will not follow the path across the rename. In other words, only commits for exact paths provided will be included.
request
- describes the commits to retrieve, and the repository to retrieve them frompageRequest
- the start and limit for the page being requestednull
@Nonnull Page<Commit> getCommitsBetween(@Nonnull CommitsBetweenRequest request, @Nonnull PageRequest pageRequest)
included commits
and the
excluded commits
. Included and excluded commits may be specified
by branch or tag name or by commit ID. The commits returned are those which are reachable an included commit
and not reachable from any excluded commit. While this may imply an ancestral relationship between included
and excluded IDs, that is not strictly required. When the IDs are unrelated, all commits reachable from the
included commits are candidates for the returned page, and excluded commits are effectively ignored. One or
more paths may be provided to further narrow the results, restricting the returned commits to only which modify
one or more of the specified paths.
Which commits are included and which are excluded is important here. Consider the following example:
---- A ---- B ---- C \ \ FA1 ---- FA2 ---- FA3If "master" is excluded and "feature-A" is included, commits FA1, FA2 and FA3 will be returned because they are reachable from "feature-A" but not from "master". If the two IDs were reversed, commits B and C would be returned, because they are reachable from "master" but not from "feature-A". This approach of swapping includes and excludes can be used to determine how two branches have diverged over time.
When retrieving commits, extra properties
can also be loaded.
Properties are metadata associated with commits by CommitIndexer
s. Until 4.0, the extra properties
requested also control the attributes that are loaded. Attributes will be removed in 4.0.
Warning: Commits specified using branch or tag names will be resolved against the primary
repository
. When retrieving commits between repositories,
commits in the secondary repository
may only be
specified by commit ID. This means requesting a page like this will not work:
CommitsBetweenRequest request = new CommitsBetweenRequest.Builder(repository)
.exclude("master")
.include("master")
.secondaryRepository(forkOfRepository)
.build();
Page<Commit> page = commitService.getCommitsBetween(request, PageUtils.newRequest(0, 25));
The returned page will always be empty because "master" was resolved on both sides using the same repository,
producing the same commit to include and exclude. This also demonstrates that excludes take precedence
over includes, as one might expect.request
- describes the commits to include/exclude, paths to filter by and which repository, or
repositories, contain the commitspageRequest
- the start and limit for the page being requested@Nonnull Optional<MinimalCommit> getCommonAncestor(@Nonnull CommonAncestorRequest request)
request
- request describing which common ancestor to retrieveOptional.empty()
if the provided commits do
not have a common ancestorCommitDiscussion getDiscussion(@Nonnull CommitDiscussionRequest request)
commit discussion
matching the provided request.
Note: Nullability actually depends on the provided request.
request
- the request describing the discussion to retrieve or createnull
depending on the requestvoid streamChanges(@Nonnull ChangesRequest request, @Nonnull ChangeCallback callback)
until
and since
commits. If the since
commit is not specified, the
until
commit's first parent is used automatically.
Note: The implementation will apply a hard cap (page.max.changes
) and it is not
possible to request subsequent content when that cap is exceeded.
request
- describes the two commits to retrieve changes between and the repository which contains
both commitscallback
- a callback to receive the changesvoid streamCommits(@Nonnull BulkCommitsRequest request, @Nonnull BulkCommitCallback callback)
repositories
from which commits are being requested
or an exception will be thrown.
Due to the bulk nature of this method, it is required that full IDs
be used to
identify the commits to be streamed. Short IDs, including display IDs
, will
not work. To load commits using a short ID, search first using the CommitIndex
, which does accept
short IDs, and then use this method to resolve full Commit
s for any matches the index returns.
Note: Commits may not be passed to the callback in the order they are requested.
request
- the request, specifying which commits to retrieve and from which repositoriescallback
- a callback to receive the commitsvoid streamCommits(@Nonnull CommitsRequest request, @Nonnull CommitCallback callback)
CommitsRequest.getCommitId()
, unless one or more paths
are provided.
Then the first commit streamed, if any are, will be the first commit in the ancestry of the specified starting
commit which modifies at least one of the specified files.
This service call may be used to:
When streaming commits, extra properties
can also be loaded.
Properties are metadata associated with commits by CommitIndexer
s. Until 4.0, the extra properties
requested also control the attributes that are loaded. Attributes will be removed in 4.0.
Note: If any of the provided paths is renamed at some point in its history, commits will not follow the path across the rename. In other words, only commits for exact paths provided will be included.
request
- describes the commits to stream, and the repository to stream them fromcallback
- a callback to receive the commitsvoid streamCommitsBetween(@Nonnull CommitsBetweenRequest request, @Nonnull CommitCallback callback)
included commits
and the
excluded commits
.
This method promises to call CommitCallback.onStart(CommitContext)
on the supplied callback exactly once,
followed by zero or more calls to CommitCallback.onCommit(Commit)
, one for each commit to be streamed
(until onCommit(...)
returns false
or there are no more commits),
followed by exactly one call to CommitCallback.onEnd(CommitSummary)
.
See getCommitsBetween(...)
for a
description of the semantics of the commits returned.
request
- describes the commits to include/exclude, paths to filter by and which repository, or
repositories, contain the commitscallback
- a callback to receive the commitsvoid streamDiff(@Nonnull DiffRequest request, @Nonnull DiffContentCallback callback)
paths
at the specified commit.
Note: This interface is currently not paged. The implementation will apply a hard cap
(page.max.diff.lines
) and it is not possible to request subsequent content when that cap is exceeded.
request
- the repository, starting and terminating commits, and paths to filter bycallback
- a callback to receive the diff detailsvoid streamDiff(@Nonnull DiffRequest request, @Nonnull TypeAwareOutputSupplier outputSupplier)
request
.request
- the repository, starting and terminating commitsoutputSupplier
- a supplier which will provide an output streamvoid streamLastModified(@Nonnull LastModifiedRequest request, @Nonnull LastModifiedCallback callback)
path
, starting
from the specified commit
.
The commit ID
serves as a starting point. For any files under
the requested path, commits are traversed from that starting point until the most recent commit to directly
modify each file is found. Because the exact number of commits which must be traversed is unknown, this
operation may be very expensive.
request
- the repository, path and starting commitcallback
- a callback to receive last modification datavoid traverse(@Nonnull TraversalRequest request, @Nonnull TraversalCallback callback)
request
- the traversal request describing the repository and the commits to include and excludecallback
- a callback to receive the traversed commitsCopyright © 2020 Atlassian. All rights reserved.