summaryrefslogtreecommitdiff
blob: 0b02e5a173655bd69bfd5ebc6895b7c93269d9f6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
--- frontend/file-selector.cc
+++ frontend/file-selector.cc
@@ -35,6 +35,7 @@
 #include <cstdio>
 #include <cstdlib>
 #include <cstring>
+#include <string>
 #include <unistd.h>
 
 #include "pisa_aleart_dialog.h"
@@ -1023,17 +1024,14 @@
   // check write access to the directory (note that we need execute
   // privileges as well)
 
-  char *slash = strrchr( file, '/');
-  *slash = '\0';		// temporarily truncate to dirname
-  const char *dir = (file == slash
-		     ? "/"	// whoops!, file in root directory
-		     : file);
+  const char *slash = strrchr( file, '/');
+  std::string dir( file, slash - file);
+  if (dir.empty())
+    dir = "/";
 
   bool w_ok = false;		// assume the worst
-  if (0 == access( dir, F_OK ))
-    w_ok = (0 == access( dir, W_OK | X_OK ));
-
-  *slash = '/';			// restore filename
+  if (0 == access( dir.c_str(), F_OK ))
+    w_ok = (0 == access( dir.c_str(), W_OK | X_OK ));
 
   return w_ok;
 }
--- frontend/pisa_view_manager.cc
+++ frontend/pisa_view_manager.cc
@@ -45,6 +45,7 @@
 #include <sys/stat.h>
 #include <dirent.h>
 #include <locale.h>
+#include <string>
 
 /*------------------------------------------------------------*/
 #include "pisa_view_manager.h"
@@ -1170,10 +1171,10 @@
 pisa_file_type
 view_manager::get_file_type (const char *filename)
 {
-  char *dot   = strrchr (filename, '.');
+  const char *dot   = strrchr (filename, '.');
   if (!dot)
     {
-      char *slash = strrchr (filename, '/');
+      const char *slash = strrchr (filename, '/');
       if (   (strlen (slash) == strlen ("/" PACKAGE_TARNAME "XXXXXX"))
 	  && (0 == strncmp (slash, "/" PACKAGE_TARNAME,
 			    strlen ("/" PACKAGE_TARNAME))))
@@ -1260,19 +1261,19 @@
 {
   int cancel = 0;		// default: don't cancel
 
-  char *slash = strrchr( regexp, '/' );
+  const char *slash = strrchr( regexp, '/' );
 
   if (!slash)
     return cancel = 1;
 
-  *slash = '\0';		// regexp now holds the directory name
-  char dirname[ strlen( regexp )];
-  strcpy( dirname, regexp );
+  std::string s( regexp, slash - regexp);
+  char dirname[ s.size()];
+  strcpy( dirname, s.c_str());
 
-  *slash = '^';			// re-anchor the regexp
+  s = std::string("^") + (slash + 1); // re-anchor the regexp
 
   regex_t *comp_regex = new regex_t;
-  int comp = regcomp( comp_regex, slash, REG_EXTENDED );
+  int comp = regcomp( comp_regex, s.c_str(), REG_EXTENDED );
 
   if (0 == comp)
     {
--- lib/imgstream.cc
+++ lib/imgstream.cc
@@ -185,7 +185,7 @@
   return lt_dlclose (lib);
 }
 
-static int reversionsort (const void*, const void*);
+static int reversionsort (const dirent**, const dirent**);
 int selector (const dirent *);
 				// forward declarations
 
@@ -321,7 +321,7 @@
 //! The C library's versionsort() function in reverse.
 static
 int
-reversionsort (const void *a, const void *b)
+reversionsort (const dirent **a, const dirent **b)
 {
   return versionsort (b, a);
 }