Merge pull request #1105 from rbberger/truncate-file-path

Avoid buffer overflow during errors with long filenames
This commit is contained in:
Axel Kohlmeyer 2018-09-09 01:30:14 -04:00 committed by GitHub
commit 2faa34b2be
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 4 additions and 4 deletions

View File

@ -75,7 +75,7 @@ void Error::universe_all(const char *file, int line, const char *str)
update->whichflag = 0; update->whichflag = 0;
char msg[100]; char msg[100];
sprintf(msg, "ERROR: %s (%s:%d)\n", str, file, line); snprintf(msg, 100, "ERROR: %s (%s:%d)\n", str, truncpath(file), line);
throw LAMMPSException(msg); throw LAMMPSException(msg);
#else #else
MPI_Finalize(); MPI_Finalize();
@ -100,7 +100,7 @@ void Error::universe_one(const char *file, int line, const char *str)
update->whichflag = 0; update->whichflag = 0;
char msg[100]; char msg[100];
sprintf(msg, "ERROR: %s (%s:%d)\n", str, file, line); snprintf(msg, 100, "ERROR: %s (%s:%d)\n", str, truncpath(file), line);
throw LAMMPSAbortException(msg, universe->uworld); throw LAMMPSAbortException(msg, universe->uworld);
#else #else
MPI_Abort(universe->uworld,1); MPI_Abort(universe->uworld,1);
@ -151,7 +151,7 @@ void Error::all(const char *file, int line, const char *str)
update->whichflag = 0; update->whichflag = 0;
char msg[100]; char msg[100];
sprintf(msg, "ERROR: %s (%s:%d)\n", str, file, line); snprintf(msg, 100, "ERROR: %s (%s:%d)\n", str, truncpath(file), line);
if (universe->nworlds > 1) { if (universe->nworlds > 1) {
throw LAMMPSAbortException(msg, universe->uworld); throw LAMMPSAbortException(msg, universe->uworld);
@ -201,7 +201,7 @@ void Error::one(const char *file, int line, const char *str)
update->whichflag = 0; update->whichflag = 0;
char msg[100]; char msg[100];
sprintf(msg, "ERROR on proc %d: %s (%s:%d)\n", me, str, file, line); snprintf(msg, 100, "ERROR on proc %d: %s (%s:%d)\n", me, str, truncpath(file), line);
throw LAMMPSAbortException(msg, world); throw LAMMPSAbortException(msg, world);
#else #else
MPI_Abort(world,1); MPI_Abort(world,1);