mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
72ba95873a
(without InnoDB - all InnoDB changes were ignored)
88 lines
2.8 KiB
CMake
88 lines
2.8 KiB
CMake
# Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; version 2 of the License.
|
|
#
|
|
# This program 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 General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
# This script creates initial database for packaging on Windows
|
|
SET(CMAKE_SOURCE_DIR "@CMAKE_SOURCE_DIR@")
|
|
SET(CMAKE_CURRENT_BINARY_DIR "@CMAKE_CURRENT_BINARY_DIR@")
|
|
SET(MYSQLD_EXECUTABLE "@MYSQLD_EXECUTABLE@")
|
|
SET(CMAKE_CFG_INTDIR "@CMAKE_CFG_INTDIR@")
|
|
SET(WIN32 "@WIN32@")
|
|
# Force Visual Studio to output to stdout
|
|
IF(ENV{VS_UNICODE_OUTPUT})
|
|
SET ($ENV{VS_UNICODE_OUTPUT})
|
|
ENDIF()
|
|
IF(CMAKE_CFG_INTDIR AND CONFIG)
|
|
#Resolve build configuration variables
|
|
STRING(REPLACE "${CMAKE_CFG_INTDIR}" ${CONFIG} MYSQLD_EXECUTABLE
|
|
"${MYSQLD_EXECUTABLE}")
|
|
ENDIF()
|
|
|
|
# Create bootstrapper SQL script
|
|
FILE(WRITE bootstrap.sql "use mysql;\n" )
|
|
FOREACH(FILENAME mysql_system_tables.sql mysql_system_tables_data.sql mysql_performance_tables.sql)
|
|
FILE(STRINGS ${CMAKE_SOURCE_DIR}/scripts/${FILENAME} CONTENTS)
|
|
FOREACH(STR ${CONTENTS})
|
|
IF(NOT STR MATCHES "@current_hostname")
|
|
FILE(APPEND bootstrap.sql "${STR}\n")
|
|
ENDIF()
|
|
ENDFOREACH()
|
|
ENDFOREACH()
|
|
FILE(READ ${CMAKE_SOURCE_DIR}/scripts/fill_help_tables.sql CONTENTS)
|
|
FILE(APPEND bootstrap.sql "${CONTENTS}")
|
|
|
|
FILE(REMOVE_RECURSE mysql performance_schema)
|
|
FILE(REMOVE ibdata1 ib_logfile0 ib_logfile1)
|
|
|
|
MAKE_DIRECTORY(mysql)
|
|
IF(WIN32)
|
|
SET(CONSOLE --console)
|
|
ENDIF()
|
|
|
|
SET(BOOTSTRAP_COMMAND
|
|
${MYSQLD_EXECUTABLE}
|
|
--no-defaults
|
|
${CONSOLE}
|
|
--bootstrap
|
|
--lc-messages-dir=${CMAKE_CURRENT_BINARY_DIR}/share
|
|
--basedir=.
|
|
--datadir=.
|
|
--default-storage-engine=MyISAM
|
|
--max_allowed_packet=8M
|
|
--net_buffer_length=16K
|
|
)
|
|
|
|
GET_FILENAME_COMPONENT(CWD . ABSOLUTE)
|
|
EXECUTE_PROCESS(
|
|
COMMAND "@CMAKE_COMMAND@" -E echo Executing ${BOOTSTRAP_COMMAND}
|
|
)
|
|
EXECUTE_PROCESS (
|
|
COMMAND "@CMAKE_COMMAND@" -E
|
|
echo input file bootstrap.sql, current directory ${CWD}
|
|
)
|
|
EXECUTE_PROCESS (
|
|
COMMAND ${BOOTSTRAP_COMMAND}
|
|
INPUT_FILE bootstrap.sql
|
|
OUTPUT_VARIABLE OUT
|
|
ERROR_VARIABLE ERR
|
|
RESULT_VARIABLE RESULT
|
|
)
|
|
|
|
IF(NOT RESULT EQUAL 0)
|
|
MESSAGE(FATAL_ERROR "Could not create initial database \n ${OUT} \n ${ERR}")
|
|
ENDIF()
|
|
|
|
EXECUTE_PROCESS (
|
|
COMMAND "@CMAKE_COMMAND@" -E touch ${CMAKE_CURRENT_BINARY_DIR}/initdb.dep
|
|
)
|