Mercurial > projects > ldc
view dmd2/man.c @ 978:6a32d2e18175
Fix a latent bug in the asm code.
I think that technically, using "*m0" instead of "*0" allows LLVM to pick
between using the same memory as output 0 and using a new memory location.
(So far I haven't been able to construct a testcase that actually breaks
because of this, though)
author | Frits van Bommel <fvbommel wxs.nl> |
---|---|
date | Wed, 18 Feb 2009 03:38:12 +0100 |
parents | f04dde6e882c |
children |
line wrap: on
line source
// Compiler implementation of the D programming language // Copyright (c) 2008-2008 by Digital Mars // All Rights Reserved // written by Walter Bright // http://www.digitalmars.com // License for redistribution is by either the Artistic License // in artistic.txt, or the GNU General Public License in gnu.txt. // See the included readme.txt for details. #include <stdio.h> #include <string.h> #include <stdlib.h> #include <assert.h> #if _WIN32 #include <windows.h> #pragma comment(lib,"shell32.lib") void browse(const char *url) { ShellExecute(NULL, "open", url, NULL, NULL, SW_SHOWNORMAL); } #endif #if linux || __APPLE__ #include <sys/types.h> #include <sys/wait.h> #include <unistd.h> void browse(const char *url) { pid_t childpid; const char *args[3]; const char *browser = getenv("BROWSER"); if (browser) browser = strdup(browser); else browser = "firefox"; args[0] = browser; args[1] = url; args[2] = NULL; childpid = fork(); if (childpid == 0) { execvp(args[0], (char**)args); perror(args[0]); // failed to execute return; } } #endif