loci: move string tables to their own file
diff --git a/c_gen/c_code_gen.py b/c_gen/c_code_gen.py
index 12c96ed..5226e57 100644
--- a/c_gen/c_code_gen.py
+++ b/c_gen/c_code_gen.py
@@ -514,7 +514,6 @@
#include "loci_int.h"
""")
- gen_object_enum_str(out)
gen_init_map(out)
def type_data_c_gen(out, name):
@@ -1042,63 +1041,6 @@
}
""")
-def gen_object_enum_str(out):
- out.write("\nconst char *const of_object_id_str[] = {\n")
- out.write(" \"of_object\",\n")
- for cls in of_g.ordered_messages:
- out.write(" \"%s\",\n" % cls)
- out.write("\n /* Non-message objects */\n")
- for cls in of_g.ordered_non_messages:
- out.write(" \"%s\",\n" % cls)
- out.write("\n /* List objects */\n")
- for cls in of_g.ordered_list_objects:
- out.write(" \"%s\",\n" % cls)
- out.write("\n /* Generic stats request/reply types; pseudo objects */\n")
- for cls in of_g.ordered_pseudo_objects:
- out.write(" \"%s\",\n" % cls)
- out.write("\n \"of_unknown_object\"\n};\n")
-
- # We'll do version strings while we're at it
- out.write("""
- const char *const of_version_str[] = {
- "Unknown OpenFlow Version",
- "OpenFlow-1.0",
- "OpenFlow-1.1",
- "OpenFlow-1.2"
-};
-
-const of_mac_addr_t of_mac_addr_all_ones = {
- {
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
- }
-};
-/* Just to be explicit; static duration vars are init'd to 0 */
-const of_mac_addr_t of_mac_addr_all_zeros = {
- {
- 0, 0, 0, 0, 0, 0
- }
-};
-
-const of_ipv6_t of_ipv6_all_ones = {
- {
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
- }
-};
-/* Just to be explicit; static duration vars are init'd to 0 */
-const of_ipv6_t of_ipv6_all_zeros = {
- {
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0
- }
-};
-
-/** @var of_error_strings
- * The error string map; use abs value to index
- */
-const char *const of_error_strings[] = { OF_ERROR_STRINGS };
-""")
-
################################################################
#
# Internal Utility Functions
diff --git a/c_gen/codegen.py b/c_gen/codegen.py
index a526a95..592a69a 100644
--- a/c_gen/codegen.py
+++ b/c_gen/codegen.py
@@ -106,3 +106,15 @@
# Append legacy generated code
c_code_gen.gen_new_function_definitions(out, cls)
c_code_gen.gen_list_accessors(out, cls)
+
+def generate_strings(install_dir):
+ object_id_strs = []
+ object_id_strs.append("of_object")
+ object_id_strs.extend(of_g.ordered_messages)
+ object_id_strs.extend(of_g.ordered_non_messages)
+ object_id_strs.extend(of_g.ordered_list_objects)
+ object_id_strs.extend(of_g.ordered_pseudo_objects)
+ object_id_strs.append("of_unknown_object")
+
+ with template_utils.open_output(install_dir, "loci/src/loci_strings.c") as out:
+ util.render_template(out, "loci_strings.c", object_id_strs=object_id_strs)
diff --git a/c_gen/templates/loci_strings.c b/c_gen/templates/loci_strings.c
new file mode 100644
index 0000000..f546e12
--- /dev/null
+++ b/c_gen/templates/loci_strings.c
@@ -0,0 +1,75 @@
+:: # Copyright 2013, Big Switch Networks, Inc.
+:: #
+:: # LoxiGen is licensed under the Eclipse Public License, version 1.0 (EPL), with
+:: # the following special exception:
+:: #
+:: # LOXI Exception
+:: #
+:: # As a special exception to the terms of the EPL, you may distribute libraries
+:: # generated by LoxiGen (LoxiGen Libraries) under the terms of your choice, provided
+:: # that copyright and licensing notices generated by LoxiGen are not altered or removed
+:: # from the LoxiGen Libraries and the notice provided below is (i) included in
+:: # the LoxiGen Libraries, if distributed in source code form and (ii) included in any
+:: # documentation for the LoxiGen Libraries, if distributed in binary form.
+:: #
+:: # Notice: "Copyright 2013, Big Switch Networks, Inc. This library was generated by the LoxiGen Compiler."
+:: #
+:: # You may not use this file except in compliance with the EPL or LOXI Exception. You may obtain
+:: # a copy of the EPL at:
+:: #
+:: # http://www.eclipse.org/legal/epl-v10.html
+:: #
+:: # Unless required by applicable law or agreed to in writing, software
+:: # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+:: # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+:: # EPL for the specific language governing permissions and limitations
+:: # under the EPL.
+:: include('_copyright.c')
+#include <loci/loci.h>
+#include <loci/of_object.h>
+#include "loci_log.h"
+#include "loci_int.h"
+
+const char *const of_object_id_str[] = {
+:: for cls in object_id_strs:
+ "${cls}",
+:: #endfor
+};
+
+const char *const of_version_str[] = {
+ "Unknown OpenFlow Version",
+ "OpenFlow-1.0",
+ "OpenFlow-1.1",
+ "OpenFlow-1.2"
+};
+
+const of_mac_addr_t of_mac_addr_all_ones = {
+ {
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
+ }
+};
+/* Just to be explicit; static duration vars are init'd to 0 */
+const of_mac_addr_t of_mac_addr_all_zeros = {
+ {
+ 0, 0, 0, 0, 0, 0
+ }
+};
+
+const of_ipv6_t of_ipv6_all_ones = {
+ {
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
+ }
+};
+/* Just to be explicit; static duration vars are init'd to 0 */
+const of_ipv6_t of_ipv6_all_zeros = {
+ {
+ 0, 0, 0, 0, 0, 0, 0, 0,
+ 0, 0, 0, 0, 0, 0, 0, 0
+ }
+};
+
+/** @var of_error_strings
+ * The error string map; use abs value to index
+ */
+const char *const of_error_strings[] = { OF_ERROR_STRINGS };
diff --git a/lang_c.py b/lang_c.py
index 21e9e1e..40619c0 100644
--- a/lang_c.py
+++ b/lang_c.py
@@ -179,3 +179,4 @@
c_gen.codegen.generate_classes(install_dir)
c_gen.codegen.generate_header_classes(install_dir)
c_gen.codegen.generate_lists(install_dir)
+ c_gen.codegen.generate_strings(install_dir)