
This change introduces a new prolog predicate for the number of parents of a given patch set. This can be used to determine from within the "rules.pl" file whether a change is a merge commit or not. This can be useful in order to evaluate a different set of submit rules for merge commits. Example usage: submit_rule(submit(Parents)) :- Parents = label('Is-Merge', need(_)). submit_rule(submit(Parents)) :- gerrit:commit_parent_count(A), A > 1, Parents = label('Is-Merge', ok(user(ID))). Change-Id: I306163510e201606e936d95caea5ffa0bb957236
52 lines
1.6 KiB
Java
52 lines
1.6 KiB
Java
// 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;
|
|
}
|
|
}
|