Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(202)

Side by Side Diff: mojo/public/tools/bindings/generators/mojom_js_generator.py

Issue 1517043004: [mojo] Add typemap and variant support to generators (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@pickle3
Patch Set: Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 # Copyright 2013 The Chromium Authors. All rights reserved. 1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Generates JavaScript source files from a mojom.Module.""" 5 """Generates JavaScript source files from a mojom.Module."""
6 6
7 import mojom.generate.generator as generator 7 import mojom.generate.generator as generator
8 import mojom.generate.module as mojom 8 import mojom.generate.module as mojom
9 import mojom.generate.pack as pack 9 import mojom.generate.pack as pack
10 from mojom.generate.template_expander import UseJinja 10 from mojom.generate.template_expander import UseJinja
(...skipping 367 matching lines...) Expand 10 before | Expand all | Expand 10 after
378 "unions": self.GetUnions(), 378 "unions": self.GetUnions(),
379 "interfaces": self.GetInterfaces(), 379 "interfaces": self.GetInterfaces(),
380 "imported_interfaces": self.GetImportedInterfaces(), 380 "imported_interfaces": self.GetImportedInterfaces(),
381 } 381 }
382 382
383 @UseJinja("js_templates/module.amd.tmpl", filters=js_filters) 383 @UseJinja("js_templates/module.amd.tmpl", filters=js_filters)
384 def GenerateAMDModule(self): 384 def GenerateAMDModule(self):
385 return self.GetParameters() 385 return self.GetParameters()
386 386
387 def GenerateFiles(self, args): 387 def GenerateFiles(self, args):
388 if self.variant:
yzshen1 2015/12/15 00:09:10 Please see my comment in mojom_java_generator.py
389 return
390
388 self.Write(self.GenerateAMDModule(), 391 self.Write(self.GenerateAMDModule(),
389 self.MatchMojomFilePath("%s.js" % self.module.name)) 392 self.MatchMojomFilePath("%s.js" % self.module.name))
390 393
391 def GetImports(self): 394 def GetImports(self):
392 used_names = set() 395 used_names = set()
393 for each_import in self.module.imports: 396 for each_import in self.module.imports:
394 simple_name = each_import["module_name"].split(".")[0] 397 simple_name = each_import["module_name"].split(".")[0]
395 398
396 # Since each import is assigned a variable in JS, they need to have unique 399 # Since each import is assigned a variable in JS, they need to have unique
397 # names. 400 # names.
(...skipping 13 matching lines...) Expand all
411 self.GetStructs() + self.GetStructsFromMethods()) 414 self.GetStructs() + self.GetStructsFromMethods())
412 415
413 def GetImportedInterfaces(self): 416 def GetImportedInterfaces(self):
414 interface_to_import = {}; 417 interface_to_import = {};
415 for each_import in self.module.imports: 418 for each_import in self.module.imports:
416 for each_interface in each_import["module"].interfaces: 419 for each_interface in each_import["module"].interfaces:
417 name = each_interface.name 420 name = each_interface.name
418 interface_to_import[name] = each_import["unique_name"] + "." + name 421 interface_to_import[name] = each_import["unique_name"] + "." + name
419 return interface_to_import; 422 return interface_to_import;
420 423
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698