DO NOT REPLY TO THIS MESSAGE. INSTEAD, POST ANY RESPONSES TO THE LINK BELOW.
[STR New]
Link: http://www.fltk.org/str.php?L2790
Version: 1.3-feature
Attached file "fluid-class-type-constructor-without-parameters_v3.patch"...
Link: http://www.fltk.org/str.php?L2790
Version: 1.3-feature
Index: Fl_Window_Type.cxx
===================================================================
--- Fl_Window_Type.cxx (revision 9204)
+++ Fl_Window_Type.cxx (working copy)
@@ -1499,12 +1499,15 @@
if (!c) c = "Fl_Group";
write_h("\nclass %s : public %s {\n", name(), c);
- if (strstr(c, "Window")) {
- write_h(" void _%s();\n", trimclassname(name()));
- write_h("public:\n");
+ write_h(" void _%s();\n", trimclassname(name()));
+ write_h("public:\n");
+ write_h(" typedef %s THISCLASS;\n", name());
+ write_h(" %s();\n", trimclassname(name()));
+ int isWindow = strstr(c, "Window") != NULL;
+ if (isWindow) {
+
write_h(" %s(int X, int Y, int W, int H, const char *L = 0);\n",
trimclassname(name()));
write_h(" %s(int W, int H, const char *L = 0);\n", trimclassname(name()));
- write_h(" %s();\n", trimclassname(name()));
// a constructor with all four dimensions plus label
write_c("%s::%s(int X, int Y, int W, int H, const char *L)\n", name(),
trimclassname(name()));
@@ -1515,10 +1518,24 @@
// a constructor with just the size and label. The window manager will
position the window
write_c("%s::%s(int W, int H, const char *L)\n", name(),
trimclassname(name()));
write_c(" : %s(0, 0, W, H, L) {\n", c);
- write_c(" clear_flag(16);\n");
+ write_c(" clear_flag(GROUP_RELATIVE);\n");
write_c(" _%s();\n", trimclassname(name()));
write_c("}\n\n");
+// write_c(" %s *w = this;\n", name());
+ } else {
+ write_h(" %s(int X, int Y, int W, int H, const char *L = 0);\n",
trimclassname(name()));
+
+ write_c("%s::%s(int X, int Y, int W, int H, const char *L)\n", name(),
trimclassname(name()));
+ if (wc_relative)
+ write_c(" : %s(0, 0, W, H, L) {\n", c);
+ else
+ write_c(" : %s(X, Y, W, H, L) {\n", c);
+ write_c(" _%s();\n", trimclassname(name()));
+ if (wc_relative) write_c(" position(X, Y);\n");
+ write_c("}\n\n");
+ }
+
// a constructor that takes size and label from the Fluid database
write_c("%s::%s()\n", name(), trimclassname(name()));
write_c(" : %s(0, 0, %d, %d, ", c, o->w(), o->h());
@@ -1526,23 +1543,11 @@
if (cstr) write_cstring(cstr);
else write_c("0");
write_c(") {\n");
- write_c(" clear_flag(16);\n");
+ if (isWindow) write_c(" clear_flag(GROUP_RELATIVE);\n");
write_c(" _%s();\n", trimclassname(name()));
write_c("}\n\n");
write_c("void %s::_%s() {\n", name(), trimclassname(name()));
-// write_c(" %s *w = this;\n", name());
- } else {
- write_h("public:\n");
- write_h(" %s(int X, int Y, int W, int H, const char *L = 0);\n",
trimclassname(name()));
-
- write_c("%s::%s(int X, int Y, int W, int H, const char *L)\n", name(),
trimclassname(name()));
- if (wc_relative)
- write_c(" : %s(0, 0, W, H, L) {\n", c);
- else
- write_c(" : %s(X, Y, W, H, L) {\n", c);
- }
-
// write_c(" %s *o = this;\n", name());
write_widget_code();
@@ -1550,7 +1555,6 @@
void Fl_Widget_Class_Type::write_code2() {
write_extra_code();
- if (wc_relative) write_c("%sposition(X, Y);\n", indent());
if (modal) write_c("%sset_modal();\n", indent());
else if (non_modal) write_c("%sset_non_modal();\n", indent());
if (!((Fl_Window*)o)->border()) write_c("%sclear_border();\n", indent());
_______________________________________________
fltk-dev mailing list
fltk-dev@easysw.com
http://lists.easysw.com/mailman/listinfo/fltk-dev