NonNoteEntry.java
/*
* Copyright (C) 2010, Google Inc. and others
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Distribution License v. 1.0 which is available at
* https://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*/
package org.eclipse.jgit.notes;
import org.eclipse.jgit.lib.AnyObjectId;
import org.eclipse.jgit.lib.FileMode;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.TreeFormatter;
import org.eclipse.jgit.util.Paths;
/** A tree entry found in a note branch that isn't a valid note. */
class NonNoteEntry extends ObjectId {
/** Name of the entry in the tree, in raw format. */
private final byte[] name;
/** Mode of the entry as parsed from the tree. */
private final FileMode mode;
/** The next non-note entry in the same tree, as defined by tree order. */
NonNoteEntry next;
NonNoteEntry(byte[] name, FileMode mode, AnyObjectId id) {
super(id);
this.name = name;
this.mode = mode;
}
void format(TreeFormatter fmt) {
fmt.append(name, mode, this);
}
int treeEntrySize() {
return TreeFormatter.entrySize(mode, name.length);
}
int pathCompare(byte[] bBuf, int bPos, int bLen, FileMode bMode) {
return Paths.compare(
name, 0, name.length, mode.getBits(),
bBuf, bPos, bLen, bMode.getBits());
}
}