From f6a137b998d663a98390138f1a11c467c3001658 Mon Sep 17 00:00:00 2001 From: Michael R Sweet Date: Fri, 25 Mar 2005 21:12:15 +0000 Subject: 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 --- fluid/fluid.cxx | 10 +- fluid/template_panel.cxx | 520 +++++++++++++++++++++++------------------------ fluid/template_panel.fl | 488 ++++++++++++++++++++++---------------------- fluid/template_panel.h | 112 +++++----- vcnet/fltk.lib.vcproj | 3 + vcnet/fltkdll.vcproj | 3 + 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 -#include -#include "../src/flstring.h" -#include -#include -#include -#include -#include -#ifdef WIN32 -#include -#else -#include -#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 +#include +#include "../src/flstring.h" +#include +#include +#include +#include +#include +#if defined(WIN32) && !defined(__CYGWIN__) +#include +#else +#include +#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 } {} - -decl {\#include } {} - -decl {\#include "../src/flstring.h"} {} - -decl {\#include } {} - -decl {\#include } {} - -decl {\#include } {} - -decl {\#include } {} - -decl {\#include } {} - -declblock {\#ifdef WIN32} {after {\#endif // WIN32} -} { - decl {\#include } {} - decl {\#else} {} - decl {\#include } {} -} - -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 } {} + +decl {\#include } {} + +decl {\#include "../src/flstring.h"} {} + +decl {\#include } {} + +decl {\#include } {} + +decl {\#include } {} + +decl {\#include } {} + +decl {\#include } {} + +declblock {\#if defined(WIN32) && !defined(__CYGWIN__)} {selected after {\#endif // WIN32 && !__CYGWIN__} +} { + decl {\#include } {} + decl {\#else} {} + decl {\#include } {} +} + +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 -#include -extern Fl_Double_Window *template_panel; -#include -extern Fl_Browser *template_browser; -#include -extern Fl_Box *template_preview; -#include -extern Fl_Input *template_name; -extern Fl_Input *template_instance; -#include -#include -extern void template_delete_cb(Fl_Button*, void*); -extern Fl_Button *template_delete; -#include -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 +#include +extern Fl_Double_Window *template_panel; +#include +extern Fl_Browser *template_browser; +#include +extern Fl_Box *template_preview; +#include +extern Fl_Input *template_name; +extern Fl_Input *template_instance; +#include +#include +extern void template_delete_cb(Fl_Button*, void*); +extern Fl_Button *template_delete; +#include +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 @@ -1732,6 +1732,9 @@ PreprocessorDefinitions=""/> + + + + + RelativePath="..\fluid\CodeEditor.cxx"> + RelativePath="..\fluid\factory.cxx"> + RelativePath="..\fluid\file.cxx"> + RelativePath="..\fluid\Fl_Function_Type.cxx"> + RelativePath="..\fluid\Fl_Group_Type.cxx"> + RelativePath="..\fluid\Fl_Menu_Type.cxx"> + RelativePath="..\fluid\Fl_Type.cxx"> + RelativePath="..\fluid\Fl_Widget_Type.cxx"> + RelativePath="..\fluid\Fl_Window_Type.cxx"> + RelativePath="..\fluid\fluid.cxx"> + RelativePath="..\fluid\Fluid_Image.cxx"> + RelativePath="..\fluid\function_panel.cxx"> + RelativePath="..\fluid\template_panel.cxx"> + + + RelativePath="..\fluid\widget_panel.cxx">