summaryrefslogtreecommitdiff
path: root/mysys
diff options
context:
space:
mode:
authorVladislav Vaintroub <wlad@montyprogram.com>2012-01-20 01:57:58 +0100
committerVladislav Vaintroub <wlad@montyprogram.com>2012-01-20 01:57:58 +0100
commit74cac79218c58e399bec261683617d66652663fe (patch)
tree43978b455d807351ff5b1a46b27323980d365166 /mysys
parent139bf5ce4c3e67c287418a3c5043b056c9a5cf4d (diff)
downloadmariadb-git-74cac79218c58e399bec261683617d66652663fe.tar.gz
- Fix rpl_checksum test. Use basename of file in error messages, not the o
nes prefixed with .\ or ./ - Add my_basename() to mysys. - Do not compile files that are not needed on Windows (my_addr_resolve, an d safemalloc related stuff it it is not used) Avoids linker warnings about compilation of essentially empty files.
Diffstat (limited to 'mysys')
-rw-r--r--mysys/CMakeLists.txt13
-rw-r--r--mysys/my_basename.c41
-rw-r--r--mysys/stacktrace.c15
3 files changed, 56 insertions, 13 deletions
diff --git a/mysys/CMakeLists.txt b/mysys/CMakeLists.txt
index bf70b4615c1..819406b67e1 100644
--- a/mysys/CMakeLists.txt
+++ b/mysys/CMakeLists.txt
@@ -29,11 +29,11 @@ SET(MYSYS_SOURCES array.c charset-def.c charset.c checksum.c default.c
my_mkdir.c my_mmap.c my_once.c my_open.c my_pread.c my_pthread.c
my_quick.c my_read.c my_redel.c my_rename.c my_seek.c my_sleep.c
my_static.c my_symlink.c my_symlink2.c my_sync.c my_thr_init.c
+ my_basename.c
my_write.c ptr_cmp.c queues.c stacktrace.c
rijndael.c sha1.c string.c thr_alarm.c thr_lock.c thr_mutex.c
thr_rwlock.c tree.c typelib.c base64.c my_memmem.c my_getpagesize.c
lf_alloc-pin.c lf_dynarray.c lf_hash.c
- my_addr_resolve.c safemalloc.c my_new.cc
my_atomic.c my_getncpus.c my_safehash.c my_chmod.c my_rnd.c
my_uuid.c wqueue.c waiting_threads.c ma_dyncol.c
my_rdtsc.c)
@@ -42,8 +42,17 @@ IF (WIN32)
SET (MYSYS_SOURCES ${MYSYS_SOURCES} my_winthread.c my_wincond.c my_winerr.c my_winfile.c my_windac.c my_conio.c)
ENDIF()
-IF(NOT HAVE_CXX_NEW)
+IF(UNIX)
+ SET (MYSYS_SOURCES ${MYSYS_SOURCES} my_addr_resolve.c)
+ENDIF()
+
+IF(WITH_SAFEMALLOC OR NOT HAVE_CXX_NEW)
ADD_DEFINITIONS( -DUSE_MYSYS_NEW)
+ SET (MYSYS_SOURCES ${MYSYS_SOURCES} my_new.cc)
+ENDIF()
+
+IF(WITH_SAFEMALLOC)
+ SET (MYSYS_SOURCES ${MYSYS_SOURCES} safemalloc.c)
ENDIF()
IF(HAVE_ALARM)
diff --git a/mysys/my_basename.c b/mysys/my_basename.c
new file mode 100644
index 00000000000..9d1eaf53efa
--- /dev/null
+++ b/mysys/my_basename.c
@@ -0,0 +1,41 @@
+/* Copyright (C) 2011 Monty Program Ab
+
+ 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 */
+
+#include <my_sys.h>
+/**
+ @brief retrieve last component of the filename.
+ Loosely based on Single Unix Spec definition.
+
+ @fn my_basename()
+ @param filename Filename
+*/
+const char *my_basename(const char *filename)
+{
+ const char *last;
+ const char *s=filename;
+
+ /* Handle basename()'s special cases, as per single unix spec */
+ if (!filename || !filename[0])
+ return ".";
+ if(filename[0] == '/' && filename[1]== '\0')
+ return filename;
+
+ for(last= s; *s; s++)
+ {
+ if (*s == '/' || *s == '\\')
+ last= s + 1;
+ }
+ return last;
+}
diff --git a/mysys/stacktrace.c b/mysys/stacktrace.c
index 1766c0f503a..30c9fafcb82 100644
--- a/mysys/stacktrace.c
+++ b/mysys/stacktrace.c
@@ -465,6 +465,7 @@ void my_write_core(int sig)
#include <dbghelp.h>
#include <tlhelp32.h>
+#include <my_sys.h>
#if _MSC_VER
#pragma comment(lib, "dbghelp")
#endif
@@ -652,14 +653,10 @@ void my_print_stacktrace(uchar* unused1, ulong unused2)
&(package.sym));
have_source= SymGetLineFromAddr64(hProcess, addr, &line_offset, &line);
- my_safe_printf_stderr("%p ", addr);
+ my_safe_printf_stderr("%p ", (uintptr_t)addr);
if(have_module)
{
- char *base_image_name= strrchr(module.ImageName, '\\');
- if(base_image_name)
- base_image_name++;
- else
- base_image_name= module.ImageName;
+ const char *base_image_name= my_basename(module.ImageName);
my_safe_printf_stderr("%s!", base_image_name);
}
if(have_symbol)
@@ -670,11 +667,7 @@ void my_print_stacktrace(uchar* unused1, ulong unused2)
if(have_source)
{
- char *base_file_name= strrchr(line.FileName, '\\');
- if(base_file_name)
- base_file_name++;
- else
- base_file_name= line.FileName;
+ const char *base_file_name= my_basename(line.FileName);
my_safe_printf_stderr("[%s:%u]",
base_file_name, line.LineNumber);
}