All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.abubusoft.kripton.processor.sqlite.SqlUtility Maven / Gradle / Ivy

There is a newer version: 8.2.0-rc.4
Show newest version
/*******************************************************************************
 * Copyright 2015, 2017 Francesco Benincasa ([email protected]).
 *
 * 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.abubusoft.kripton.processor.sqlite;

import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import com.abubusoft.kripton.common.Pair;
import com.abubusoft.kripton.processor.core.ModelProperty;
import com.abubusoft.kripton.processor.exceptions.MethodParameterNotFoundException;
import com.abubusoft.kripton.processor.sqlite.model.SQLiteEntity;
import com.abubusoft.kripton.processor.sqlite.model.SQLiteModelMethod;
import com.squareup.javapoet.TypeName;

// TODO: Auto-generated Javadoc
/**
 * The Class SqlUtility.
 */
public class SqlUtility {
	
	/** The Constant PARAMETER. */
	private static final Pattern PARAMETER = Pattern.compile("\\$\\{\\s*([\\w\\.]*)\\s*\\}");

	/** The Constant WORD. */
	private static final Pattern WORD = Pattern.compile("([_a-zA-Z]\\w*)");

	/**
	 * Extract from value string every placeholder ${}, replace it with ? and
	 * then convert every field typeName with column typeName. The result is a
	 * pair: the first value is the elaborated string. The second is the list of
	 * parameters associated to ?. This second parameter is the list of
	 * parameters and replaced with ?.
	 *
	 * @param value the value
	 * @param method the method
	 * @param entity the entity
	 * @return Pair 
	 */
	public static Pair>> extractParametersFromString(String value, SQLiteModelMethod method, SQLiteEntity entity) {
		String whereStatement = value;
		Pair>> result = new Pair>>();
		result.value1 = new ArrayList>();

		// replace placeholder ${ } with ?
		{
			Matcher matcher = PARAMETER.matcher(whereStatement);

			String paramName;
			StringBuffer buffer = new StringBuffer();
			TypeName paramType;
			while (matcher.find()) {
				matcher.appendReplacement(buffer, "?");
				paramName = matcher.group(1);
				paramType = method.findParameterTypeByAliasOrName(paramName);

				if (paramType == null) {
					throw (new MethodParameterNotFoundException(method, paramName));
				}
				result.value1.add(new Pair(paramName, paramType));
			}
			matcher.appendTail(buffer);

			whereStatement = buffer.toString();
		}

		// replace fields
		{
			Matcher matcher = WORD.matcher(whereStatement);

			StringBuffer buffer = new StringBuffer();
			while (matcher.find()) {
				ModelProperty property = entity.findPropertyByName(matcher.group(1));
				if (property != null) {
					matcher.appendReplacement(buffer, entity.findPropertyByName(matcher.group(1)).columnName);
				}

			}
			matcher.appendTail(buffer);
			whereStatement = buffer.toString();
		}

		result.value0 = whereStatement;

		return result;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy