From d1c77f2e543c477d55a7c6d0cf52822bac123895 Mon Sep 17 00:00:00 2001 From: Bruno LATHUILIERE Date: Thu, 14 Jun 2018 21:05:58 +0200 Subject: [PATCH 1/2] --exclude option accepts file with long line (4096 caracters) --- vr_exclude.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/vr_exclude.c b/vr_exclude.c index 35c3c28..97e9033 100644 --- a/vr_exclude.c +++ b/vr_exclude.c @@ -33,6 +33,8 @@ #include "vr_main.h" +#define LINE_SIZEMAX VR_FNNAME_BUFSIZE + static Vr_Exclude* vr_addExclude (Vr_Exclude* list, const HChar * fnname, const HChar * objname) { Vr_Exclude * cell = VG_(malloc)("vr.addExclude.1", sizeof(Vr_Exclude)); cell->fnname = VG_(strdup)("vr.addExclude.2", fnname); @@ -99,7 +101,7 @@ Vr_Exclude * vr_loadExcludeList (Vr_Exclude * list, const HChar * fname) { return list; } - SizeT nLine = 256; + SizeT nLine = LINE_SIZEMAX; HChar *line = VG_(malloc)("vr.loadExcludes.1", nLine*sizeof(HChar)); Int lineno = 0; @@ -108,9 +110,9 @@ Vr_Exclude * vr_loadExcludeList (Vr_Exclude * list, const HChar * fname) { // Skip non-blank characters for (c = line; - cline+255) { + if (*c == 0 || c>line+LINE_SIZEMAX-1) { VG_(umsg)("ERROR (parse)\n"); return list; } @@ -118,7 +120,7 @@ Vr_Exclude * vr_loadExcludeList (Vr_Exclude * list, const HChar * fname) { // Skip blank characters for (++c; - c Date: Thu, 14 Jun 2018 23:46:29 +0200 Subject: [PATCH 2/2] --source option accepts file with long line (4096 caracters) --- vr_exclude.c | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/vr_exclude.c b/vr_exclude.c index 97e9033..6a82a3c 100644 --- a/vr_exclude.c +++ b/vr_exclude.c @@ -113,7 +113,7 @@ Vr_Exclude * vr_loadExcludeList (Vr_Exclude * list, const HChar * fname) { cline+LINE_SIZEMAX-1) { - VG_(umsg)("ERROR (parse)\n"); + VG_(umsg)("ERROR (parse) :%s \n",line); return list; } *c = 0; @@ -283,7 +283,7 @@ Vr_IncludeSource * vr_loadIncludeSourceList (Vr_IncludeSource * list, const HCha return list; } - SizeT nLine = 256; + SizeT nLine = LINE_SIZEMAX ; HChar *line = VG_(malloc)("vr.loadIncludeSources.1", nLine*sizeof(HChar)); Int lineno = 0; @@ -293,29 +293,29 @@ Vr_IncludeSource * vr_loadIncludeSourceList (Vr_IncludeSource * list, const HCha HChar* filename = line; // Skip non-blank characters for (c = line; - cline+255) { - VG_(umsg)("ERROR (parse1)\n"); + if (*c == 0 || c>line+LINE_SIZEMAX-1) { + VG_(umsg)("ERROR (parse1) : %s\n",line); return list; } *c = 0; // Skip blank characters for (++c; - cline+255) { - VG_(umsg)("ERROR (parse2)\n"); + if (c>line+LINE_SIZEMAX-1) { + VG_(umsg)("ERROR (parse2) : %s\n",line); return list; } if (*c==0) { - c = line + 256; + c = line + LINE_SIZEMAX; } else { *c = 0; ++c; @@ -324,7 +324,7 @@ Vr_IncludeSource * vr_loadIncludeSourceList (Vr_IncludeSource * list, const HCha // Skip blank characters for (; - c