Don't allow extra boxtypes to override user-defined boxtypes.

Change the help link function to get both the widget and pathname.


git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@1659 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Michael R Sweet 2001-10-27 03:29:25 +00:00
parent d2bfebbb4b
commit 68fb9f7910
6 changed files with 86 additions and 63 deletions

10
CHANGES
View File

@ -1,3 +1,13 @@
CHANGES IN FLTK 1.1.0b5
- Fl::set_boxtype() and fl_internal_boxtype() now keep
track of when a boxtype is changed; this allows you to
override the "special" boxtypes without references to
those boxtypes causing them to be reset.
- Fl_Help_Func now takes a Fl_Widget pointer as well as
a pathname.
CHANGES IN FLTK 1.1.0b4 CHANGES IN FLTK 1.1.0b4
**** NOTE: DUE TO CHANGES IN THE FL_WIDGET CLASS, **** **** NOTE: DUE TO CHANGES IN THE FL_WIDGET CLASS, ****

View File

@ -1,5 +1,5 @@
// //
// "$Id: Fl_Help_View.H,v 1.1.2.1 2001/09/29 14:38:58 easysw Exp $" // "$Id: Fl_Help_View.H,v 1.1.2.2 2001/10/27 03:29:25 easysw Exp $"
// //
// Help Viewer widget definitions. // Help Viewer widget definitions.
// //
@ -43,7 +43,7 @@
// //
typedef const char *(Fl_Help_Func)(const char *); typedef const char *(Fl_Help_Func)(Fl_Widget *, const char *);
// //
@ -210,5 +210,5 @@ class Fl_Help_View : public Fl_Group //// Help viewer widget
#endif // !_Fl_Help_View_H_ #endif // !_Fl_Help_View_H_
// //
// End of "$Id: Fl_Help_View.H,v 1.1.2.1 2001/09/29 14:38:58 easysw Exp $". // End of "$Id: Fl_Help_View.H,v 1.1.2.2 2001/10/27 03:29:25 easysw Exp $".
// //

View File

@ -66,12 +66,14 @@ in the buffer.
<H4><A NAME="Fl_Help_View.link">void link(Fl_Help_Func *fn)</A></H4> <H4><A NAME="Fl_Help_View.link">void link(Fl_Help_Func *fn)</A></H4>
<P>This method assigns a callback function to use when a link is <P>This method assigns a callback function to use when a link is
followed or a file is loaded (via <CODE>Fl_Help_View::load()</CODE>) that followed or a file is loaded (via
requires a different file or path. The callback function receives the <CODE>Fl_Help_View::load()</CODE>) that requires a different
full pathname for the file in question and must return a pathname that file or path. The callback function receives a pointer to the
can be opened as a local file. This is used by the <CODE>Fl_Help_View</CODE> widget and the full pathname for the
<A HREF="Fl_Help_App.html"><CODE>Fl_Help_App</CODE></A> widget to support WWW file in question and must return a pathname that can be opened
addresses. as a local file. This can also be used to retrieve remote or
virtual documents, returning the temporary file that contains
the actual data.</P>
<H4><A NAME="Fl_Help_View.load">int load(const char *f)</A></H4> <H4><A NAME="Fl_Help_View.load">int load(const char *f)</A></H4>

View File

@ -1,5 +1,5 @@
// //
// "$Id: Fl_Help_View.cxx,v 1.1.2.7 2001/10/26 21:18:30 easysw Exp $" // "$Id: Fl_Help_View.cxx,v 1.1.2.8 2001/10/27 03:29:25 easysw Exp $"
// //
// Fl_Help_View widget routines. // Fl_Help_View widget routines.
// //
@ -547,7 +547,7 @@ Fl_Help_View::add_image(const char *name, // I - Path of image
sprintf(temp, "%s/%s", directory_, name); sprintf(temp, "%s/%s", directory_, name);
if (link_) if (link_)
localname = (*link_)(temp); localname = (*link_)(this, temp);
else else
localname = temp; localname = temp;
} }
@ -562,12 +562,12 @@ Fl_Help_View::add_image(const char *name, // I - Path of image
} }
if (link_) if (link_)
localname = (*link_)(temp); localname = (*link_)(this, temp);
else else
localname = temp; localname = temp;
} }
else if (link_) else if (link_)
localname = (*link_)(name); localname = (*link_)(this, name);
else else
localname = name; localname = name;
@ -2840,7 +2840,7 @@ Fl_Help_View::load(const char *f)// I - Filename to load (may also have target)
*target++ = '\0'; *target++ = '\0';
if (link_) if (link_)
localname = (*link_)(filename_); localname = (*link_)(this, filename_);
else else
localname = filename_; localname = filename_;
@ -3584,5 +3584,5 @@ scrollbar_callback(Fl_Widget *s, void *)
// //
// End of "$Id: Fl_Help_View.cxx,v 1.1.2.7 2001/10/26 21:18:30 easysw Exp $". // End of "$Id: Fl_Help_View.cxx,v 1.1.2.8 2001/10/27 03:29:25 easysw Exp $".
// //

