diff options
author | Jérémy Zurcher <jeremy@asynk.ch> | 2011-04-28 15:10:26 +0200 |
---|---|---|
committer | Jérémy Zurcher <jeremy@asynk.ch> | 2011-04-28 15:10:26 +0200 |
commit | ef95395fd1467b2f84ad664356d5b6d8dd13b71a (patch) | |
tree | 59073f94f95f0b50b4c8fa80aca1802e40e2472c /tools/genruby.rb | |
parent | 19324a30a17c6ea0b3d77d34160841ef90ce3ed1 (diff) | |
download | ffi-efl-ef95395fd1467b2f84ad664356d5b6d8dd13b71a.zip ffi-efl-ef95395fd1467b2f84ad664356d5b6d8dd13b71a.tar.gz |
clean tools/genruby
Diffstat (limited to 'tools/genruby.rb')
-rwxr-xr-x | tools/genruby.rb | 45 |
1 files changed, 24 insertions, 21 deletions
diff --git a/tools/genruby.rb b/tools/genruby.rb index c41076a..eb1c91d 100755 --- a/tools/genruby.rb +++ b/tools/genruby.rb @@ -6,21 +6,23 @@ lib_path = File.join path, '..', 'lib', 'efl', 'ffi' # # header, module name, fct prefix, lib libraries = [ - [ 'eina_types.h', 'Eina', 'eina', 'eina'], - [ 'eina_main.h', 'Eina', 'eina', 'eina'], - [ 'eina_list.h', 'EinaList', 'eina_list', 'eina'], - [ 'Eet.h', 'Eet', 'eet', 'eet'], - [ 'Evas.h', 'Evas', 'evas', 'evas'], -# [ 'Evas_GL.h', 'EvasGl', 'evas_gl', 'evas'], - [ 'Edje.h', 'Edje', 'edje', 'edje'], - [ 'Ecore.h', 'Ecore', 'ecore', 'ecore'], -# [ 'Ecore_Con.h', 'EcoreCon', 'ecore_con', 'ecore'], - [ 'Ecore_Input.h', 'EcoreInput', 'ecore', 'ecore'], - [ 'Ecore_Getopt.h', 'EcoreGetopt', 'ecore_getopt', 'ecore'], - [ 'Ecore_Evas.h', 'Ecore_evas', 'ecore', 'ecore'], -# [ 'Ecore_Fb.h', 'Ecore_fb', 'ecore', 'ecore'], -# [ 'Ecore_File.h', 'Ecore_file', 'ecore', 'ecore'], - [ 'Elementary.h', 'Elm', 'elm', 'libelementary-ver-pre-svn-09.so.0' ], + # HEADER MODUE NAME FCT PREFIX LIB OUTPUT + [ 'eina_types.h', 'Eina', 'eina', 'eina', 'eina/eina_types.rb' ], + [ 'eina_main.h', 'Eina', 'eina', 'eina', 'eina.rb' ], + [ 'eina_list.h', 'EinaList', 'eina_list', 'eina', 'eina/eina_list.rb' ], +# [ 'eina_hash.h', 'EinaHash', 'eina_hash', 'eina', 'eina/eina_hash.rb' ], + [ 'Eet.h', 'Eet', 'eet', 'eet', 'eet.rb' ], + [ 'Evas.h', 'Evas', 'evas', 'evas', 'evas.rb' ], +# [ 'Evas_GL.h', 'EvasGl', 'evas_gl', 'evas', 'evas/evas_gl.rb' ], + [ 'Edje.h', 'Edje', 'edje', 'edje', 'edje.rb' ], + [ 'Ecore.h', 'Ecore', 'ecore', 'ecore', 'ecore.rb' ], +# [ 'Ecore_Con.h', 'EcoreCon', 'ecore_con', 'ecore', 'ecore/ecore_con.rb' ], + [ 'Ecore_Input.h', 'EcoreInput', 'ecore', 'ecore', 'ecore/ecore_input.rb' ], + [ 'Ecore_Getopt.h', 'EcoreGetopt', 'ecore_getopt', 'ecore', 'ecore/ecore_getopt.rb' ], + [ 'Ecore_Evas.h', 'EcoreEvas', 'ecore', 'ecore', 'ecore/ecore_evas.rb' ], +# [ 'Ecore_Fb.h', 'EcoreFb', 'ecore', 'ecore', 'ecore/ecore_fb.rb' ], +# [ 'Ecore_File.h', 'EcoreFile', 'ecore', 'ecore', 'ecore/ecore_file.rb' ], + [ 'Elementary.h', 'Elm', 'elm', 'libelementary-ver-pre-svn-09.so.0', 'elementary.rb' ], ] # INDENT=' '*8 @@ -35,7 +37,7 @@ module Efl # module MNAME def self.method_missing m, *args, &block - return Efl::FFI.send 'MBASE_'+m.to_s, *args, &block + return Efl::FFI.send 'PREFIX_'+m.to_s, *args, &block end end # @@ -239,20 +241,21 @@ end # Dir.mkdir lib_path unless Dir.exists? lib_path # -libraries.collect do |header,module_name,module_base,lib| +libraries.collect do |header,module_name,fct_prefix,lib, output| base = File.join path, 'api', header - output = File.join lib_path, "#{header[0..-3].downcase}.rb" + output = File.join lib_path, output + Dir.mkdir File.dirname output unless Dir.exists? File.dirname output puts "parse #{base}-*" - r = [lib, output, module_name, module_base ] + r = [lib, output, module_name, fct_prefix ] r << gen_enums(base, INDENT) r << gen_typedefs(base, INDENT) r << gen_callbacks(base, INDENT) r << gen_functions(base, INDENT) r -end.each do |lib, output, module_name, module_base, enums, typedefs, callbacks, functions| +end.each do |lib, output, module_name, fct_prefix, enums, typedefs, callbacks, functions| puts "generate #{output}" open(output,'w:utf-8') do |f| - f << HEADER.sub(/MNAME/,module_name).sub(/MBASE/,module_base) + f << HEADER.sub(/MNAME/,module_name).sub(/PREFIX/,fct_prefix) f << "#{INDENT}#\n#{INDENT}ffi_lib '#{lib}'" f << "\n#{INDENT}#\n#{INDENT}# ENUMS" f << "\n"+enums.collect { |t| ( t.is_a?(Array) ? ( TYPES_USAGE[t[0]] ? t[1] : nil ) : t ) }.compact.join("\n") unless enums.empty? |