
com.iofairy.pattern.matcher.StringRMatcher Maven / Gradle / Ivy
/*
* Copyright (C) 2021 iofairy,
*
* 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 com.iofairy.pattern.matcher;
import com.iofairy.lambda.R1;
import com.iofairy.lambda.RT1;
import com.iofairy.pattern.PatternIn;
import com.iofairy.pattern.type.*;
import java.util.List;
import java.util.Objects;
/**
* String Matcher with return value
* @since 0.0.1
*/
public class StringRMatcher extends SimpleRInMatcher {
private PatternString patternString;
private String ucValue; // Upper Case Value
private boolean ignoreCase = false;
private boolean isMatchForNext = false;
public StringRMatcher(String value, PatternString patternString) {
this(value);
this.patternString = patternString;
ucValue = value;
if (value != null){
if (patternString == PatternString.ICCONTAIN
|| patternString == PatternString.ICPREFIX
|| patternString == PatternString.ICSUFFIX){
ucValue = value.toUpperCase();
ignoreCase = true;
}
}
}
public StringRMatcher(String value, boolean isMatch) {
super(value, isMatch);
}
public StringRMatcher(String value) {
this(value, false);
}
@Override
public StringRMatcher when(String value, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch) {
if (value == null || this.value == null) {
if (this.value == value) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
String ucValue = ignoreCase ? value.toUpperCase() : value;
switch (patternString) {
case IGNORECASE:
if (ucValue.equalsIgnoreCase(this.ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case CONTAIN:
case ICCONTAIN:
if (this.ucValue.contains(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case PREFIX:
case ICPREFIX:
if (this.ucValue.startsWith(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case SUFFIX:
case ICSUFFIX:
if (this.ucValue.endsWith(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
default:
if (this.ucValue.equals(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
}
}
return this;
}
@Override
public StringRMatcher whenNext(String value, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch) {
if (value == null || this.value == null) {
if (this.value == value) {
returnValue = action.$(this.value);
}
return this;
}
String ucValue = ignoreCase ? value.toUpperCase() : value;
switch (patternString) {
case IGNORECASE:
if (ucValue.equalsIgnoreCase(this.ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case CONTAIN:
case ICCONTAIN:
if (this.ucValue.contains(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case PREFIX:
case ICPREFIX:
if (this.ucValue.startsWith(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case SUFFIX:
case ICSUFFIX:
if (this.ucValue.endsWith(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
default:
if (this.ucValue.equals(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
}
}
return this;
}
@Override
public StringRMatcher with(String value, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch) {
if (value == null || this.value == null) {
if (this.value == value) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
String ucValue = ignoreCase ? value.toUpperCase() : value;
switch (patternString) {
case IGNORECASE:
if (ucValue.equalsIgnoreCase(this.ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case CONTAIN:
case ICCONTAIN:
if (this.ucValue.contains(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case PREFIX:
case ICPREFIX:
if (this.ucValue.startsWith(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
case SUFFIX:
case ICSUFFIX:
if (this.ucValue.endsWith(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
break;
default:
if (this.ucValue.equals(ucValue)) {
isMatch = true;
returnValue = action.$(this.value);
}
}
}
return this;
}
@Override
public StringRMatcher withNext(String value, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch) {
if (value == null || this.value == null) {
if (this.value == value) {
returnValue = action.$(this.value);
}
return this;
}
String ucValue = ignoreCase ? value.toUpperCase() : value;
switch (patternString) {
case IGNORECASE:
if (ucValue.equalsIgnoreCase(this.ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case CONTAIN:
case ICCONTAIN:
if (this.ucValue.contains(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case PREFIX:
case ICPREFIX:
if (this.ucValue.startsWith(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
case SUFFIX:
case ICSUFFIX:
if (this.ucValue.endsWith(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
break;
default:
if (this.ucValue.equals(ucValue)) {
isMatchForNext = true;
returnValue = action.$(this.value);
}
}
}
return this;
}
@Override
public StringRMatcher when(boolean value, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch && value) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
@Override
public StringRMatcher whenNext(boolean value, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch && value) {
returnValue = action.$(this.value);
}
return this;
}
@Override
public StringRMatcher with(boolean value, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch && value) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
@Override
public StringRMatcher withNext(boolean value, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch && value) {
returnValue = action.$(this.value);
}
return this;
}
@Override
public StringRMatcher when(PatternIn values, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch) {
if (this.value == null) {
if (values == null || values.getVs().contains(this.value)) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
if (values != null) {
List vs = values.getVs();
for (String v : vs) {
if (v != null) {
when(v, action);
if (isMatch) break;
}
}
}
}
return this;
}
@Override
public StringRMatcher whenNext(PatternIn values, R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch) {
if (this.value == null) {
if (values == null || values.getVs().contains(this.value)) {
returnValue = action.$(this.value);
}
return this;
}else {
if (values != null) {
List vs = values.getVs();
for (String v : vs) {
if (v != null) {
whenNext(v, action);
if (isMatchForNext) break;
}
}
}
}
}
return this;
}
@Override
public StringRMatcher with(PatternIn values, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch) {
if (this.value == null) {
if (values == null || values.getVs().contains(this.value)) {
isMatch = true;
returnValue = action.$(this.value);
}
return this;
}
if (values != null) {
List vs = values.getVs();
for (String v : vs) {
if (v != null) {
with(v, action);
if (isMatch) break;
}
}
}
}
return this;
}
@Override
public StringRMatcher withNext(PatternIn values, RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch) {
if (this.value == null) {
if (values == null || values.getVs().contains(this.value)) {
returnValue = action.$(this.value);
}
return this;
}else {
if (values != null) {
List vs = values.getVs();
for (String v : vs) {
if (v != null) {
withNext(v, action);
if (isMatchForNext) break;
}
}
}
}
}
return this;
}
@Override
public R orElse(R1 super String, ? extends R> action) {
Objects.requireNonNull(action);
if (!isMatch) {
returnValue = action.$(this.value);
}
return returnValue;
}
@Override
public R orWith(RT1 super String, ? extends R, E> action) throws E {
Objects.requireNonNull(action);
if (!isMatch) {
returnValue = action.$(this.value);
}
return returnValue;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy