89fade9
diff -up hplip-3.14.10/prnt/hpcups/HPCupsFilter.cpp.strncpy hplip-3.14.10/prnt/hpcups/HPCupsFilter.cpp
89fade9
--- hplip-3.14.10/prnt/hpcups/HPCupsFilter.cpp.strncpy	2015-01-21 16:52:44.066497631 +0000
89fade9
+++ hplip-3.14.10/prnt/hpcups/HPCupsFilter.cpp	2015-01-21 16:59:46.216434376 +0000
89fade9
@@ -203,6 +203,7 @@ HPCupsFilter::HPCupsFilter() : m_pPrinte
89fade9
     adj_k_width = 0;
89fade9
     black_raster = NULL;
89fade9
     color_raster = NULL;
89fade9
+    memset (&m_JA, 0, sizeof (m_JA));
89fade9
 }
89fade9
 
89fade9
 HPCupsFilter::~HPCupsFilter()
89fade9
@@ -384,9 +385,9 @@ DRIVER_ERROR HPCupsFilter::startPage (cu
89fade9
         m_JA.media_attributes.physical_height = cups_header->PageSize[1];
89fade9
         m_JA.media_attributes.printable_width = ((cups_header->ImagingBoundingBox[2]-cups_header->ImagingBoundingBox[0]) * horz_res) / 72;
89fade9
         m_JA.media_attributes.printable_height = ((cups_header->ImagingBoundingBox[3]-cups_header->ImagingBoundingBox[1]) * vert_res) / 72;
89fade9
-        strncpy(m_JA.media_attributes.PageSizeName, &cups_header->cupsString[0][0], sizeof(m_JA.media_attributes.PageSizeName));
89fade9
-        strncpy(m_JA.media_attributes.MediaTypeName, cups_header->MediaType, sizeof(m_JA.media_attributes.MediaTypeName));
89fade9
-        strncpy(m_JA.quality_attributes.hbpl1_print_quality, cups_header->OutputType, sizeof(m_JA.quality_attributes.hbpl1_print_quality));
89fade9
+        strncpy(m_JA.media_attributes.PageSizeName, &cups_header->cupsString[0][0], sizeof(m_JA.media_attributes.PageSizeName)-1);
89fade9
+        strncpy(m_JA.media_attributes.MediaTypeName, cups_header->MediaType, sizeof(m_JA.media_attributes.MediaTypeName)-1);
89fade9
+        strncpy(m_JA.quality_attributes.hbpl1_print_quality, cups_header->OutputType, sizeof(m_JA.quality_attributes.hbpl1_print_quality)-1);
89fade9
         m_JA.color_mode = cups_header->cupsRowStep;
89fade9
     }
89fade9
     else {
89fade9
diff -up hplip-3.14.10/prnt/hpijs/hpijs.cpp.strncpy hplip-3.14.10/prnt/hpijs/hpijs.cpp
89fade9
--- hplip-3.14.10/prnt/hpijs/hpijs.cpp.strncpy	2015-01-21 17:00:03.225512410 +0000
89fade9
+++ hplip-3.14.10/prnt/hpijs/hpijs.cpp	2015-01-21 17:04:59.308870785 +0000
89fade9
@@ -605,7 +605,7 @@ int main (int argc, char *argv[], char *
89fade9
    }
89fade9
 
89fade9
    if (argc > 2)
89fade9
-        strncpy(user_name, argv[2], sizeof(user_name));
89fade9
+        strncpy(user_name, argv[2], sizeof(user_name) - 1);
89fade9
 
89fade9
 #ifdef HAVE_LIBHPIP
89fade9
    char *pDev;
89fade9
diff -up hplip-3.14.10/prnt/hpijs/hpijsfax.cpp.strncpy hplip-3.14.10/prnt/hpijs/hpijsfax.cpp
89fade9
--- hplip-3.14.10/prnt/hpijs/hpijsfax.cpp.strncpy	2015-01-21 17:05:06.585904171 +0000
89fade9
+++ hplip-3.14.10/prnt/hpijs/hpijsfax.cpp	2015-01-21 17:05:15.787946389 +0000
89fade9
@@ -282,7 +282,7 @@ int hpijsFaxServer (int argc, char **arg
89fade9
 	char user_name[32]={0,};
89fade9
 
89fade9
    if (argc > 2)
89fade9
-        strncpy(user_name, argv[2], sizeof(user_name));
89fade9
+        strncpy(user_name, argv[2], sizeof(user_name) - 1);
89fade9
 
89fade9
     snprintf(hpFileName,sizeof(hpFileName),"%s/hp_%s_ijsfax_Log_XXXXXX",CUPS_TMP_DIR, user_name);
89fade9