Merge branch 'stable-2.16' into stable-3.0

* stable-2.16:
  Bazel: Fix plugin api javadoc generation
  Add new prolog fact to documentation
  Add prolog predicate to determine number of parents

Change-Id: I4e2e62a44dcf653264ba456e1640aa998158f78b
This commit is contained in:
Marco Miller 2020-03-15 16:31:40 -04:00
commit 3c0d021f07
3 changed files with 55 additions and 1 deletions

View File

@ -48,6 +48,9 @@ of them we must use a qualified name like `gerrit:change_branch(X)`.
|`commit_message/1` |`commit_message('Fix bug X').`
|Commit message as string atom
|`commit_parent_count/1` |`commit_parent_count(1).`
|Number of parent commits of a commit. Can be used to detect merge commits
|`commit_stats/3` |`commit_stats(5,20,50).`
|Number of files modified, number of insertions and the number of deletions.

View File

@ -0,0 +1,51 @@
// Copyright (C) 2020 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package gerrit;
import com.google.gerrit.server.rules.StoredValues;
import com.googlecode.prolog_cafe.exceptions.PrologException;
import com.googlecode.prolog_cafe.lang.IntegerTerm;
import com.googlecode.prolog_cafe.lang.Operation;
import com.googlecode.prolog_cafe.lang.Predicate;
import com.googlecode.prolog_cafe.lang.Prolog;
import com.googlecode.prolog_cafe.lang.Term;
import org.eclipse.jgit.revwalk.RevCommit;
/**
* Prolog fact for the number of parents of a given commit
*
* <pre>
* 'commit_parent_count'(-Count)
* </pre>
*/
public class PRED_commit_parent_count_1 extends Predicate.P1 {
public PRED_commit_parent_count_1(Term a1, Operation n) {
arg1 = a1;
cont = n;
}
@Override
public Operation exec(Prolog engine) throws PrologException {
engine.setB0();
Term a1 = arg1.dereference();
RevCommit commit = StoredValues.COMMIT.get(engine);
if (!a1.unify(new IntegerTerm(commit.getParentCount()), engine.trail)) {
return engine.fail();
}
return cont;
}
}

View File

@ -32,7 +32,7 @@ def _impl(ctx):
"export TZ",
"rm -rf %s" % source,
"mkdir %s" % source,
" && ".join(["unzip -qud %s %s" % (source, j.path) for j in source_jars.to_list()]),
" && ".join(["unzip -qoud %s %s" % (source, j.path) for j in source_jars.to_list()]),
"rm -rf %s" % dir,
"mkdir %s" % dir,
" ".join([