123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143(**************************************************************************)(* *)(* This file is part of Frama-C. *)(* *)(* Copyright (C) 2007-2023 *)(* CEA (Commissariat à l'énergie atomique et aux énergies *)(* alternatives) *)(* *)(* you can redistribute it and/or modify it under the terms of the GNU *)(* Lesser General Public License as published by the Free Software *)(* Foundation, version 2.1. *)(* *)(* It 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 Lesser General Public License for more details. *)(* *)(* See the GNU Lesser General Public License version 2.1 *)(* for more details (enclosed in the file licenses/LGPLv2.1). *)(* *)(**************************************************************************)openWidgetclasstool?label?tooltip?content()=letstatus=newWidget.image`Noneinlettoggle=newWidget.toggle~align:`Left?label?tooltip~border:false()inletaction=newWidget.button~icon:`MEDIA_PLAY?tooltip()inobject(self)initializerbeginletcolor=`NAME"orange"intoggle#coerce#misc#modify_bg[`PRELIGHT,color;`ACTIVE,color];toggle#connectself#toggle;action#connectself#action;self#togglefalse;action#set_borderfalse;Wutil.oncontentself#set_content;endvalmutabledetails=Nonevalmutabletooltip=Nonevalmutablecallback=Nonevalmutableview=Nonemethodprivatetogglea=matchdetailswith|None->()|Somew->Wutil.set_visiblewamethodprivateaction()=matchcallbackwith|None->()|Somef->f()methodprivaterender=lethbox=GPack.hbox~show:true()inhbox#pack~expand:falsestatus#coerce;hbox#pack~expand:true~fill:true~padding:1toggle#coerce;hbox#pack~expand:falseaction#coerce;matchdetailswith|None->hbox#coerce|Somew->letvbox=GPack.vbox~show:true()invbox#pack~expand:falsehbox#coerce;vbox#pack~expand:true~fill:falsew#coerce;vbox#coercemethodtool=(self:>tool)methodwidget=matchviewwithSomew->w|None->letw=newWutil.gobj_widgetself#renderinview<-Somew;wmethodcoerce=self#widget#coercemethodon_active=toggle#connectmethodis_active=toggle#getmethodset_active=toggle#setmethodhas_action=callback!=Nonemethodset_enablede=self#widget#set_enabledemethodset_visiblev=self#widget#set_visiblevmethodset_label=toggle#set_labelmethodset_tooltiptxt=toggle#set_tooltiptxtmethodset_status=status#set_iconmethodclear_action=callback<-None;action#set_visiblefalsemethodset_action?icon?tooltip?callback:cb()=begincallback<-cb;action#set_visibletrue;action#set_enabled(cb!=None);Wutil.oniconaction#set_icon;Wutil.ontooltipaction#set_tooltip;endmethodset_content(w:widget)=assert(details==None);letframe=GBin.frame~show:false()inletpadds=GBin.alignment~padding:(4,4,4,4)()inpadds#addw#coerce;frame#addpadds#coerce;details<-Someframeend(* -------------------------------------------------------------------------- *)(* --- Panel --- *)(* -------------------------------------------------------------------------- *)classpanel()=letbox=GPack.vbox~show:true()inobject(self)inheritWutil.gobj_widgetboxvalmutablelock=falsevalmutabletools=[]methodadd_widget(w:GObj.widget)=box#pack~expand:falsewmethodadd_tool(w:tool)=beginself#add_widgetw#coerce;w#on_active(self#activew);tools<-w::tools;endmethodprivateactivewa=ifa&¬lockthentrylock<-true;List.iter(funw0->ifw0<>wthenw0#set_activefalse)tools;lock<-false;withe->lock<-false;raiseeend