From 169ac913e9930f7e4a27f395e6c06901f7c849c3 Mon Sep 17 00:00:00 2001 From: "Richard W.M. Jones" Date: Wed, 5 Sep 2012 11:12:25 +0100 Subject: generator: gobject: Use a more normal way to output files. The generator output is identical, verified by comparing the output files before and after the change. --- generator/gobject.ml | 172 ++++++++++++++++++++++----------------------------- generator/main.ml | 39 +++++++++++- 2 files changed, 111 insertions(+), 100 deletions(-) (limited to 'generator') diff --git a/generator/gobject.ml b/generator/gobject.ml index 4a57ba32..0e96076b 100644 --- a/generator/gobject.ml +++ b/generator/gobject.ml @@ -103,7 +103,7 @@ let generate_gobject_proto name ?(single_line = true) pr ", GError **err"; pr ")" -let output_filenames = +let filenames = "session" :: "tristate" :: (* structs *) @@ -118,75 +118,66 @@ let output_filenames = ) all_functions ) -let output_header filename f = - let header = sprintf "gobject/include/guestfs-gobject/%s.h" filename in +let header_start filename = + generate_header CStyle GPLv2plus; let guard = Str.global_replace (Str.regexp "-") "_" filename in let guard = "GUESTFS_GOBJECT_" ^ String.uppercase guard ^ "_H__" in - output_to header (fun () -> - generate_header CStyle GPLv2plus; - pr "#ifndef %s\n" guard; - pr "#define %s\n" guard; - pr " + pr "#ifndef %s\n" guard; + pr "#define %s\n" guard; + pr " #include #include #include G_BEGIN_DECLS -"; - - f (); +" - pr " +and header_end filename = + let guard = Str.global_replace (Str.regexp "-") "_" filename in + let guard = "GUESTFS_GOBJECT_" ^ String.uppercase guard ^ "_H__" in + pr " G_END_DECLS #endif /* %s */ -" guard; - ) +" guard -let output_source filename ?(title=None) ?(shortdesc=None) ?(longdesc=None) f = - let source = sprintf "gobject/src/%s.c" filename in - output_to source (fun () -> - generate_header CStyle GPLv2plus; - - pr "#include \n\n"; - - pr "#include \"guestfs-gobject.h\"\n\n"; - - pr "/**\n"; - pr " * SECTION:%s\n" filename; +let source_start ?title ?shortdesc ?longdesc filename = + generate_header CStyle GPLv2plus; - (match title with - | Some title -> - pr " * @title: %s\n" title - | _ -> ()); + pr "#include \n\n"; + pr "#include \"guestfs-gobject.h\"\n\n"; + pr "/**\n"; + pr " * SECTION:%s\n" filename; - (match shortdesc with - | Some desc -> - pr " * @short_description: %s\n" desc; - | _ -> ()); + (match title with + | Some title -> + pr " * @title: %s\n" title + | _ -> ()); - pr " * @include: guestfs-gobject.h\n"; + (match shortdesc with + | Some desc -> + pr " * @short_description: %s\n" desc; + | _ -> ()); - (match longdesc with - | Some desc -> - pr " *\n"; - pr " %s\n" desc - | _ -> ()); + pr " * @include: guestfs-gobject.h\n"; - pr " */\n"; + (match longdesc with + | Some desc -> + pr " *\n"; + pr " %s\n" desc + | _ -> ()); - f (); - ) + pr " */\n" let generate_gobject_makefile () = generate_header HashStyle GPLv2plus; let headers = List.map - (function n -> sprintf "include/guestfs-gobject/%s.h" n) output_filenames + (function n -> sprintf "include/guestfs-gobject/%s.h" n) filenames in let sources = - List.map (function n -> sprintf "src/%s.c" n) output_filenames + List.map (function n -> sprintf "src/%s.c" n) filenames in pr "guestfs_gobject_headers= \\\n include/guestfs-gobject.h \\\n %s\n\n" (String.concat " \\\n " headers); @@ -196,7 +187,7 @@ let generate_gobject_header () = generate_header CStyle GPLv2plus; List.iter (function f -> pr "#include \n" f) - output_filenames + filenames let generate_gobject_doc_title () = pr @@ -212,11 +203,13 @@ let generate_gobject_doc_title () = List.iter ( function n -> pr " \n" n - ) output_filenames; + ) filenames; pr "\n" -let generate_gobject_struct_header typ cols () = +let generate_gobject_struct_header filename typ cols () = + header_start filename; + let camel = camel_name_of_struct typ in pr "\n"; @@ -272,9 +265,14 @@ let generate_gobject_struct_header typ cols () = pr " gfloat %s;\n" n ) cols; pr "};\n"; - pr "GType guestfs_%s_get_type(void);\n" typ + pr "GType guestfs_%s_get_type(void);\n" typ; + + header_end filename + +let generate_gobject_struct_source filename typ cols () = + let title = "Guestfs" ^ camel_name_of_struct typ in + source_start ~title filename; -let generate_gobject_struct_source typ cols () = let name = "guestfs_" ^ typ in let camel_name = "Guestfs" ^ camel_name_of_struct typ in @@ -295,17 +293,8 @@ let generate_gobject_struct_source typ cols () = pr "G_DEFINE_BOXED_TYPE(%s, %s, %s_copy, %s_free)\n" camel_name name name name -let generate_gobject_structs = - List.iter ( - fun (typ, cols) -> - let filename = "struct-" ^ typ in - output_header filename (generate_gobject_struct_header typ cols); - output_source ~title:(Some ("Guestfs" ^ camel_name_of_struct typ)) - filename - (generate_gobject_struct_source typ cols) - ) structs - -let generate_gobject_optargs_header name optargs f () = +let generate_gobject_optargs_header filename name optargs f () = + header_start filename; let uc_name = String.uppercase name in let camel_name = camel_of_name f in let type_define = "GUESTFS_TYPE_" ^ uc_name in @@ -357,9 +346,14 @@ let generate_gobject_optargs_header name optargs f () = pr "};\n\n"; pr "GType guestfs_%s_get_type(void);\n" name; - pr "%s *guestfs_%s_new(void);\n" camel_name name + pr "%s *guestfs_%s_new(void);\n" camel_name name; + header_end filename + +let generate_gobject_optargs_source filename name optargs f () = + let desc = + "An object encapsulating optional arguments for guestfs_session_" ^ name in + source_start ~shortdesc:desc ~longdesc:desc filename; -let generate_gobject_optargs_source name optargs f () = let uc_name = String.uppercase name in let camel_name = camel_of_name f in let type_define = "GUESTFS_TYPE_" ^ uc_name in @@ -538,22 +532,9 @@ let generate_gobject_optargs_source name optargs f () = pr " return GUESTFS_%s(g_object_new(%s, NULL));\n" uc_name type_define; pr "}\n" -let generate_gobject_optargs = - List.iter ( - function - | ({ name = name; style = (_, _, (_::_ as optargs)) } as f) -> - let filename = "optargs-" ^ name in - output_header - filename - (generate_gobject_optargs_header name optargs f); - let desc = "An object encapsulating optional arguments for guestfs_session_" ^ name in - output_source ~shortdesc:(Some desc) ~longdesc:(Some desc) - filename - (generate_gobject_optargs_source name optargs f) - | { style = _, _, [] } -> () - ) all_functions - let generate_gobject_tristate_header () = + let filename = "tristate" in + header_start filename; pr " /** * GuestfsTristate: @@ -575,9 +556,14 @@ typedef enum GType guestfs_tristate_get_type(void); #define GUESTFS_TYPE_TRISTATE (guestfs_tristate_get_type()) -" +"; + header_end filename let generate_gobject_tristate_source () = + let filename = "tristate" in + let title = "GuestfsTristate" in + let shortdesc = "An object representing a tristate value" in + source_start ~title ~shortdesc filename; pr " GType guestfs_tristate_get_type(void) @@ -597,6 +583,8 @@ guestfs_tristate_get_type(void) " let generate_gobject_session_header () = + let filename = "session" in + header_start filename; pr " /* GuestfsSessionEvent */ @@ -709,9 +697,15 @@ gboolean guestfs_session_close(GuestfsSession *session, GError **err); fun ({ name = name; style = style } as f) -> generate_gobject_proto name style f; pr ";\n"; - ) all_functions + ) all_functions; + + header_end filename let generate_gobject_session_source () = + let filename = "session" in + let shortdesc = "A libguestfs session" in + source_start ~shortdesc filename; + pr " #include #include @@ -1283,23 +1277,3 @@ guestfs_session_close(GuestfsSession *session, GError **err) pr "}\n"; ) all_functions - -let generate_gobject () = - output_to "gobject/Makefile.inc" generate_gobject_makefile; - output_to "gobject/include/guestfs-gobject.h" generate_gobject_header; - output_to "gobject/docs/guestfs-title.sgml" generate_gobject_doc_title; - - generate_gobject_structs; - generate_gobject_optargs; - - output_header "tristate" generate_gobject_tristate_header; - output_source - ~title:(Some "GuestfsTristate") - ~shortdesc:(Some "An object representing a tristate value") - "tristate" - generate_gobject_tristate_source; - - output_header "session" generate_gobject_session_header; - output_source ~shortdesc:(Some "A libguestfs session") - "session" - generate_gobject_session_source diff --git a/generator/main.ml b/generator/main.ml index 793bdd55..74419f10 100644 --- a/generator/main.ml +++ b/generator/main.ml @@ -22,8 +22,10 @@ open Unix open Printf open Pr +open Actions open Structs open Api_versions +open Types open C open Xdr @@ -139,8 +141,43 @@ Run it from the top source directory using the command output_to "erlang/guestfs.erl" generate_erlang_erl; output_to "erlang/erl-guestfs.c" generate_erlang_c; output_to ~perm:0o555 "erlang/bindtests.erl" generate_erlang_bindtests; + output_to "gobject/bindtests.js" generate_gobject_js_bindtests; - generate_gobject(); + output_to "gobject/Makefile.inc" generate_gobject_makefile; + output_to "gobject/include/guestfs-gobject.h" generate_gobject_header; + output_to "gobject/docs/guestfs-title.sgml" generate_gobject_doc_title; + + List.iter ( + fun (typ, cols) -> + let short = sprintf "struct-%s" typ in + let filename = + sprintf "gobject/include/guestfs-gobject/%s.h" short in + output_to filename (generate_gobject_struct_header short typ cols); + let filename = sprintf "gobject/src/%s.c" short in + output_to filename (generate_gobject_struct_source short typ cols) + ) structs; + + List.iter ( + function + | ({ name = name; style = (_, _, (_::_ as optargs)) } as f) -> + let short = sprintf "optargs-%s" name in + let filename = + sprintf "gobject/include/guestfs-gobject/%s.h" short in + output_to filename + (generate_gobject_optargs_header short name optargs f); + let filename = sprintf "gobject/src/%s.c" short in + output_to filename + (generate_gobject_optargs_source short name optargs f) + | { style = _, _, [] } -> () + ) all_functions; + + output_to "gobject/include/guestfs-gobject/tristate.h" + generate_gobject_tristate_header; + output_to "gobject/src/tristate.c" generate_gobject_tristate_source; + + output_to "gobject/include/guestfs-gobject/session.h" + generate_gobject_session_header; + output_to "gobject/src/session.c" generate_gobject_session_source; (* Generate the list of files generated -- last. *) printf "generated %d lines of code\n" (get_lines_generated ()); -- cgit