A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[mc] Fix memory leads after calls to xbt_basename()
[simgrid.git]
/
src
/
mc
/
Process.cpp
diff --git
a/src/mc/Process.cpp
b/src/mc/Process.cpp
index
a04ec5c
..
6bf24dc
100644
(file)
--- a/
src/mc/Process.cpp
+++ b/
src/mc/Process.cpp
@@
-107,13
+107,17
@@
struct s_mc_memory_map_re {
static char* get_lib_name(const char* pathname, struct s_mc_memory_map_re* res)
{
static char* get_lib_name(const char* pathname, struct s_mc_memory_map_re* res)
{
- c
onst char* map_basename = xbt_basename((char*)
pathname);
+ c
har* map_basename = xbt_basename(
pathname);
regmatch_t match;
regmatch_t match;
- if(regexec(&res->so_re, map_basename, 1, &match, 0))
+ if(regexec(&res->so_re, map_basename, 1, &match, 0)) {
+ free(map_basename);
return nullptr;
return nullptr;
+ }
char* libname = strndup(map_basename, match.rm_so);
char* libname = strndup(map_basename, match.rm_so);
+ free(map_basename);
+ map_basename = nullptr;
// Strip the version suffix:
if(libname && !regexec(&res->version_re, libname, 1, &match, 0)) {
// Strip the version suffix:
if(libname && !regexec(&res->version_re, libname, 1, &match, 0)) {