THRIFT-1214 JavaScript constructor does not accept object properties
authorRoger Meier <roger@apache.org>
Tue, 21 Jun 2011 14:09:13 +0000 (14:09 +0000)
committerRoger Meier <roger@apache.org>
Tue, 21 Jun 2011 14:09:13 +0000 (14:09 +0000)
Patch: Henrique Mendonca

git-svn-id: https://svn.apache.org/repos/asf/thrift/trunk@1138013 13f79535-47bb-0310-9956-ffa450edef68

compiler/cpp/src/generate/t_js_generator.cc
lib/js/thrift.js

index 8daaedf..7561b12 100644 (file)
@@ -560,7 +560,7 @@ void t_js_generator::generate_js_struct_definition(ofstream& out,
     out << indent() <<  "if (args) {" << endl;
 
     for (m_iter = members.begin(); m_iter != members.end(); ++m_iter) {
-        out << indent() << indent() << "if (!args." << (*m_iter)->get_name() << ") {" << endl
+        out << indent() << indent() << "if (args." << (*m_iter)->get_name() << " !== undefined) {" << endl
             << indent() << indent() << indent() << "this." << (*m_iter)->get_name() << " = args." << (*m_iter)->get_name()  << ";" << endl
             << indent() << indent() << "}" << endl;
     }
index f4e7235..8b1733e 100644 (file)
@@ -460,7 +460,7 @@ Thrift.Protocol.prototype = {
                 map = ',' + map;
             }
 
-            if ( ! isNaN(k)) { k = '"' + k + '"'; } //json "keys" need to be strings
+            if (! isNaN(k)) { k = '"' + k + '"'; } //json "keys" need to be strings
             map = k + ':' + v + map;
         }
         map = '{' + map;