View File

@ -1,5 +1,5 @@
# #
# "$Id: Makefile,v 1.18.2.14.2.13 2001/09/30 17:54:45 easysw Exp $" # "$Id: Makefile,v 1.18.2.14.2.14 2001/10/27 03:29:25 easysw Exp $"
# #
# Library makefile for the Fast Light Tool Kit (FLTK). # Library makefile for the Fast Light Tool Kit (FLTK).
# #
@ -170,6 +170,7 @@ all: $(LIBNAME) $(DSONAME) $(GLLIBNAME) $(GLDSONAME)
$(LIBNAME): $(OBJECTS) $(LIBNAME): $(OBJECTS)
echo $(LIBCOMMAND) $@ ... echo $(LIBCOMMAND) $@ ...
rm -f $@
$(LIBCOMMAND) $@ $(OBJECTS) $(LIBCOMMAND) $@ $(OBJECTS)
$(RANLIB) $@ $(RANLIB) $@
@ -181,11 +182,13 @@ libfltk_s.a: $(OBJECTS)
echo $(DSOCOMMAND) libfltk_s.o ... echo $(DSOCOMMAND) libfltk_s.o ...
$(DSOCOMMAND) libfltk_s.o $(OBJECTS) $(IMAGELIBS) $(DSOCOMMAND) libfltk_s.o $(OBJECTS) $(IMAGELIBS)
echo $(LIBCOMMAND) libfltk_s.a libfltk_s.o echo $(LIBCOMMAND) libfltk_s.a libfltk_s.o
rm -f $@
$(LIBCOMMAND) libfltk_s.a libfltk_s.o $(LIBCOMMAND) libfltk_s.a libfltk_s.o
chmod +x libfltk_s.a chmod +x libfltk_s.a
$(GLLIBNAME): $(GLOBJECTS) $(GLLIBNAME): $(GLOBJECTS)
echo $(LIBCOMMAND) $@ ... echo $(LIBCOMMAND) $@ ...
rm -f $@
$(LIBCOMMAND) $@ $(GLOBJECTS) $(LIBCOMMAND) $@ $(GLOBJECTS)
$(RANLIB) $@ $(RANLIB) $@
@ -197,6 +200,7 @@ libfltk_gl_s.a: $(GLOBJECTS)
echo $(DSOCOMMAND) libfltk_gl_s.o ... echo $(DSOCOMMAND) libfltk_gl_s.o ...
$(DSOCOMMAND) libfltk_gl_s.o $(GLOBJECTS) $(DSOCOMMAND) libfltk_gl_s.o $(GLOBJECTS)
echo $(LIBCOMMAND) libfltk_gl_s.a libfltk_gl_s.o echo $(LIBCOMMAND) libfltk_gl_s.a libfltk_gl_s.o
rm -f $@
$(LIBCOMMAND) libfltk_gl_s.a libfltk_gl_s.o $(LIBCOMMAND) libfltk_gl_s.a libfltk_gl_s.o
chmod +x libfltk_gl_s.a chmod +x libfltk_gl_s.a
@ -263,5 +267,5 @@ install: $(LIBNAME) $(DSONAME) $(GLLIBNAME) $(GLDSONAME)
ln -s FL $(includedir)/Fl ln -s FL $(includedir)/Fl
# #
# End of "$Id: Makefile,v 1.18.2.14.2.13 2001/09/30 17:54:45 easysw Exp $". # End of "$Id: Makefile,v 1.18.2.14.2.14 2001/10/27 03:29:25 easysw Exp $".
# #

View File

