com.sqlapp.gradle.plugins.pojo.VersionUpPojo.groovy Maven / Gradle / Ivy
/*
* Copyright (C) 2007-2017 Tatsuo Satoh
*
* This file is part of sqlapp-gradle-plugin.
*
* sqlapp-gradle-plugin is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* sqlapp-gradle-plugin is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with sqlapp-gradle-plugin. If not, see .
*/
package com.sqlapp.gradle.plugins.pojo
import com.sqlapp.util.CommonUtils
import groovy.lang.Closure;
import java.io.File
import java.util.List;
import org.gradle.api.DefaultTask
import org.gradle.api.Plugin
import org.gradle.api.Project
import org.gradle.api.tasks.Input
import org.gradle.api.tasks.InputDirectory
import org.gradle.api.tasks.Optional;
import org.gradle.api.tasks.TaskAction;
class VersionUpPojo extends DbPojo{
VersionUpPojo(Project project) {
super(project)
}
/**file directory*/
@InputDirectory
@Optional
def fileDirectory=new File("./");
/**encoding*/
@Input
@Optional
String encoding="UTF-8";
/**
* バージョンアップ用SQLのディレクトリ
*/
@InputDirectory
@Optional
def sqlDirectory;
/**
* バージョンダウン用のSQLのディレクトリ
*/
@InputDirectory
@Optional
def downSqlDirectory;
/**
* バージョンアップ前に実行するSQLのディレクトリ
*/
@InputDirectory
@Optional
def setupSqlDirectory=null;
/**
* バージョンアップ後に実行するSQLのディレクトリ
*/
@InputDirectory
@Optional
def finalizeSqlDirectory=null;
@Input
@Optional
Long lastChangeNumber=null;
@Input
@Optional
boolean showVersionOnly=false;
@Input
@Optional
boolean withSeriesNumber=true;
/**Schema Change log table name*/
@Input
@Optional
ChangeTablePojo changeTable=null;
@Input
@Optional
String placeholderPrefix='${';
@Input
@Optional
String placeholderSuffix='}';
@Input
@Optional
boolean placeholders=false;
void fileDirectory(def fileDirectory){
this.setFileDirectory(fileDirectory);
}
void encoding(String encoding) {
this.encoding=encoding
}
void sqlDownDirectory(def downSqlDirectory){
this.setDownSqlDirectory(downSqlDirectory);
}
void sqlDirectory(String sqlDirectory){
this.setSqlDirectory(sqlDirectory);
}
void setupSqlDirectory(def setupSqlDirectory){
this.setSetupSqlDirectory(setupSqlDirectory);
}
void finalizeSqlDirectory(def finalizeSqlDirectory){
this.setFinalizeSqlDirectory(finalizeSqlDirectory);
}
void changeTable(Closure closure) {
if (this.changeTable==null){
this.changeTable=project.configure(new ChangeTablePojo(this.getProject()), closure)
}else{
project.configure(this.changeTable, closure)
}
}
void setChangeTable(ChangeTablePojo changeTable) {
this.changeTable=changeTable
}
void lastChangeNumber(String lastChangeNumber){
this.setLastChangeNumber(lastChangeNumber);
}
void setLastChangeNumber(String lastChangeNumber){
if (lastChangeNumber!=null){
this.lastChangeNumber=Long.valueOf(lastChangeNumber);
}
}
void showVersionOnly(boolean showVersionOnly){
this.setShowVersionOnly(showVersionOnly);
}
void withSeriesNumber(boolean withSeriesNumber){
this.setWithSeriesNumber(withSeriesNumber);
}
VersionUpPojo clone(){
VersionUpPojo clone= super.clone();
if (this.changeTable!=null){
clone.changeTable=this.changeTable.clone();
}
return clone;
}
void placeholderPrefix(String placeholderPrefix){
this.placeholderPrefix=placeholderPrefix;
}
void placeholderSuffix(String placeholderSuffix){
this.placeholderSuffix=placeholderSuffix;
}
void placeholders(boolean placeholders){
this.placeholders=placeholders;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy