#*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.
 *#
#if($nestTables == false)
package $tablePackageName;

#if($baseTableClassName.equals('DBTable'))
import org.apache.empire.db.DBTable;
#end
import org.apache.empire.data.DataType;
import org.apache.empire.db.DBTableColumn;
import $basePackageName.${dbClassName};
#end

#if($nestTables == true)
  public static class $parser.getTableClassName($table.name) extends ${baseTableClassName} {
#else
public class $parser.getTableClassName($table.name) extends ${baseTableClassName} {
#end

	private static final long serialVersionUID = 1L;
	
	// define columns
#foreach ($col in $table.columns)
	public final DBTableColumn ${parser.getColumnName($col)};
#end
	
	public $parser.getTableClassName($table.name)(${dbClassName} db) {
		super("$table.name", db);
		
		// create columns
#foreach ($col in $table.columns)
#if($parser.getDefaultValue($col))
		${parser.getColumnName($col)} = addColumn("${col.name}", DataType.${parser.getDataType($col)}, ${col.size}, ${col.isRequired()}, ${parser.getDefaultValue($col)});
#else
		${parser.getColumnName($col)} = addColumn("${col.name}", DataType.${parser.getDataType($col)}, ${col.size}, ${col.isRequired()});
#end
#end


#if($table.keyColumns && $table.keyColumns.size()>0)
		// configure key columns (primary key)
#if($table.keyColumns.size()==1)
		setPrimaryKey(${parser.getColumnName($table.keyColumns[0])});
#else
		DBTableColumn[] keyColumns = new DBTableColumn[] {
#foreach ($col in $table.keyColumns)
#if($foreach.isLast()==false)
			${parser.getColumnName($col)},
#else
			${parser.getColumnName($col)} };
		setPrimaryKey(keyColumns);
#end
#end
#end

#end
	}
#if($nestTables == true)
  }
#else
}
#end