com.hp.autonomy.aci.content.identifier.reference.AbstractReferences Maven / Gradle / Ivy
/*
* Copyright 2009-2015 Hewlett-Packard Development Company, L.P.
* Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License.
*/
package com.hp.autonomy.aci.content.identifier.reference;
import com.hp.autonomy.aci.content.identifier.DocumentIdentifiers;
import com.hp.autonomy.aci.content.identifier.IndexingIdentifiers;
import com.hp.autonomy.aci.content.identifier.QueryIdentifiers;
import java.util.UUID;
/**
* An abstract base-class that partially implements the {@link References} interface using sensible defaults.
*/
public abstract class AbstractReferences implements References {
// Stringifier just converts a Reference to a String. This is needed because we need subtly different string
// representations for queries and indexing.
private interface Stringifier {
String toString(Reference reference);
}
private static final Stringifier ACI_STRINGIFIER = new Stringifier() {
@Override
public String toString(final Reference reference) {
return reference.toString();
}
};
private static final Stringifier INDEXING_STRINGIFIER = new Stringifier() {
@Override
public String toString(final Reference reference) {
return reference.toIndexingString();
}
};
private static final String MATCH_NOTHING = "MATCH_NOTHING_" + UUID.randomUUID().toString();
/**
*
* @return {@code "matchreference"} or equivalent
*/
@Override
public String getMatchParameterName() {
return QueryIdentifiers.MATCH_REFERENCE;
}
/**
*
* @return {@code "DREDOCREF"} or equivalent
*/
@Override
public String getIndexingIdentifierName() {
return IndexingIdentifiers.DREDOCREF;
}
/**
*
* @return {@code "dontmatchreference"} or equivalent
*/
@Override
public String getDontMatchParameterName() {
return DocumentIdentifiers.DONT_MATCH_REFERENCE;
}
/**
*
* @return {@code "reference"} or equivalent
*/
@Override
public String getGetContentParameterName() {
return DocumentIdentifiers.REFERENCE;
}
@Override
public String toIndexingString() {
return toString(INDEXING_STRINGIFIER);
}
@Override
public References append(final String reference, final int section) {
return new ReferencesBuilder(this).append(reference, section);
}
@Override
public References append(final String... references) {
return new ReferencesBuilder(this).append(references);
}
@Override
public References append(final Iterable>... references) {
return new ReferencesBuilder(this).append(references);
}
/**
* Simple implementation that tests for emptiness using size() == 0. In most cases this should be
* overridden with a better implementation.
*
* @return true if and only if size is 0.
*/
@Override
public boolean isEmpty() {
return size() == 0;
}
/**
* Simple implementation that calculates the size by counting the number of elements in the iterator. In most cases
* this should be overridden with a better implementation.
*
* @return {@inheritDoc}
*/
@Override
public int size() {
int size = 0;
for (final Reference ref : this) {
++size;
}
return size;
}
@Override
public boolean equals(final Object obj) {
return obj == this || obj instanceof References && toString().equals(obj.toString());
}
@Override
public int hashCode() {
return toString().hashCode();
}
@Override
public String toString() {
return toString(ACI_STRINGIFIER);
}
private String toString(final Stringifier stringifier) {
if (isEmpty()) {
return MATCH_NOTHING;
}
final StringBuilder builder = new StringBuilder();
for (final Reference reference : this) {
if (reference == null) {
throw new IllegalStateException("Unexpected null reference in iterator");
}
builder.append(stringifier.toString(reference)).append('+');
}
if (builder.length() > 0) {
builder.deleteCharAt(builder.length() - 1);
}
return builder.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy