diff options
| author | Michael R Sweet <michael.r.sweet@gmail.com> | 2005-03-25 21:12:15 +0000 |
|---|---|---|
| committer | Michael R Sweet <michael.r.sweet@gmail.com> | 2005-03-25 21:12:15 +0000 |
| commit | f6a137b998d663a98390138f1a11c467c3001658 (patch) | |
| tree | d9309966f95897e7fb0462bf84a88fa0f4f87b07 | |
| parent | f5ed012b28231526a56e302a923d24f82a7fad2d (diff) | |
Fixed VC++.NET project files (FLTK, FLTKDLL, FLUID).
Fixed Cygwin FLUID compile problem (STR #772)
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@4192 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
| -rw-r--r-- | fluid/fluid.cxx | 10 | ||||
| -rw-r--r-- | fluid/template_panel.cxx | 520 | ||||
| -rw-r--r-- | fluid/template_panel.fl | 488 | ||||
| -rw-r--r-- | fluid/template_panel.h | 112 | ||||
| -rw-r--r-- | vcnet/fltk.lib.vcproj | 3 | ||||
| -rw-r--r-- | vcnet/fltkdll.vcproj | 3 | ||||
| -rw-r--r-- | vcnet/fluid.vcproj | 35 |
7 files changed, 592 insertions, 579 deletions
diff --git a/fluid/fluid.cxx b/fluid/fluid.cxx index 095711a78..0f41104aa 100644 --- a/fluid/fluid.cxx +++ b/fluid/fluid.cxx @@ -46,7 +46,7 @@ #include "alignment_panel.h" #include "function_panel.h" #include "template_panel.h" -#ifndef WIN32 +#if !defined(WIN32) || defined(__CYGWIN__) # include "print_panel.h" #endif // !WIN32 @@ -251,7 +251,11 @@ void save_template_cb(Fl_Widget *, void *) { fluid_prefs.getUserdataPath(filename, sizeof(filename)); strlcat(filename, "templates", sizeof(filename)); +#if defined(WIN32) && !defined(__CYGWIN__) + if (access(filename, 0)) mkdir(filename); +#else if (access(filename, 0)) mkdir(filename, 0777); +#endif // WIN32 && !__CYGWIN__ strlcat(filename, "/", sizeof(filename)); strlcat(filename, safename, sizeof(filename)); @@ -848,7 +852,7 @@ void manual_cb(Fl_Widget *, void *) { // Load and show the print dialog... void print_menu_cb(Fl_Widget *, void *) { -#ifdef WIN32 +#if defined(WIN32) && !defined(__CYGWIN__) fl_message("Sorry, printing is not yet implemented on Windows..."); } #else @@ -1300,7 +1304,7 @@ void print_cb(Fl_Return_Button *, void *) { print_progress->hide(); print_panel->hide(); } -#endif // WIN32 +#endif // WIN32 && !__CYGWIN__ //////////////////////////////////////////////////////////////// diff --git a/fluid/template_panel.cxx b/fluid/template_panel.cxx index c9a523787..a24e13086 100644 --- a/fluid/template_panel.cxx +++ b/fluid/template_panel.cxx @@ -1,260 +1,260 @@ -// -// "$Id$" -// -// FLUID template support for the Fast Light Tool Kit (FLTK). -// -// Copyright 1998-2005 by Bill Spitzak and others. -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Library General Public -// License as published by the Free Software Foundation; either -// version 2 of the License, or (at your option) any later version. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Library General Public License for more details. -// -// You should have received a copy of the GNU Library General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -// USA. -// -// Please report all bugs and problems on the following page: -// -// http://www.fltk.org/str.php -// - -// generated by Fast Light User Interface Designer (fluid) version 1.0107 - -#include "template_panel.h" -#include <stdio.h> -#include <stdlib.h> -#include "../src/flstring.h" -#include <errno.h> -#include <FL/filename.H> -#include <FL/fl_ask.H> -#include <FL/Fl_Shared_Image.H> -#include <FL/Fl_Preferences.H> -#ifdef WIN32 -#include <io.h> -#else -#include <unistd.h> -#endif // WIN32 -extern Fl_Preferences fluid_prefs; - -Fl_Double_Window *template_panel=(Fl_Double_Window *)0; - -static void cb_template_panel(Fl_Double_Window*, void*) { - Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_browser->deselect(); -template_name->value(""); -template_instance->value(""); -template_panel->hide(); -} - -Fl_Browser *template_browser=(Fl_Browser *)0; - -static void cb_template_browser(Fl_Browser*, void*) { - if (Fl::event_clicks()) { - template_panel->hide(); - return; -} -Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); -template_preview->redraw(); - -int item = template_browser->value(); - -if (item <= 1) template_instance->deactivate(); -else template_instance->activate(); - -if (item < 1) { - template_submit->deactivate(); - template_delete->deactivate(); - return; -} - -template_submit->activate(); - -const char *flfile = (const char *)template_browser->data(item); -if (!flfile) { - template_delete->deactivate(); - return; -} - -template_name->value(template_browser->text(item)); - -template_delete->activate(); - -char pngfile[1024], *ext; - -strlcpy(pngfile, flfile, sizeof(pngfile)); -if ((ext = strrchr(pngfile, '.')) == NULL) return; -strcpy(ext, ".png"); - -img = Fl_Shared_Image::get(pngfile); - -if (img) { - template_preview->image(img); - template_preview->redraw(); -}; -} - -Fl_Box *template_preview=(Fl_Box *)0; - -Fl_Input *template_name=(Fl_Input *)0; - -static void cb_template_name(Fl_Input*, void*) { - if (strlen(template_name->value())) { - template_submit->activate(); - if (Fl::event_key() == FL_Enter) template_panel->hide(); -} else template_submit->deactivate(); -} - -Fl_Input *template_instance=(Fl_Input *)0; - -Fl_Button *template_delete=(Fl_Button *)0; - -static void cb_Cancel(Fl_Button*, void*) { - Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_browser->deselect(); -template_name->value(""); -template_instance->value(""); -template_panel->hide(); -} - -Fl_Return_Button *template_submit=(Fl_Return_Button *)0; - -static void cb_template_submit(Fl_Return_Button*, void*) { - Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_panel->hide(); -} - -Fl_Double_Window* make_template_panel() { - Fl_Double_Window* w; - { Fl_Double_Window* o = template_panel = new Fl_Double_Window(460, 355, "New/Save Template"); - w = o; - o->callback((Fl_Callback*)cb_template_panel); - { Fl_Browser* o = template_browser = new Fl_Browser(10, 28, 180, 250, "Available Templates:"); - o->type(2); - o->labelfont(1); - o->callback((Fl_Callback*)cb_template_browser); - o->align(FL_ALIGN_TOP_LEFT); - o->when(3); - } - { Fl_Box* o = template_preview = new Fl_Box(200, 28, 250, 250); - o->box(FL_THIN_DOWN_BOX); - o->align(69|FL_ALIGN_INSIDE); - Fl_Group::current()->resizable(o); - } - { Fl_Input* o = template_name = new Fl_Input(124, 288, 326, 25, "Template Name:"); - o->labelfont(1); - o->textfont(4); - o->callback((Fl_Callback*)cb_template_name); - o->when(3); - } - { Fl_Input* o = template_instance = new Fl_Input(124, 288, 326, 25, "Instance Name:"); - o->labelfont(1); - o->textfont(4); - o->hide(); - } - { Fl_Group* o = new Fl_Group(10, 323, 440, 25); - { Fl_Button* o = template_delete = new Fl_Button(10, 323, 133, 25, "Delete Template"); - o->callback((Fl_Callback*)template_delete_cb); - } - { Fl_Box* o = new Fl_Box(153, 323, 126, 25); - Fl_Group::current()->resizable(o); - } - { Fl_Button* o = new Fl_Button(289, 323, 72, 25, "Cancel"); - o->callback((Fl_Callback*)cb_Cancel); - } - { Fl_Return_Button* o = template_submit = new Fl_Return_Button(371, 323, 79, 25, "Save"); - o->callback((Fl_Callback*)cb_template_submit); - } - o->end(); - } - o->set_modal(); - o->end(); - } - return w; -} - -void template_clear() { - int i; -void *filename; - -for (i = 1; i <= template_browser->size(); i ++) { - if ((filename = template_browser->data(i)) != NULL) free(filename); -} - -template_browser->deselect(); -template_browser->clear(); -} - -void template_delete_cb(Fl_Button *, void *) { - int item = template_browser->value(); -if (item < 1) return; - -const char *name = template_browser->text(item); -const char *flfile = (const char *)template_browser->data(item); -if (!flfile) return; - -if (!fl_choice("Are you sure you want to delete the template \"%s\"?", - "Cancel", "Delete", 0, name)) return; - -if (unlink(flfile)) { - fl_alert("Unable to delete template \"%s\":\n%s", name, strerror(errno)); - return; -} - -template_browser->remove(item); -template_browser->do_callback(); -} - -void template_load() { - int i; -char name[1024], filename[1024], path[1024], *ptr; -struct dirent **files; -int num_files; - -fluid_prefs.getUserdataPath(path, sizeof(path)); -strlcat(path, "templates", sizeof(path)); - -num_files = fl_filename_list(path, &files); - -for (i = 0; i < num_files; i ++) { - if (fl_filename_match(files[i]->d_name, "*.fl")) { - // Format the name as the filename with "_" replaced with " " - // and without the trailing ".fl"... - strlcpy(name, files[i]->d_name, sizeof(name)); - *strstr(name, ".fl") = '\0'; - - for (ptr = name; *ptr; ptr ++) { - if (*ptr == '_') *ptr = ' '; - } - - // Add the template to the browser... - snprintf(filename, sizeof(filename), "%s/%s", path, files[i]->d_name); - template_browser->add(name, strdup(filename)); - } - - free(files[i]); -} - -if (num_files > 0) free(files); -} - -// -// End of "$Id$". -// +//
+// "$Id$"
+//
+// FLUID template support for the Fast Light Tool Kit (FLTK).
+//
+// Copyright 1998-2005 by Bill Spitzak and others.
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Library General Public
+// License as published by the Free Software Foundation; either
+// version 2 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Library General Public License for more details.
+//
+// You should have received a copy of the GNU Library General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+// USA.
+//
+// Please report all bugs and problems on the following page:
+//
+// http://www.fltk.org/str.php
+//
+
+// generated by Fast Light User Interface Designer (fluid) version 1.0107
+
+#include "template_panel.h"
+#include <stdio.h>
+#include <stdlib.h>
+#include "../src/flstring.h"
+#include <errno.h>
+#include <FL/filename.H>
+#include <FL/fl_ask.H>
+#include <FL/Fl_Shared_Image.H>
+#include <FL/Fl_Preferences.H>
+#if defined(WIN32) && !defined(__CYGWIN__)
+#include <io.h>
+#else
+#include <unistd.h>
+#endif // WIN32 && !__CYGWIN__
+extern Fl_Preferences fluid_prefs;
+
+Fl_Double_Window *template_panel=(Fl_Double_Window *)0;
+
+static void cb_template_panel(Fl_Double_Window*, void*) {
+ Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_browser->deselect();
+template_name->value("");
+template_instance->value("");
+template_panel->hide();
+}
+
+Fl_Browser *template_browser=(Fl_Browser *)0;
+
+static void cb_template_browser(Fl_Browser*, void*) {
+ if (Fl::event_clicks()) {
+ template_panel->hide();
+ return;
+}
+Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+template_preview->redraw();
+
+int item = template_browser->value();
+
+if (item <= 1) template_instance->deactivate();
+else template_instance->activate();
+
+if (item < 1) {
+ template_submit->deactivate();
+ template_delete->deactivate();
+ return;
+}
+
+template_submit->activate();
+
+const char *flfile = (const char *)template_browser->data(item);
+if (!flfile) {
+ template_delete->deactivate();
+ return;
+}
+
+template_name->value(template_browser->text(item));
+
+template_delete->activate();
+
+char pngfile[1024], *ext;
+
+strlcpy(pngfile, flfile, sizeof(pngfile));
+if ((ext = strrchr(pngfile, '.')) == NULL) return;
+strcpy(ext, ".png");
+
+img = Fl_Shared_Image::get(pngfile);
+
+if (img) {
+ template_preview->image(img);
+ template_preview->redraw();
+};
+}
+
+Fl_Box *template_preview=(Fl_Box *)0;
+
+Fl_Input *template_name=(Fl_Input *)0;
+
+static void cb_template_name(Fl_Input*, void*) {
+ if (strlen(template_name->value())) {
+ template_submit->activate();
+ if (Fl::event_key() == FL_Enter) template_panel->hide();
+} else template_submit->deactivate();
+}
+
+Fl_Input *template_instance=(Fl_Input *)0;
+
+Fl_Button *template_delete=(Fl_Button *)0;
+
+static void cb_Cancel(Fl_Button*, void*) {
+ Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_browser->deselect();
+template_name->value("");
+template_instance->value("");
+template_panel->hide();
+}
+
+Fl_Return_Button *template_submit=(Fl_Return_Button *)0;
+
+static void cb_template_submit(Fl_Return_Button*, void*) {
+ Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_panel->hide();
+}
+
+Fl_Double_Window* make_template_panel() {
+ Fl_Double_Window* w;
+ { Fl_Double_Window* o = template_panel = new Fl_Double_Window(460, 355, "New/Save Template");
+ w = o;
+ o->callback((Fl_Callback*)cb_template_panel);
+ { Fl_Browser* o = template_browser = new Fl_Browser(10, 28, 180, 250, "Available Templates:");
+ o->type(2);
+ o->labelfont(1);
+ o->callback((Fl_Callback*)cb_template_browser);
+ o->align(FL_ALIGN_TOP_LEFT);
+ o->when(3);
+ }
+ { Fl_Box* o = template_preview = new Fl_Box(200, 28, 250, 250);
+ o->box(FL_THIN_DOWN_BOX);
+ o->align(69|FL_ALIGN_INSIDE);
+ Fl_Group::current()->resizable(o);
+ }
+ { Fl_Input* o = template_name = new Fl_Input(124, 288, 326, 25, "Template Name:");
+ o->labelfont(1);
+ o->textfont(4);
+ o->callback((Fl_Callback*)cb_template_name);
+ o->when(3);
+ }
+ { Fl_Input* o = template_instance = new Fl_Input(124, 288, 326, 25, "Instance Name:");
+ o->labelfont(1);
+ o->textfont(4);
+ o->hide();
+ }
+ { Fl_Group* o = new Fl_Group(10, 323, 440, 25);
+ { Fl_Button* o = template_delete = new Fl_Button(10, 323, 133, 25, "Delete Template");
+ o->callback((Fl_Callback*)template_delete_cb);
+ }
+ { Fl_Box* o = new Fl_Box(153, 323, 126, 25);
+ Fl_Group::current()->resizable(o);
+ }
+ { Fl_Button* o = new Fl_Button(289, 323, 72, 25, "Cancel");
+ o->callback((Fl_Callback*)cb_Cancel);
+ }
+ { Fl_Return_Button* o = template_submit = new Fl_Return_Button(371, 323, 79, 25, "Save");
+ o->callback((Fl_Callback*)cb_template_submit);
+ }
+ o->end();
+ }
+ o->set_modal();
+ o->end();
+ }
+ return w;
+}
+
+void template_clear() {
+ int i;
+void *filename;
+
+for (i = 1; i <= template_browser->size(); i ++) {
+ if ((filename = template_browser->data(i)) != NULL) free(filename);
+}
+
+template_browser->deselect();
+template_browser->clear();
+}
+
+void template_delete_cb(Fl_Button *, void *) {
+ int item = template_browser->value();
+if (item < 1) return;
+
+const char *name = template_browser->text(item);
+const char *flfile = (const char *)template_browser->data(item);
+if (!flfile) return;
+
+if (!fl_choice("Are you sure you want to delete the template \"%s\"?",
+ "Cancel", "Delete", 0, name)) return;
+
+if (unlink(flfile)) {
+ fl_alert("Unable to delete template \"%s\":\n%s", name, strerror(errno));
+ return;
+}
+
+template_browser->remove(item);
+template_browser->do_callback();
+}
+
+void template_load() {
+ int i;
+char name[1024], filename[1024], path[1024], *ptr;
+struct dirent **files;
+int num_files;
+
+fluid_prefs.getUserdataPath(path, sizeof(path));
+strlcat(path, "templates", sizeof(path));
+
+num_files = fl_filename_list(path, &files);
+
+for (i = 0; i < num_files; i ++) {
+ if (fl_filename_match(files[i]->d_name, "*.fl")) {
+ // Format the name as the filename with "_" replaced with " "
+ // and without the trailing ".fl"...
+ strlcpy(name, files[i]->d_name, sizeof(name));
+ *strstr(name, ".fl") = '\0';
+
+ for (ptr = name; *ptr; ptr ++) {
+ if (*ptr == '_') *ptr = ' ';
+ }
+
+ // Add the template to the browser...
+ snprintf(filename, sizeof(filename), "%s/%s", path, files[i]->d_name);
+ template_browser->add(name, strdup(filename));
+ }
+
+ free(files[i]);
+}
+
+if (num_files > 0) free(files);
+}
+
+//
+// End of "$Id$".
+//
diff --git a/fluid/template_panel.fl b/fluid/template_panel.fl index 5e3a4660a..ae2e2b7ea 100644 --- a/fluid/template_panel.fl +++ b/fluid/template_panel.fl @@ -1,244 +1,244 @@ -# data file for the Fltk User Interface Designer (fluid) -version 1.0107 -header_name {.h} -code_name {.cxx} -comment {// -// "$Id$" -// -// FLUID template support for the Fast Light Tool Kit (FLTK). -// -// Copyright 1998-2005 by Bill Spitzak and others. -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Library General Public -// License as published by the Free Software Foundation; either -// version 2 of the License, or (at your option) any later version. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Library General Public License for more details. -// -// You should have received a copy of the GNU Library General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -// USA. -// -// Please report all bugs and problems on the following page: -// -// http://www.fltk.org/str.php -// -} {in_source in_header -} - -decl {\#include <stdio.h>} {} - -decl {\#include <stdlib.h>} {} - -decl {\#include "../src/flstring.h"} {} - -decl {\#include <errno.h>} {} - -decl {\#include <FL/filename.H>} {} - -decl {\#include <FL/fl_ask.H>} {} - -decl {\#include <FL/Fl_Shared_Image.H>} {} - -decl {\#include <FL/Fl_Preferences.H>} {} - -declblock {\#ifdef WIN32} {after {\#endif // WIN32} -} { - decl {\#include <io.h>} {} - decl {\#else} {} - decl {\#include <unistd.h>} {} -} - -decl {extern Fl_Preferences fluid_prefs;} {} - -Function {make_template_panel()} {open -} { - Fl_Window template_panel { - label {New/Save Template} - callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_browser->deselect(); -template_name->value(""); -template_instance->value(""); -template_panel->hide();} open - xywh {340 237 460 355} type Double resizable modal visible - } { - Fl_Browser template_browser { - label {Available Templates:} - callback {if (Fl::event_clicks()) { - template_panel->hide(); - return; -} -Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); -template_preview->redraw(); - -int item = template_browser->value(); - -if (item <= 1) template_instance->deactivate(); -else template_instance->activate(); - -if (item < 1) { - template_submit->deactivate(); - template_delete->deactivate(); - return; -} - -template_submit->activate(); - -const char *flfile = (const char *)template_browser->data(item); -if (!flfile) { - template_delete->deactivate(); - return; -} - -template_name->value(template_browser->text(item)); - -template_delete->activate(); - -char pngfile[1024], *ext; - -strlcpy(pngfile, flfile, sizeof(pngfile)); -if ((ext = strrchr(pngfile, '.')) == NULL) return; -strcpy(ext, ".png"); - -img = Fl_Shared_Image::get(pngfile); - -if (img) { - template_preview->image(img); - template_preview->redraw(); -}} selected - xywh {10 28 180 250} type Hold labelfont 1 align 5 when 3 - } - Fl_Box template_preview { - xywh {200 28 250 250} box THIN_DOWN_BOX align 85 resizable - } - Fl_Input template_name { - label {Template Name:} - callback {if (strlen(template_name->value())) { - template_submit->activate(); - if (Fl::event_key() == FL_Enter) template_panel->hide(); -} else template_submit->deactivate();} - xywh {124 288 326 25} labelfont 1 when 3 textfont 4 - } - Fl_Input template_instance { - label {Instance Name:} - xywh {124 288 326 25} labelfont 1 textfont 4 hide - } - Fl_Group {} { - xywh {10 323 440 25} - } { - Fl_Button template_delete { - label {Delete Template} - callback template_delete_cb - xywh {10 323 133 25} - } - Fl_Box {} { - xywh {153 323 126 25} resizable - } - Fl_Button {} { - label Cancel - callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_browser->deselect(); -template_name->value(""); -template_instance->value(""); -template_panel->hide();} - xywh {289 323 72 25} - } - Fl_Return_Button template_submit { - label Save - callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image(); -if (img) img->release(); -template_preview->image(0); - -template_panel->hide();} - xywh {371 323 79 25} - } - } - } -} - -Function {template_clear()} {return_type void -} { - code {int i; -void *filename; - -for (i = 1; i <= template_browser->size(); i ++) { - if ((filename = template_browser->data(i)) != NULL) free(filename); -} - -template_browser->deselect(); -template_browser->clear();} {} -} - -Function {template_delete_cb(Fl_Button *, void *)} {return_type void -} { - code {int item = template_browser->value(); -if (item < 1) return; - -const char *name = template_browser->text(item); -const char *flfile = (const char *)template_browser->data(item); -if (!flfile) return; - -if (!fl_choice("Are you sure you want to delete the template \\"%s\\"?", - "Cancel", "Delete", 0, name)) return; - -if (unlink(flfile)) { - fl_alert("Unable to delete template \\"%s\\":\\n%s", name, strerror(errno)); - return; -} - -template_browser->remove(item); -template_browser->do_callback();} {} -} - -Function {template_load()} {open return_type void -} { - code {int i; -char name[1024], filename[1024], path[1024], *ptr; -struct dirent **files; -int num_files; - -fluid_prefs.getUserdataPath(path, sizeof(path)); -strlcat(path, "templates", sizeof(path)); - -num_files = fl_filename_list(path, &files); - -for (i = 0; i < num_files; i ++) { - if (fl_filename_match(files[i]->d_name, "*.fl")) { - // Format the name as the filename with "_" replaced with " " - // and without the trailing ".fl"... - strlcpy(name, files[i]->d_name, sizeof(name)); - *strstr(name, ".fl") = '\\0'; - - for (ptr = name; *ptr; ptr ++) { - if (*ptr == '_') *ptr = ' '; - } - - // Add the template to the browser... - snprintf(filename, sizeof(filename), "%s/%s", path, files[i]->d_name); - template_browser->add(name, strdup(filename)); - } - - free(files[i]); -} - -if (num_files > 0) free(files);} {} -} - -comment { -// -// End of "$Id$". -//} {in_source in_header -} +# data file for the Fltk User Interface Designer (fluid)
+version 1.0107
+header_name {.h}
+code_name {.cxx}
+comment {//
+// "$Id$"
+//
+// FLUID template support for the Fast Light Tool Kit (FLTK).
+//
+// Copyright 1998-2005 by Bill Spitzak and others.
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Library General Public
+// License as published by the Free Software Foundation; either
+// version 2 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Library General Public License for more details.
+//
+// You should have received a copy of the GNU Library General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+// USA.
+//
+// Please report all bugs and problems on the following page:
+//
+// http://www.fltk.org/str.php
+//
+} {in_source in_header
+}
+
+decl {\#include <stdio.h>} {}
+
+decl {\#include <stdlib.h>} {}
+
+decl {\#include "../src/flstring.h"} {}
+
+decl {\#include <errno.h>} {}
+
+decl {\#include <FL/filename.H>} {}
+
+decl {\#include <FL/fl_ask.H>} {}
+
+decl {\#include <FL/Fl_Shared_Image.H>} {}
+
+decl {\#include <FL/Fl_Preferences.H>} {}
+
+declblock {\#if defined(WIN32) && !defined(__CYGWIN__)} {selected after {\#endif // WIN32 && !__CYGWIN__}
+} {
+ decl {\#include <io.h>} {}
+ decl {\#else} {}
+ decl {\#include <unistd.h>} {}
+}
+
+decl {extern Fl_Preferences fluid_prefs;} {}
+
+Function {make_template_panel()} {open
+} {
+ Fl_Window template_panel {
+ label {New/Save Template}
+ callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_browser->deselect();
+template_name->value("");
+template_instance->value("");
+template_panel->hide();} open
+ xywh {340 237 460 355} type Double resizable modal visible
+ } {
+ Fl_Browser template_browser {
+ label {Available Templates:}
+ callback {if (Fl::event_clicks()) {
+ template_panel->hide();
+ return;
+}
+Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+template_preview->redraw();
+
+int item = template_browser->value();
+
+if (item <= 1) template_instance->deactivate();
+else template_instance->activate();
+
+if (item < 1) {
+ template_submit->deactivate();
+ template_delete->deactivate();
+ return;
+}
+
+template_submit->activate();
+
+const char *flfile = (const char *)template_browser->data(item);
+if (!flfile) {
+ template_delete->deactivate();
+ return;
+}
+
+template_name->value(template_browser->text(item));
+
+template_delete->activate();
+
+char pngfile[1024], *ext;
+
+strlcpy(pngfile, flfile, sizeof(pngfile));
+if ((ext = strrchr(pngfile, '.')) == NULL) return;
+strcpy(ext, ".png");
+
+img = Fl_Shared_Image::get(pngfile);
+
+if (img) {
+ template_preview->image(img);
+ template_preview->redraw();
+}}
+ xywh {10 28 180 250} type Hold labelfont 1 align 5 when 3
+ }
+ Fl_Box template_preview {
+ xywh {200 28 250 250} box THIN_DOWN_BOX align 85 resizable
+ }
+ Fl_Input template_name {
+ label {Template Name:}
+ callback {if (strlen(template_name->value())) {
+ template_submit->activate();
+ if (Fl::event_key() == FL_Enter) template_panel->hide();
+} else template_submit->deactivate();}
+ xywh {124 288 326 25} labelfont 1 when 3 textfont 4
+ }
+ Fl_Input template_instance {
+ label {Instance Name:}
+ xywh {124 288 326 25} labelfont 1 textfont 4 hide
+ }
+ Fl_Group {} {
+ xywh {10 323 440 25}
+ } {
+ Fl_Button template_delete {
+ label {Delete Template}
+ callback template_delete_cb
+ xywh {10 323 133 25}
+ }
+ Fl_Box {} {
+ xywh {153 323 126 25} resizable
+ }
+ Fl_Button {} {
+ label Cancel
+ callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_browser->deselect();
+template_name->value("");
+template_instance->value("");
+template_panel->hide();}
+ xywh {289 323 72 25}
+ }
+ Fl_Return_Button template_submit {
+ label Save
+ callback {Fl_Shared_Image *img = (Fl_Shared_Image *)template_preview->image();
+if (img) img->release();
+template_preview->image(0);
+
+template_panel->hide();}
+ xywh {371 323 79 25}
+ }
+ }
+ }
+}
+
+Function {template_clear()} {return_type void
+} {
+ code {int i;
+void *filename;
+
+for (i = 1; i <= template_browser->size(); i ++) {
+ if ((filename = template_browser->data(i)) != NULL) free(filename);
+}
+
+template_browser->deselect();
+template_browser->clear();} {}
+}
+
+Function {template_delete_cb(Fl_Button *, void *)} {return_type void
+} {
+ code {int item = template_browser->value();
+if (item < 1) return;
+
+const char *name = template_browser->text(item);
+const char *flfile = (const char *)template_browser->data(item);
+if (!flfile) return;
+
+if (!fl_choice("Are you sure you want to delete the template \\"%s\\"?",
+ "Cancel", "Delete", 0, name)) return;
+
+if (unlink(flfile)) {
+ fl_alert("Unable to delete template \\"%s\\":\\n%s", name, strerror(errno));
+ return;
+}
+
+template_browser->remove(item);
+template_browser->do_callback();} {}
+}
+
+Function {template_load()} {open return_type void
+} {
+ code {int i;
+char name[1024], filename[1024], path[1024], *ptr;
+struct dirent **files;
+int num_files;
+
+fluid_prefs.getUserdataPath(path, sizeof(path));
+strlcat(path, "templates", sizeof(path));
+
+num_files = fl_filename_list(path, &files);
+
+for (i = 0; i < num_files; i ++) {
+ if (fl_filename_match(files[i]->d_name, "*.fl")) {
+ // Format the name as the filename with "_" replaced with " "
+ // and without the trailing ".fl"...
+ strlcpy(name, files[i]->d_name, sizeof(name));
+ *strstr(name, ".fl") = '\\0';
+
+ for (ptr = name; *ptr; ptr ++) {
+ if (*ptr == '_') *ptr = ' ';
+ }
+
+ // Add the template to the browser...
+ snprintf(filename, sizeof(filename), "%s/%s", path, files[i]->d_name);
+ template_browser->add(name, strdup(filename));
+ }
+
+ free(files[i]);
+}
+
+if (num_files > 0) free(files);} {}
+}
+
+comment {
+//
+// End of "$Id$".
+//} {in_source in_header
+}
diff --git a/fluid/template_panel.h b/fluid/template_panel.h index df5898a88..26fef3655 100644 --- a/fluid/template_panel.h +++ b/fluid/template_panel.h @@ -1,56 +1,56 @@ -// -// "$Id$" -// -// FLUID template support for the Fast Light Tool Kit (FLTK). -// -// Copyright 1998-2005 by Bill Spitzak and others. -// -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Library General Public -// License as published by the Free Software Foundation; either -// version 2 of the License, or (at your option) any later version. -// -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Library General Public License for more details. -// -// You should have received a copy of the GNU Library General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -// USA. -// -// Please report all bugs and problems on the following page: -// -// http://www.fltk.org/str.php -// - -// generated by Fast Light User Interface Designer (fluid) version 1.0107 - -#ifndef template_panel_h -#define template_panel_h -#include <FL/Fl.H> -#include <FL/Fl_Double_Window.H> -extern Fl_Double_Window *template_panel; -#include <FL/Fl_Browser.H> -extern Fl_Browser *template_browser; -#include <FL/Fl_Box.H> -extern Fl_Box *template_preview; -#include <FL/Fl_Input.H> -extern Fl_Input *template_name; -extern Fl_Input *template_instance; -#include <FL/Fl_Group.H> -#include <FL/Fl_Button.H> -extern void template_delete_cb(Fl_Button*, void*); -extern Fl_Button *template_delete; -#include <FL/Fl_Return_Button.H> -extern Fl_Return_Button *template_submit; -Fl_Double_Window* make_template_panel(); -void template_clear(); -void template_delete_cb(Fl_Button *, void *); -void template_load(); -#endif - -// -// End of "$Id$". -// +//
+// "$Id$"
+//
+// FLUID template support for the Fast Light Tool Kit (FLTK).
+//
+// Copyright 1998-2005 by Bill Spitzak and others.
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Library General Public
+// License as published by the Free Software Foundation; either
+// version 2 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Library General Public License for more details.
+//
+// You should have received a copy of the GNU Library General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+// USA.
+//
+// Please report all bugs and problems on the following page:
+//
+// http://www.fltk.org/str.php
+//
+
+// generated by Fast Light User Interface Designer (fluid) version 1.0107
+
+#ifndef template_panel_h
+#define template_panel_h
+#include <FL/Fl.H>
+#include <FL/Fl_Double_Window.H>
+extern Fl_Double_Window *template_panel;
+#include <FL/Fl_Browser.H>
+extern Fl_Browser *template_browser;
+#include <FL/Fl_Box.H>
+extern Fl_Box *template_preview;
+#include <FL/Fl_Input.H>
+extern Fl_Input *template_name;
+extern Fl_Input *template_instance;
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Button.H>
+extern void template_delete_cb(Fl_Button*, void*);
+extern Fl_Button *template_delete;
+#include <FL/Fl_Return_Button.H>
+extern Fl_Return_Button *template_submit;
+Fl_Double_Window* make_template_panel();
+void template_clear();
+void template_delete_cb(Fl_Button *, void *);
+void template_load();
+#endif
+
+//
+// End of "$Id$".
+//
diff --git a/vcnet/fltk.lib.vcproj b/vcnet/fltk.lib.vcproj index d9c3c9dd8..3f744f517 100644 --- a/vcnet/fltk.lib.vcproj +++ b/vcnet/fltk.lib.vcproj @@ -1733,6 +1733,9 @@ </FileConfiguration>
</File>
<File
+ RelativePath="..\src\fl_read_image.cxx">
+ </File>
+ <File
RelativePath="..\src\fl_rect.cxx">
<FileConfiguration
Name="Debug|Win32">
diff --git a/vcnet/fltkdll.vcproj b/vcnet/fltkdll.vcproj index 8b06d5ce2..891e7e2f9 100644 --- a/vcnet/fltkdll.vcproj +++ b/vcnet/fltkdll.vcproj @@ -1782,6 +1782,9 @@ </FileConfiguration>
</File>
<File
+ RelativePath="..\src\fl_read_image.cxx">
+ </File>
+ <File
RelativePath="..\src\fl_rect.cxx">
<FileConfiguration
Name="Release|Win32">
diff --git a/vcnet/fluid.vcproj b/vcnet/fluid.vcproj index 350c66ce3..85e799d2d 100644 --- a/vcnet/fluid.vcproj +++ b/vcnet/fluid.vcproj @@ -20,7 +20,7 @@ <Tool
Name="VCCLCompilerTool"
Optimization="0"
- AdditionalIncludeDirectories=".,.."
+ AdditionalIncludeDirectories=".,..,..\zlib,..\png"
PreprocessorDefinitions="WIN32;_DEBUG;_WINDOWS;WIN32_LEAN_AND_MEAN;VC_EXTRA_LEAN;WIN32_EXTRA_LEAN"
RuntimeLibrary="3"
UsePrecompiledHeader="2"
@@ -87,7 +87,7 @@ InlineFunctionExpansion="2"
ImproveFloatingPointConsistency="TRUE"
FavorSizeOrSpeed="0"
- AdditionalIncludeDirectories=".,.."
+ AdditionalIncludeDirectories=".,..,..\zlib,..\png"
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;WIN32_LEAN_AND_MEAN;VC_EXTRA_LEAN;WIN32_EXTRA_LEAN"
RuntimeLibrary="2"
UsePrecompiledHeader="2"
@@ -220,7 +220,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\factory.cxx">
+ RelativePath="..\fluid\CodeEditor.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -239,7 +239,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\file.cxx">
+ RelativePath="..\fluid\factory.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -258,7 +258,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Function_Type.cxx">
+ RelativePath="..\fluid\file.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -277,7 +277,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Group_Type.cxx">
+ RelativePath="..\fluid\Fl_Function_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -296,7 +296,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Menu_Type.cxx">
+ RelativePath="..\fluid\Fl_Group_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -315,7 +315,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Type.cxx">
+ RelativePath="..\fluid\Fl_Menu_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -334,7 +334,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Widget_Type.cxx">
+ RelativePath="..\fluid\Fl_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -353,7 +353,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fl_Window_Type.cxx">
+ RelativePath="..\fluid\Fl_Widget_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -372,7 +372,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\fluid.cxx">
+ RelativePath="..\fluid\Fl_Window_Type.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -391,7 +391,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\Fluid_Image.cxx">
+ RelativePath="..\fluid\fluid.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -410,7 +410,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\function_panel.cxx">
+ RelativePath="..\fluid\Fluid_Image.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -429,7 +429,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\undo.cxx">
+ RelativePath="..\fluid\function_panel.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -448,7 +448,10 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\widget_panel.cxx">
+ RelativePath="..\fluid\template_panel.cxx">
+ </File>
+ <File
+ RelativePath="..\fluid\undo.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
@@ -467,7 +470,7 @@ </FileConfiguration>
</File>
<File
- RelativePath="..\fluid\CodeEditor.cxx">
+ RelativePath="..\fluid\widget_panel.cxx">
<FileConfiguration
Name="Debug|Win32">
<Tool
|
