diff options
author | Vladislav Vaintroub <wlad@montyprogram.com> | 2012-01-20 01:57:58 +0100 |
---|---|---|
committer | Vladislav Vaintroub <wlad@montyprogram.com> | 2012-01-20 01:57:58 +0100 |
commit | 74cac79218c58e399bec261683617d66652663fe (patch) | |
tree | 43978b455d807351ff5b1a46b27323980d365166 /mysys | |
parent | 139bf5ce4c3e67c287418a3c5043b056c9a5cf4d (diff) | |
download | mariadb-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.txt | 13 | ||||
-rw-r--r-- | mysys/my_basename.c | 41 | ||||
-rw-r--r-- | mysys/stacktrace.c | 15 |
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); } |