@ -1,5 +1,5 @@
// //
// "$Id: fl_boxtype.cxx,v 1.8.2.4.2.1 2001/08/04 12:21:33 easysw Exp $" // "$Id: fl_boxtype.cxx,v 1.8.2.4.2.2 2001/10/27 03:29:25 easysw Exp $"
// //
// Box drawing code for the Fast Light Tool Kit (FLTK). // Box drawing code for the Fast Light Tool Kit (FLTK).
// //
@ -186,46 +186,47 @@ void fl_border_frame(int x, int y, int w, int h, Fl_Color c) {
static struct { static struct {
Fl_Box_Draw_F *f; Fl_Box_Draw_F *f;
uchar dx, dy, dw, dh; uchar dx, dy, dw, dh;
int set;
} fl_box_table[] = { } fl_box_table[] = {
// must match list in Enumerations.H!!! // must match list in Enumerations.H!!!
{fl_no_box, 0,0,0,0}, {fl_no_box, 0,0,0,0,1},
{fl_rectf, 0,0,0,0}, // FL_FLAT_BOX {fl_rectf, 0,0,0,0,1}, // FL_FLAT_BOX
{fl_up_box, D1,D1,D2,D2}, {fl_up_box, D1,D1,D2,D2,1},
{fl_down_box, D1,D1,D2,D2}, {fl_down_box, D1,D1,D2,D2,1},
{fl_up_frame, D1,D1,D2,D2}, {fl_up_frame, D1,D1,D2,D2,1},
{fl_down_frame, D1,D1,D2,D2}, {fl_down_frame, D1,D1,D2,D2,1},
{fl_thin_up_box, 1,1,2,2}, {fl_thin_up_box, 1,1,2,2,1},
{fl_thin_down_box, 1,1,2,2}, {fl_thin_down_box, 1,1,2,2,1},
{fl_thin_up_frame, 1,1,2,2}, {fl_thin_up_frame, 1,1,2,2,1},
{fl_thin_down_frame, 1,1,2,2}, {fl_thin_down_frame, 1,1,2,2,1},
{fl_engraved_box, 2,2,4,4}, {fl_engraved_box, 2,2,4,4,1},
{fl_embossed_box, 2,2,4,4}, {fl_embossed_box, 2,2,4,4,1},
{fl_engraved_frame, 2,2,4,4}, {fl_engraved_frame, 2,2,4,4,1},
{fl_embossed_frame, 2,2,4,4}, {fl_embossed_frame, 2,2,4,4,1},
{fl_border_box, 1,1,2,2}, {fl_border_box, 1,1,2,2,1},
{fl_border_box, 1,1,2,2}, // _FL_SHADOW_BOX, {fl_border_box, 1,1,2,2,0}, // _FL_SHADOW_BOX,
{fl_border_frame, 1,1,2,2}, {fl_border_frame, 1,1,2,2,1},
{fl_border_frame, 1,1,2,2}, // _FL_SHADOW_FRAME, {fl_border_frame, 1,1,2,2,0}, // _FL_SHADOW_FRAME,
{fl_border_box, 1,1,2,2}, // _FL_ROUNDED_BOX, {fl_border_box, 1,1,2,2,0}, // _FL_ROUNDED_BOX,
{fl_border_box, 1,1,2,2}, // _FL_RSHADOW_BOX, {fl_border_box, 1,1,2,2,0}, // _FL_RSHADOW_BOX,
{fl_border_frame, 1,1,2,2}, // _FL_ROUNDED_FRAME {fl_border_frame, 1,1,2,2,0}, // _FL_ROUNDED_FRAME
{fl_rectf, 0,0,0,0}, // _FL_RFLAT_BOX, {fl_rectf, 0,0,0,0,0}, // _FL_RFLAT_BOX,
{fl_up_box, 3,3,6,6}, // _FL_ROUND_UP_BOX {fl_up_box, 3,3,6,6,0}, // _FL_ROUND_UP_BOX
{fl_down_box, 3,3,6,6}, // _FL_ROUND_DOWN_BOX, {fl_down_box, 3,3,6,6,0}, // _FL_ROUND_DOWN_BOX,
{fl_up_box, 0,0,0,0}, // _FL_DIAMOND_UP_BOX {fl_up_box, 0,0,0,0,0}, // _FL_DIAMOND_UP_BOX
{fl_down_box, 0,0,0,0}, // _FL_DIAMOND_DOWN_BOX {fl_down_box, 0,0,0,0,0}, // _FL_DIAMOND_DOWN_BOX
{fl_border_box, 1,1,2,2}, // _FL_OVAL_BOX, {fl_border_box, 1,1,2,2,0}, // _FL_OVAL_BOX,
{fl_border_box, 1,1,2,2}, // _FL_OVAL_SHADOW_BOX, {fl_border_box, 1,1,2,2,0}, // _FL_OVAL_SHADOW_BOX,
{fl_border_frame, 1,1,2,2}, // _FL_OVAL_FRAME {fl_border_frame, 1,1,2,2,0}, // _FL_OVAL_FRAME
{fl_rectf, 0,0,0,0}, // _FL_OVAL_FLAT_BOX, {fl_rectf, 0,0,0,0,0}, // _FL_OVAL_FLAT_BOX,
{fl_up_box, 3,3,6,6}, // FL_FREE_BOX+0 {fl_up_box, 3,3,6,6,0}, // FL_FREE_BOX+0
{fl_down_box, 3,3,6,6}, // FL_FREE_BOX+1 {fl_down_box, 3,3,6,6,0}, // FL_FREE_BOX+1
{fl_up_box, 3,3,6,6}, // FL_FREE_BOX+2 {fl_up_box, 3,3,6,6,0}, // FL_FREE_BOX+2
{fl_down_box, 3,3,6,6}, // FL_FREE_BOX+3 {fl_down_box, 3,3,6,6,0}, // FL_FREE_BOX+3
{fl_up_box, 3,3,6,6}, // FL_FREE_BOX+4 {fl_up_box, 3,3,6,6,0}, // FL_FREE_BOX+4
{fl_down_box, 3,3,6,6}, // FL_FREE_BOX+5 {fl_down_box, 3,3,6,6,0}, // FL_FREE_BOX+5
{fl_up_box, 3,3,6,6}, // FL_FREE_BOX+6 {fl_up_box, 3,3,6,6,0}, // FL_FREE_BOX+6
{fl_down_box, 3,3,6,6}, // FL_FREE_BOX+7 {fl_down_box, 3,3,6,6,0}, // FL_FREE_BOX+7
}; };
int Fl::box_dx(Fl_Boxtype t) {return fl_box_table[t].dx;} int Fl::box_dx(Fl_Boxtype t) {return fl_box_table[t].dx;}
@ -233,11 +234,17 @@ int Fl::box_dy(Fl_Boxtype t) {return fl_box_table[t].dy;}
int Fl::box_dw(Fl_Boxtype t) {return fl_box_table[t].dw;} int Fl::box_dw(Fl_Boxtype t) {return fl_box_table[t].dw;}
int Fl::box_dh(Fl_Boxtype t) {return fl_box_table[t].dh;} int Fl::box_dh(Fl_Boxtype t) {return fl_box_table[t].dh;}
void fl_internal_boxtype(Fl_Boxtype t, Fl_Box_Draw_F* f) {fl_box_table[t].f=f;} void fl_internal_boxtype(Fl_Boxtype t, Fl_Box_Draw_F* f) {
if (!fl_box_table[t].set) {
fl_box_table[t].f = f;
fl_box_table[t].set = 1;
}
}
void Fl::set_boxtype(Fl_Boxtype t, Fl_Box_Draw_F* f, void Fl::set_boxtype(Fl_Boxtype t, Fl_Box_Draw_F* f,
uchar a, uchar b, uchar c, uchar d) { uchar a, uchar b, uchar c, uchar d) {
fl_box_table[t].f = f; fl_box_table[t].f = f;
fl_box_table[t].set = 1;
fl_box_table[t].dx = a; fl_box_table[t].dx = a;
fl_box_table[t].dy = b; fl_box_table[t].dy = b;
fl_box_table[t].dw = c; fl_box_table[t].dw = c;
@ -277,5 +284,5 @@ const {
} }
// //
// End of "$Id: fl_boxtype.cxx,v 1.8.2.4.2.1 2001/08/04 12:21:33 easysw Exp $". // End of "$Id: fl_boxtype.cxx,v 1.8.2.4.2.2 2001/10/27 03:29:25 easysw Exp $".
// //