/**
* 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.
*
* Copyright 2012-2016 the original author or authors.
*/
package org.assertj.db.api;
import org.assertj.db.navigation.ToColumn;
import org.assertj.db.navigation.ToRow;
import org.assertj.db.navigation.origin.OriginWithColumnsAndRows;
import org.assertj.db.type.AbstractDbData;
/**
* Base class for all assertions with an {@link org.assertj.db.navigation.origin.Origin}
* and have {@link org.assertj.db.type.Column}s and {@link org.assertj.db.type.Row}s.
*
* @param <E> The "self" type of this assertion class. Please read "<a href="http://bit.ly/1IZIRcY"
* target="_blank">Emulating 'self types' using Java Generics to simplify fluent API implementation</a>"
* for more details.
* @param <O> The type of the assertion class of {@link org.assertj.db.navigation.origin.Origin}.
* @param <D> The class of the actual value (an sub-class of {@link AbstractDbData}).
* @param <A> The class of the original assert (an sub-class of {@link AbstractDbAssert}).
* @param <C> The class of this assertion (an sub-class of {@link AbstractColumnAssert}).
* @param <CV> The class of this assertion on the value (an sub-class of {@link AbstractColumnValueAssert}).
* @param <R> The class of the equivalent row assert (an sub-class of {@link AbstractRowAssert}).
* @param <RV> The class of the equivalent row assertion on the value (an sub-class of {@link AbstractRowValueAssert}).
* @author RĂ©gis Pouiller
*/
public abstract class AbstractAssertWithOriginWithColumnsAndRows<E extends AbstractAssertWithOriginWithColumnsAndRows<E, O, D, A, C, CV, R, RV>, O extends OriginWithColumnsAndRows<C, R>, D extends AbstractDbData<D>, A extends AbstractDbAssert<D, A, C, CV, R, RV>, C extends AbstractColumnAssert<D, A, C, CV, R, RV>, CV extends AbstractColumnValueAssert<D, A, C, CV, R, RV>, R extends AbstractRowAssert<D, A, C, CV, R, RV>, RV extends AbstractRowValueAssert<D, A, C, CV, R, RV>>
extends AbstractAssertWithOrigin<E, O>
implements ToColumn<C>,
ToRow<R> {
/**
* Constructor.
*
* @param selfType Type of this assertion class : a sub-class of {@code AbstractAssertWithOriginWithColumnsAndRows}.
* @param origin The assertion of {@link org.assertj.db.navigation.origin.Origin}.
*/
AbstractAssertWithOriginWithColumnsAndRows(Class<E> selfType, O origin) {
super(selfType, origin);
}
/**
* {@inheritDoc}
*/
@Override
public R row() {
return returnToOrigin().row();
}
/**
* {@inheritDoc}
*/
@Override
public R row(int index) {
return returnToOrigin().row(index);
}
/**
* {@inheritDoc}
*/
@Override
public C column() {
return returnToOrigin().column();
}
/**
* {@inheritDoc}
*/
@Override
public C column(int index) {
return returnToOrigin().column(index);
}
/**
* {@inheritDoc}
*/
@Override
public C column(String columnName) {
return returnToOrigin().column(columnName);
}
}