/[jscoverage]/trunk/instrument.c
ViewVC logotype

Diff of /trunk/instrument.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 87 by siliconforks, Mon May 5 20:05:27 2008 UTC revision 179 by siliconforks, Sun Sep 21 18:35:21 2008 UTC
# Line 17  Line 17 
17      51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.      51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18  */  */
19    
20    #include <config.h>
21    
22  #include "instrument.h"  #include "instrument.h"
23    
24  #include <assert.h>  #include <assert.h>
# Line 27  Line 29 
29  #include <sys/stat.h>  #include <sys/stat.h>
30  #include <sys/types.h>  #include <sys/types.h>
31    
32    #include "encoding.h"
33    #include "global.h"
34  #include "instrument-js.h"  #include "instrument-js.h"
35  #include "resource-manager.h"  #include "resource-manager.h"
36  #include "util.h"  #include "util.h"
# Line 50  Line 54 
54      return FILE_TYPE_HTML;      return FILE_TYPE_HTML;
55    }    }
56    else {    else {
57      return FILE_TYPE_UNKNOWN;      return FILE_TYPE_OTHER;
58    }    }
59  }  }
60    
 static void highlight_file(const char * source_file, const char * destination_file, const char * relative_path) {  
   int depth = 0;  
   for (const char * p = relative_path; *p != '\0'; p++) {  
     if (*p == '/' || *p == '\\') {  
       depth++;  
     }  
   }  
   
   enum FileType file_type = get_file_type(relative_path);  
   const char * suffix = ".jscoverage.html";  
   char * highlighted_file = xmalloc(strlen(destination_file) + strlen(suffix) + 1);  
   strcpy(highlighted_file, destination_file);  
   strcat(highlighted_file, suffix);  
   
   FILE * input = xfopen(source_file, "r");  
   FILE * output = xfopen(highlighted_file, "w");  
   
   free(highlighted_file);  
   
   char * relative_path_to_ancestor = xmalloc(depth * 3 + 1);  
   for (int i = 0; i < depth; i++) {  
     strcpy(relative_path_to_ancestor + i * 3, "../");  
   }  
   relative_path_to_ancestor[depth * 3] = '\0';  
   
   fprintf(output, "<html><head><title>%s</title>\n", relative_path);  
   fprintf(output, "<link rel=\"stylesheet\" type='text/css' href='%sjscoverage.css'>\n", relative_path_to_ancestor);  
   fprintf(output, "<link rel=\"stylesheet\" type='text/css' href='%sjscoverage-sh_nedit.css'>\n", relative_path_to_ancestor);  
   fprintf(output, "<script src=\"%sjscoverage.js\"></script>\n", relative_path_to_ancestor);  
   fprintf(output, "<script src=\"%sjscoverage-sh_main.js\"></script>\n", relative_path_to_ancestor);  
   fprintf(output, "<script src=\"%sjscoverage-sh_javascript.js\"></script>\n", relative_path_to_ancestor);  
   fprintf(output, "<script>\n");  
   fprintf(output, "var gCurrentFile = \"%s\";\n", relative_path);  
   fprintf(output, "</script>\n");  
   fprintf(output, "</head><body onload=\"source_load();\">\n");  
   fprintf(output, "<h1>%s</h1>\n", relative_path);  
   fprintf(output, "<pre id=\"sourceDiv\" class='sh_%s'>", file_type == FILE_TYPE_JS? "javascript": "html");  
   free(relative_path_to_ancestor);  
   
   int c;  
   int atLineStart = 1;  
   int line = 1;  
   while ((c = fgetc(input)) != EOF) {  
     if (atLineStart) {  
       atLineStart = 0;  
     }  
   
     if (c == '<') {  
       fprintf(output, "&lt;");  
     }  
     else if (c == '>') {  
       fprintf(output, "&gt;");  
     }  
     else if (c == '&') {  
       fprintf(output, "&amp;");  
     }  
     else {  
       if (c == '\n') {  
         line++;  
         atLineStart = 1;  
       }  
       fputc(c, output);  
     }  
   }  
   fprintf(output, "</pre></body></html>\n");  
   
   fclose(output);  
   fclose(input);  
   
   suffix = ".jscoverage.js";  
   char original_file[strlen(destination_file) + strlen(suffix) + 1];  
   strcpy(original_file, destination_file);  
   strcat(original_file, suffix);  
   copy_file(source_file, original_file);  
 }  
   
