summaryrefslogtreecommitdiff
path: root/xkb/ddxList.c
diff options
context:
space:
mode:
authorAlexander Gottwald <alexander.gottwald@s1999.tu-chemnitz.de>2005-01-09 17:35:47 +0000
committerAlexander Gottwald <alexander.gottwald@s1999.tu-chemnitz.de>2005-01-09 17:35:47 +0000
commitfe4e74241f6791cb1cefdddeb492ed0f56ce99b4 (patch)
treef9ad648459ad11c54cfa5fa9976552734a29b2e8 /xkb/ddxList.c
parentba25f7e8dcaa2690ce3eab839904fac034002e0b (diff)
xc/programs/Xserver/xkb/ddxList.c
//bugs.freedesktop.org/show_bug.cgi?id=2245) attachment #1647 (https://bugs.freedesktop.org/attachment.cgi?id=1647): export Win32System and Win32TempDir remove #ifdef WIN32 block for building xkbcomp commandline create win32 tempfile in system tempdir use PATH_MAX*4 for commandline buffer unlink tmpfile again
Diffstat (limited to 'xkb/ddxList.c')
-rw-r--r--xkb/ddxList.c67
1 files changed, 38 insertions, 29 deletions
diff --git a/xkb/ddxList.c b/xkb/ddxList.c
index b2e644fc3..c58ec46d4 100644
--- a/xkb/ddxList.c
+++ b/xkb/ddxList.c
@@ -49,6 +49,22 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.
#endif
#endif
+#ifdef WIN32
+/* from ddxLoad.c */
+extern const char* Win32TempDir();
+extern int Win32System(const char *cmdline);
+#undef System
+#define System Win32System
+
+#define W32_tmparg " '%s'"
+#define W32_tmpfile ,tmpname
+#define W32_tmplen strlen(tmpname)+3
+#else
+#define W32_tmparg
+#define W32_tmpfile
+#define W32_tmplen 0
+#endif
+
/***====================================================================***/
static char *componentDirs[_XkbListNumComponents] = {
@@ -115,14 +131,14 @@ XkbDDXListComponent( DeviceIntPtr dev,
XkbSrvListInfoPtr list,
ClientPtr client)
{
-char *file,*map,*tmp,buf[PATH_MAX];
+char *file,*map,*tmp,buf[PATH_MAX*4];
FILE *in;
Status status;
int rval;
Bool haveDir;
#ifdef WIN32
-char tmpname[32];
-#endif
+char tmpname[PATH_MAX];
+#endif
if ((list->pattern[what]==NULL)||(list->pattern[what][0]=='\0'))
return Success;
@@ -141,7 +157,8 @@ char tmpname[32];
in= NULL;
haveDir= True;
#ifdef WIN32
- strcpy(tmpname, "\\temp\\xkb_XXXXXX");
+ strcpy(tmpname, Win32TempDir());
+ strcat(tmpname, "\\xkb_XXXXXX");
(void) mktemp(tmpname);
#endif
if (XkbBaseDirectory!=NULL) {
@@ -154,19 +171,15 @@ char tmpname[32];
if (!in) {
haveDir= False;
if (strlen(XkbBaseDirectory)*2+strlen(componentDirs[what])
- +(xkbDebugFlags>9?2:1)+strlen(file)+31 > PATH_MAX)
+ +W32_tmplen
+ +(xkbDebugFlags>9?2:1)+strlen(file)+35 > PATH_MAX)
return BadImplementation;
-#ifndef WIN32
- sprintf(buf,"%s/xkbcomp -R%s/%s -w %ld -l -vlfhpR '%s'",
- XkbBaseDirectory,XkbBaseDirectory,componentDirs[what],(long)
- ((xkbDebugFlags<2)?1:((xkbDebugFlags>10)?10:xkbDebugFlags)),
- file);
-#else
- sprintf(buf,"%s/xkbcomp -R%s/%s -w %ld -l -vlfhpR '%s' %s",
- XkbBaseDirectory,XkbBaseDirectory,componentDirs[what],(long)
+ sprintf(buf,
+ "'%s/xkbcomp' '-R%s/%s' -w %ld -l -vlfhpR '%s'" W32_tmparg,
+ XkbBaseDirectory,XkbBaseDirectory,componentDirs[what],(long)
((xkbDebugFlags<2)?1:((xkbDebugFlags>10)?10:xkbDebugFlags)),
- file, tmpname);
-#endif
+ file W32_tmpfile
+ );
}
}
else {
@@ -178,37 +191,32 @@ char tmpname[32];
}
if (!in) {
haveDir= False;
- if (strlen(componentDirs[what])
+ if (strlen(componentDirs[what]) + W32_tmplen
+(xkbDebugFlags>9?2:1)+strlen(file)+29 > PATH_MAX)
return BadImplementation;
-#ifndef WIN32
- sprintf(buf,"xkbcomp -R%s -w %ld -l -vlfhpR '%s'",
- componentDirs[what],(long)
- ((xkbDebugFlags<2)?1:((xkbDebugFlags>10)?10:xkbDebugFlags)),
- file);
-#else
- sprintf(buf,"xkbcomp -R%s -w %ld -l -vlfhpR '%s' %s",
- componentDirs[what],(long)
+ sprintf(buf,
+ "xkbcomp -R%s -w %ld -l -vlfhpR '%s'" W32_tmparg,
+ componentDirs[what],(long)
((xkbDebugFlags<2)?1:((xkbDebugFlags>10)?10:xkbDebugFlags)),
- file, tmpname);
-#endif
+ file W32_tmpfile
+ );
}
}
status= Success;
if (!haveDir)
+ {
#ifndef WIN32
in= Popen(buf,"r");
#else
- {
#ifdef DEBUG_CMD
- ErrorF("xkb executes: %s\n",cmd);
+ ErrorF("xkb executes: %s\n",buf);
#endif
if (System(buf) < 0)
ErrorF("Could not invoke keymap compiler\n");
else
in= fopen(tmpname, "r");
- }
#endif
+ }
if (!in)
return BadImplementation;
list->nFound[what]= 0;
@@ -262,6 +270,7 @@ char tmpname[32];
}
#else
fclose(in);
+ unlink(tmpname);
#endif
return status;
}