summaryrefslogtreecommitdiff
path: root/libmysqld
diff options
context:
space:
mode:
Diffstat (limited to 'libmysqld')
-rw-r--r--libmysqld/Makefile.am7
-rw-r--r--libmysqld/cmakelists.txt86
-rw-r--r--libmysqld/examples/cmakelists.txt11
-rw-r--r--libmysqld/lib_sql.cc2
-rw-r--r--libmysqld/libmysqld.def1
5 files changed, 105 insertions, 2 deletions
diff --git a/libmysqld/Makefile.am b/libmysqld/Makefile.am
index 33e11dc0333..6e38fb267d9 100644
--- a/libmysqld/Makefile.am
+++ b/libmysqld/Makefile.am
@@ -22,6 +22,7 @@ MYSQLSHAREdir = $(pkgdatadir)
MYSQLBASEdir= $(prefix)
MYSQLLIBdir= $(libdir)
+EXTRA_DIST = libmysqld.def
DEFS = -DEMBEDDED_LIBRARY -DMYSQL_SERVER \
-DDEFAULT_MYSQL_HOME="\"$(MYSQLBASEdir)\"" \
-DDATADIR="\"$(MYSQLDATAdir)\"" \
@@ -93,8 +94,12 @@ INC_LIB= $(top_builddir)/regex/libregex.a \
$(top_builddir)/dbug/libdbug.a \
$(top_builddir)/vio/libvio.a \
@mysql_se_libs@ \
- @yassl_libs_with_path@
+ $(yassl_las)
+if HAVE_YASSL
+yassl_las = $(top_srcdir)/extra/yassl/src/libyassl.la \
+ $(top_srcdir)/extra/yassl/taocrypt/src/libtaocrypt.la
+endif
# Storage engine specific compilation options
diff --git a/libmysqld/cmakelists.txt b/libmysqld/cmakelists.txt
new file mode 100644
index 00000000000..a11a0dffd33
--- /dev/null
+++ b/libmysqld/cmakelists.txt
@@ -0,0 +1,86 @@
+SET(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -DSAFEMALLOC -DSAFE_MUTEX")
+SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DSAFEMALLOC -DSAFE_MUTEX")
+
+# Need to set USE_TLS, since __declspec(thread) approach to thread local
+# storage does not work properly in DLLs.
+ADD_DEFINITIONS(-DUSE_TLS -DHAVE_ROW_BASED_REPLICATION -DMYSQL_SERVER
+ -DEMBEDDED_LIBRARY)
+
+# The old Windows build method used renamed (.cc -> .cpp) source files, fails
+# in #include in lib_sql.cc. So disable that using the USING_CMAKE define.
+ADD_DEFINITIONS(-DUSING_CMAKE)
+
+INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/include
+ ${CMAKE_SOURCE_DIR}/libmysqld
+ ${CMAKE_SOURCE_DIR}/libmysql
+ ${CMAKE_SOURCE_DIR}/sql
+ ${CMAKE_SOURCE_DIR}/regex
+ ${CMAKE_SOURCE_DIR}/extra/yassl/include
+ ${CMAKE_SOURCE_DIR}/storage/bdb/build_win32
+ ${CMAKE_SOURCE_DIR}/zlib
+)
+
+ADD_LIBRARY(mysqldemb emb_qcache.cc libmysqld.c lib_sql.cc
+ ../client/get_password.c ../libmysql/errmsg.c
+ ../libmysql/libmysql.c ../sql/password.c ../sql-common/client.c
+ ../sql-common/my_time.c ../sql-common/my_user.c
+ ../sql-common/pack.c ../sql/derror.cc ../sql/event_executor.cc
+ ../sql/event_timed.cc ../sql/event.cc ../sql/discover.cc
+ ../sql/field_conv.cc ../sql/field.cc ../sql/filesort.cc
+ ../sql/gstream.cc ../sql/ha_heap.cc ../sql/ha_myisam.cc
+ ../sql/ha_myisammrg.cc ${mysql_se_ha_src}
+ ../sql/handler.cc ../sql/handlerton-win.cc ../sql/hash_filo.cc
+ ../sql/hostname.cc ../sql/init.cc ../sql/item_buff.cc
+ ../sql/item_cmpfunc.cc ../sql/item.cc ../sql/item_create.cc
+ ../sql/item_func.cc ../sql/item_geofunc.cc ../sql/item_row.cc
+ ../sql/item_strfunc.cc ../sql/item_subselect.cc ../sql/item_sum.cc
+ ../sql/item_timefunc.cc ../sql/item_uniq.cc ../sql/item_xmlfunc.cc
+ ../sql/key.cc ../sql/lock.cc ../sql/log.cc ../sql/log_event.cc
+ ../sql/mf_iocache.cc ../sql/my_decimal.cc ../sql/net_serv.cc
+ ../sql/opt_range.cc ../sql/opt_sum.cc ../sql/parse_file.cc
+ ../sql/procedure.cc ../sql/protocol.cc ../sql/records.cc
+ ../sql/repl_failsafe.cc ../sql/rpl_filter.cc ../sql/set_var.cc
+ ../sql/spatial.cc ../sql/sp_cache.cc ../sql/sp.cc
+ ../sql/sp_head.cc ../sql/sp_pcontext.cc ../sql/sp_rcontext.cc
+ ../sql/sql_acl.cc ../sql/sql_analyse.cc ../sql/sql_base.cc
+ ../sql/sql_cache.cc ../sql/sql_class.cc ../sql/sql_crypt.cc
+ ../sql/sql_cursor.cc ../sql/sql_db.cc ../sql/sql_delete.cc
+ ../sql/sql_derived.cc ../sql/sql_do.cc ../sql/sql_error.cc
+ ../sql/sql_handler.cc ../sql/sql_help.cc ../sql/sql_insert.cc
+ ../sql/sql_lex.cc ../sql/sql_list.cc ../sql/sql_load.cc
+ ../sql/sql_manager.cc ../sql/sql_map.cc ../sql/sql_parse.cc
+ ../sql/sql_partition.cc ../sql/sql_plugin.cc ../sql/sql_prepare.cc
+ ../sql/sql_rename.cc ../sql/sql_repl.cc ../sql/sql_select.cc
+ ../sql/sql_show.cc ../sql/sql_state.c ../sql/sql_string.cc
+ ../sql/sql_tablespace.cc ../sql/sql_table.cc ../sql/sql_test.cc
+ ../sql/sql_trigger.cc ../sql/sql_udf.cc ../sql/sql_union.cc
+ ../sql/sql_update.cc ../sql/sql_view.cc ../sql/sql_yacc.cc
+ ../sql/strfunc.cc ../sql/table.cc ../sql/thr_malloc.cc
+ ../sql/time.cc ../sql/tztime.cc ../sql/uniques.cc ../sql/unireg.cc
+ ../sql/partition_info.cc ../vio/vio.c
+ ../vio/viosocket.c ../vio/viossl.c ../vio/viosslfactories.c)
+
+# Seems we cannot make a library without at least one source file. So use a
+# dummy empty file
+FILE(WRITE cmake_dummy.c " ")
+
+ADD_LIBRARY(mysqlserver cmake_dummy.c)
+TARGET_LINK_LIBRARIES(mysqlserver wsock32)
+ADD_DEPENDENCIES(mysqlserver dbug mysys strings zlib mysqldemb regex myisam myisammrg
+ heap yassl taocrypt)
+IF(WITH_ARCHIVE_STORAGE_ENGINE)
+ ADD_DEPENDENCIES(mysqlserver archive)
+ENDIF(WITH_ARCHIVE_STORAGE_ENGINE)
+IF(WITH_EXAMPLE_STORAGE_ENGINE)
+ ADD_DEPENDENCIES(mysqlserver example)
+ENDIF(WITH_EXAMPLE_STORAGE_ENGINE)
+IF(WITH_INNOBASE_STORAGE_ENGINE)
+ ADD_DEPENDENCIES(mysqlserver innobase)
+ENDIF(WITH_INNOBASE_STORAGE_ENGINE)
+IF(WITH_BERKELEY_STORAGE_ENGINE)
+ ADD_DEPENDENCIES(mysqlserver bdb)
+ENDIF(WITH_BERKELEY_STORAGE_ENGINE)
+
+ADD_LIBRARY(libmysqld MODULE cmake_dummy.c libmysqld.def)
+TARGET_LINK_LIBRARIES(libmysqld wsock32)
+ADD_DEPENDENCIES(libmysqld mysqlserver)
diff --git a/libmysqld/examples/cmakelists.txt b/libmysqld/examples/cmakelists.txt
new file mode 100644
index 00000000000..5c58264a7e7
--- /dev/null
+++ b/libmysqld/examples/cmakelists.txt
@@ -0,0 +1,11 @@
+INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/include
+ ${CMAKE_SOURCE_DIR}/libmysqld/include
+ ${CMAKE_SOURCE_DIR}/extra/yassl/include)
+
+# Currently does not work with DBUG, there are missing symbols reported.
+ADD_DEFINITIONS(-DDBUG_OFF)
+ADD_EXECUTABLE(test_libmysqld ../../client/completion_hash.cc
+ ../../client/mysql.cc ../../client/readline.cc
+ ../../client/sql_string.cc)
+TARGET_LINK_LIBRARIES(test_libmysqld yassl taocrypt zlib wsock32)
+ADD_DEPENDENCIES(test_libmysqld libmysqld)
diff --git a/libmysqld/lib_sql.cc b/libmysqld/lib_sql.cc
index 6c520797d4f..70022d526a5 100644
--- a/libmysqld/lib_sql.cc
+++ b/libmysqld/lib_sql.cc
@@ -28,7 +28,7 @@ extern "C"
extern unsigned long max_allowed_packet, net_buffer_length;
}
-#if defined (__WIN__)
+#if defined(__WIN__) && !defined(USING_CMAKE)
#include "../sql/mysqld.cpp"
#else
#include "../sql/mysqld.cc"
diff --git a/libmysqld/libmysqld.def b/libmysqld/libmysqld.def
index 93456901a7d..8b930c1ba1e 100644
--- a/libmysqld/libmysqld.def
+++ b/libmysqld/libmysqld.def
@@ -18,6 +18,7 @@ EXPORTS
list_delete
load_defaults
max_allowed_packet
+ my_cgets
my_end
my_getopt_print_errors
my_init