61  static void check_same_file(const char * file1, const char * file2) {  static void check_same_file(const char * file1, const char * file2) {
62    if (is_same_file(file1, file2)) {    if (is_same_file(file1, file2)) {
63      fatal("source and destination are the same");      fatal("source and destination are the same");
# Line 157  Line 85 
85    if (instrumenting) {    if (instrumenting) {
86      enum FileType file_type = get_file_type(source_file);      enum FileType file_type = get_file_type(source_file);
87      switch (file_type) {      switch (file_type) {
88      case FILE_TYPE_UNKNOWN:      case FILE_TYPE_OTHER:
89      case FILE_TYPE_HTML:      case FILE_TYPE_HTML:
90        copy_file(source_file, destination_file);        copy_file(source_file, destination_file);
91        break;        break;
# Line 165  Line 93 
93        {        {
94          FILE * input = xfopen(source_file, "r");          FILE * input = xfopen(source_file, "r");
95          FILE * output = xfopen(destination_file, "w");          FILE * output = xfopen(destination_file, "w");
96          const char * suffix = ".jscoverage.js";  
97          char temporary_file_name[strlen(destination_file) + strlen(suffix) + 1];          Stream * input_stream = Stream_new(0);
98          strcpy(temporary_file_name, destination_file);          Stream * output_stream = Stream_new(0);
99          strcat(temporary_file_name, suffix);  
100          jscoverage_instrument_js(id, input, output, temporary_file_name);          Stream_write_file_contents(input_stream, input);
101    
102            size_t num_characters = input_stream->length;
103            uint16_t * characters = NULL;
104            int result = jscoverage_bytes_to_characters(jscoverage_encoding, input_stream->data, input_stream->length, &characters, &num_characters);
105            if (result == JSCOVERAGE_ERROR_ENCODING_NOT_SUPPORTED) {
106              fatal("encoding %s not supported", jscoverage_encoding);
107            }
108            else if (result == JSCOVERAGE_ERROR_INVALID_BYTE_SEQUENCE) {
109              fatal("error decoding %s in file %s", jscoverage_encoding, id);
110            }
111            jscoverage_instrument_js(id, characters, num_characters, output_stream);
112            free(characters);
113    
114            if (fwrite(output_stream->data, 1, output_stream->length, output) != output_stream->length) {
115              fatal("cannot write to file: %s", destination_file);
116            }
117    
118            Stream_delete(input_stream);
119            Stream_delete(output_stream);
120    
121          fclose(input);          fclose(input);
122          fclose(output);          fclose(output);
123        }        }
       highlight_file(source_file, destination_file, id);  
124        break;        break;
125      }      }
126    }    }
# Line 271  Line 218 
218    }    }
219    free_dir_list(list);    free_dir_list(list);
220  }  }
   
 void jscoverage_copy_resources(const char * destination_directory) {  
   copy_resource("jscoverage.html", destination_directory);  
   copy_resource("jscoverage.css", destination_directory);  
   copy_resource("jscoverage.js", destination_directory);  
   copy_resource("jscoverage-throbber.gif", destination_directory);  
   copy_resource("jscoverage-sh_main.js", destination_directory);  
   copy_resource("jscoverage-sh_javascript.js", destination_directory);  
   copy_resource("jscoverage-sh_nedit.css", destination_directory);  
 }  

Legend:
Removed from v.87  
changed lines
  Added in v.179

  ViewVC Help
Powered by ViewVC 1.1.24