diff --git a/node.cc b/node.cc index b76a4629064..583f8b2d7bc 100644 --- a/node.cc +++ b/node.cc @@ -20,23 +20,35 @@ static int exit_code = 0; static Handle ReadFile (const string& name) { + FILE* file = fopen(name.c_str(), "rb"); if (file == NULL) return Handle(); - + fseek(file, 0, SEEK_END); int size = ftell(file); rewind(file); - char* chars = new char[size + 1]; + char chars[size+1]; chars[size] = '\0'; for (int i = 0; i < size;) { int read = fread(&chars[i], 1, size - i, file); + if(read <= 0) { + perror("read()"); + } i += read; } + + uint16_t expanded_base[size+1]; + expanded_base[size] = '\0'; + for(int i = 0; i < size; i++) + expanded_base[i] = chars[i]; + fclose(file); - Handle result = String::New(chars, size); - delete[] chars; - return result; + + HandleScope scope; + Local result = String::New(expanded_base, size); + + return scope.Close(result); } static Handle @@ -61,7 +73,6 @@ BlockingFileRead (const Arguments& args) HandleScope scope; String::Utf8Value filename(args[0]); - Handle output = ReadFile (*filename); return scope.Close(output); } diff --git a/node_http.cc b/node_http.cc index df5a85827f9..fcc032b902e 100644 --- a/node_http.cc +++ b/node_http.cc @@ -160,7 +160,14 @@ HttpRequest::Respond (Handle data) } else { Handle s = data->ToString(); oi_buf *buf = oi_buf_new2(s->Length()); - s->WriteAscii(buf->base, 0, s->Length()); + + uint16_t expanded[s->Length()]; + s->Write(expanded, 0, s->Length()); + + for(int i = 0; i < s->Length(); i++) { + buf->base[i] = expanded[i]; + } + output.push_back(buf); } connection.Write(); @@ -349,7 +356,14 @@ HttpRequest::MakeBodyCallback (const char *base, size_t length) if(length) { // TODO ByteArray? - Handle chunk = String::New(base, length); + // + + uint16_t expanded_base[length]; + for(int i = 0; i < length; i++) { + expanded_base[i] = base[i]; + } + + Handle chunk = String::New(expanded_base, length); argv[0] = chunk; } else { argv[0] = Null();