mirror of
				https://github.com/cclassic/model-ghdl
				synced 2025-11-04 02:49:33 +01:00 
			
		
		
		
	Changed default compilation method to compile-on-vcom. See README.MD on how to revert to syntax-check-only behavior.
This commit is contained in:
		@@ -24,6 +24,7 @@ VCOM
 | 
			
		||||
 | 
			
		||||
### Additional commands
 | 
			
		||||
* -ghdl *param*: Supply these arguments directly to GHDL (can be used multiple times)
 | 
			
		||||
* -no-precompile: Compile the files not until calling vsim. (Faster syntax check, but longer wait time for the simulation to start.)
 | 
			
		||||
 | 
			
		||||
### Notes
 | 
			
		||||
* *cwd* is expected to be the compile directory
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										18
									
								
								main.c
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								main.c
									
									
									
									
									
								
							@@ -247,7 +247,7 @@ int vsim(int argc, char **argv)
 | 
			
		||||
    char *simExt = NULL;
 | 
			
		||||
    char *outFileType = NULL;
 | 
			
		||||
    char vhdlver[16] = "";
 | 
			
		||||
 | 
			
		||||
    int precompiled = 1;
 | 
			
		||||
    FILE *fp;
 | 
			
		||||
 | 
			
		||||
    append_string(¶ms,"");
 | 
			
		||||
@@ -271,6 +271,9 @@ int vsim(int argc, char **argv)
 | 
			
		||||
 | 
			
		||||
    fp = fopen("/tmp/model-ghdl-vcom","r");
 | 
			
		||||
    if (fp) {
 | 
			
		||||
        fgets(workdir, sizeof(workdir), fp); // (ab)use workdir variable as temp
 | 
			
		||||
        if (!strcmp(workdir,"nopre\n"))
 | 
			
		||||
            precompiled = 0;
 | 
			
		||||
        fgets(workdir, sizeof(workdir), fp);
 | 
			
		||||
        workdir[strlen(workdir)-1] = 0;
 | 
			
		||||
        fgets(vhdlver, sizeof(vhdlver), fp);
 | 
			
		||||
@@ -344,7 +347,7 @@ int vsim(int argc, char **argv)
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    printf("[I] Compiling...\n");
 | 
			
		||||
    if (run_ghdl("ghdl -m %s --work=%s --workdir=\"%s\" %s %s", vhdlver, work, workdir, params, toplevel)) {
 | 
			
		||||
    if (run_ghdl("ghdl -%c %s --work=%s --workdir=\"%s\" %s %s", (precompiled ? 'e' : 'm'), vhdlver, work, workdir, params, toplevel)) {
 | 
			
		||||
        fprintf(stderr, "[E] Compilation failed!");
 | 
			
		||||
        showMessage(MESSAGE_ERROR, "Error! Compilation failed.", NULL, NULL);
 | 
			
		||||
    }
 | 
			
		||||
@@ -390,6 +393,7 @@ int vcom(int argc, char **argv)
 | 
			
		||||
    char *files = NULL;
 | 
			
		||||
    char vhdlver[16] = "";
 | 
			
		||||
    FILE *fp = NULL;
 | 
			
		||||
    int precompile = 1;
 | 
			
		||||
 | 
			
		||||
    printf ("[I] Emulating vcom.\n");
 | 
			
		||||
 | 
			
		||||
@@ -423,6 +427,9 @@ int vcom(int argc, char **argv)
 | 
			
		||||
        else if (ISOPT("-2008")) {
 | 
			
		||||
            strcpy(vhdlver, "--std=08");
 | 
			
		||||
        }
 | 
			
		||||
        else if (ISOPT("-no-precompile")) {
 | 
			
		||||
            precompile = 0;
 | 
			
		||||
        }
 | 
			
		||||
        else if (GETOPT("-ghdl")) {
 | 
			
		||||
            append_string(¶ms, " ");
 | 
			
		||||
            append_string(¶ms, argv[i]);
 | 
			
		||||
@@ -448,7 +455,7 @@ int vcom(int argc, char **argv)
 | 
			
		||||
    // Info for vsim later on
 | 
			
		||||
    fp = fopen("/tmp/model-ghdl-vcom","w");
 | 
			
		||||
    if (fp) {
 | 
			
		||||
        fprintf(fp, "%s\n%s", workdir, vhdlver);
 | 
			
		||||
        fprintf(fp, "%s\n%s\n%s", (precompile ? "pre" : "nopre"), workdir, vhdlver);
 | 
			
		||||
        fclose(fp);
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
@@ -457,9 +464,8 @@ int vcom(int argc, char **argv)
 | 
			
		||||
 | 
			
		||||
    run_ghdl("ghdl -i --work=%s --workdir=%s %s %s %s 2>&1",
 | 
			
		||||
             work, workdir, vhdlver, params, files);
 | 
			
		||||
    run_ghdl("ghdl -s --work=%s --workdir=%s %s %s %s 2>&1",
 | 
			
		||||
             work, workdir, vhdlver, params, files);
 | 
			
		||||
 | 
			
		||||
    run_ghdl("ghdl -%c --work=%s --workdir=%s %s %s %s 2>&1",
 | 
			
		||||
             (precompile ? 'a' : 's'), work, workdir, vhdlver, params, files);
 | 
			
		||||
 | 
			
		||||
    free(files);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user