remove mem leaks

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@1703 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Lars Gullik Bjønnes 2001-03-07 16:18:05 +00:00
parent 765db1102d
commit 916ae4222d
17 changed files with 61 additions and 65 deletions

View File

@ -1,3 +1,15 @@
2001-03-07 Lars Gullik Bjønnes <larsbj@trylle.birdstep.com>
* lyx_main.C: make toplevel_keymap a boost::scoped_ptr.
* kbmap.[Ch]: make kb_key::table a boost::shared_ptr, remove
unneeded destructor.
* intl.[Ch] (Intl): free the fd_form_keymap, make the fd_form_keymap
a standalone pointer again.
* ColorHandler.[Ch]: make lyxColorHandler a boost::scoped_ptr
2001-03-06 John Levon <moz@compsoc.man.ac.uk> 2001-03-06 John Levon <moz@compsoc.man.ac.uk>
* Makefile.am: * Makefile.am:

View File

@ -226,4 +226,4 @@ void LyXColorHandler::updateColor (LColor::color c)
} }
// //
LyXColorHandler * lyxColorHandler; boost::scoped_ptr<LyXColorHandler> lyxColorHandler;

View File

@ -15,6 +15,8 @@
#pragma interface #pragma interface
#endif #endif
#include <boost/smart_ptr.hpp>
// This is only included to provide stuff for the non-public sections // This is only included to provide stuff for the non-public sections
#include <X11/Xlib.h> #include <X11/Xlib.h>
@ -56,6 +58,6 @@ private:
}; };
/// ///
extern LyXColorHandler * lyxColorHandler; extern boost::scoped_ptr<LyXColorHandler> lyxColorHandler;
#endif #endif

View File

@ -18,6 +18,7 @@
#endif #endif
#include "Menubar.h" #include "Menubar.h"
#include "MenuBackend.h"
#include "Menubar_pimpl.h" #include "Menubar_pimpl.h"
Menubar::Menubar(LyXView * o, MenuBackend const & md) Menubar::Menubar(LyXView * o, MenuBackend const & md)

View File

@ -45,7 +45,7 @@ using std::endl;
extern GLyxAppWin * mainAppWin; extern GLyxAppWin * mainAppWin;
// Some constants // Some constants
extern kb_keymap * toplevel_keymap; extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
extern LyXAction lyxaction; extern LyXAction lyxaction;
extern BufferList bufferlist; extern BufferList bufferlist;
extern LastFiles * lastfiles; extern LastFiles * lastfiles;

View File

@ -1,3 +1,10 @@
2001-03-07 Lars Gullik Bjønnes <larsbj@trylle.birdstep.com>
* Menubar_pimpl.h: make Pipl::ItemInfo::item_ a boost::shared_ptr,
make ButtonList contain boost::shared_ptr<ItemInfo>
* Menubar_pimpl.C (~Pimpl): remove destructor
2001-03-06 John Levon <moz@compsoc.man.ac.uk> 2001-03-06 John Levon <moz@compsoc.man.ac.uk>
* Makefile.am: * Makefile.am:

View File

@ -32,7 +32,7 @@ using std::min;
typedef vector<int>::size_type size_type; typedef vector<int>::size_type size_type;
extern kb_keymap * toplevel_keymap; extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
extern LyXAction lyxaction; extern LyXAction lyxaction;
// Some constants // Some constants
@ -87,12 +87,6 @@ Menubar::Pimpl::Pimpl(LyXView * view, MenuBackend const & mb)
} }
Menubar::Pimpl::~Pimpl()
{
// Should we do something here?
}
void Menubar::Pimpl::makeMenubar(Menu const &menu) void Menubar::Pimpl::makeMenubar(Menu const &menu)
{ {
FL_FORM * form = owner_->getForm(); FL_FORM * form = owner_->getForm();
@ -132,10 +126,10 @@ void Menubar::Pimpl::makeMenubar(Menu const &menu)
fl_set_object_shortcut(obj, shortcut.c_str(), 1); fl_set_object_shortcut(obj, shortcut.c_str(), 1);
fl_set_object_callback(obj, C_Menubar_Pimpl_MenuCallback, 1); fl_set_object_callback(obj, C_Menubar_Pimpl_MenuCallback, 1);
ItemInfo * iteminfo = new ItemInfo(this, boost::shared_ptr<ItemInfo> iteminfo(new ItemInfo(this,
new MenuItem(*i), obj); new MenuItem(*i), obj));
buttonlist_.push_back(iteminfo); buttonlist_.push_back(iteminfo);
obj->u_vdata = iteminfo; obj->u_vdata = iteminfo.get();
} }
} }
@ -541,7 +535,7 @@ void Menubar::Pimpl::MenuCallback(FL_OBJECT * ob, long button)
// << ", obj_=" << iteminfo->obj_ << ")" <<endl; // << ", obj_=" << iteminfo->obj_ << ")" <<endl;
LyXView * view = iteminfo->pimpl_->owner_; LyXView * view = iteminfo->pimpl_->owner_;
MenuItem const * item = iteminfo->item_; MenuItem const * item = iteminfo->item_.get();
if (button == 1) { if (button == 1) {
// set the pseudo menu-button // set the pseudo menu-button

View File

@ -20,6 +20,7 @@
#include <vector> #include <vector>
#include <map> #include <map>
#include <boost/smart_ptr.hpp>
#include "LString.h" #include "LString.h"
#include "frontends/Menubar.h" #include "frontends/Menubar.h"
#include "commandtags.h" #include "commandtags.h"
@ -37,8 +38,6 @@ public:
/// ///
Pimpl(LyXView *, MenuBackend const &); Pimpl(LyXView *, MenuBackend const &);
/// ///
~Pimpl();
///
void set(string const &); void set(string const &);
/// Opens a top-level submenu given its name /// Opens a top-level submenu given its name
void openByName(string const &); void openByName(string const &);
@ -71,18 +70,19 @@ private:
struct ItemInfo { struct ItemInfo {
/// ///
ItemInfo(Menubar::Pimpl * p, MenuItem const * i, ItemInfo(Menubar::Pimpl * p, MenuItem const * i,
FL_OBJECT * o) FL_OBJECT * o)
: pimpl_(p), item_(i), obj_(o) {}
: pimpl_(p), obj_(o) { item_.reset(i); }
/// ///
Menubar::Pimpl * pimpl_; Menubar::Pimpl * pimpl_;
/// ///
MenuItem const * item_; boost::shared_ptr<MenuItem const> item_;
/// ///
FL_OBJECT * obj_; FL_OBJECT * obj_;
}; };
/// ///
typedef std::vector<ItemInfo *> ButtonList; typedef std::vector<boost::shared_ptr<ItemInfo> > ButtonList;
/// ///
ButtonList buttonlist_; ButtonList buttonlist_;

View File

@ -56,13 +56,14 @@ Intl::Intl()
Intl::~Intl() Intl::~Intl()
{ {
fl_free(fd_form_keymap);
r_.disconnect(); r_.disconnect();
} }
void Intl::redraw() void Intl::redraw()
{ {
if (fd_form_keymap.get() && fd_form_keymap->KeyMap->visible) if (fd_form_keymap && fd_form_keymap->KeyMap->visible)
fl_redraw_form(fd_form_keymap->KeyMap); fl_redraw_form(fd_form_keymap->KeyMap);
} }
@ -110,7 +111,7 @@ void Intl::KeyMapOn(bool on)
{ {
keymapon = on; keymapon = on;
if (!fd_form_keymap.get()) return; if (!fd_form_keymap) return;
fl_set_button(fd_form_keymap->KeyOffBtn, 0); fl_set_button(fd_form_keymap->KeyOffBtn, 0);
fl_set_button(fd_form_keymap->KeyOnBtn, 0); fl_set_button(fd_form_keymap->KeyOnBtn, 0);
@ -249,7 +250,7 @@ void Intl::InitKeyMapper(bool on)
Language->setcallback(LCombo, this); Language->setcallback(LCombo, this);
Language2->setcallback(LCombo, this); Language2->setcallback(LCombo, this);
fd_form_keymap.reset(create_form_KeyMap()); fd_form_keymap = create_form_KeyMap();
// Add the Intl* pointer // Add the Intl* pointer
fd_form_keymap->AcceptChset->u_vdata = fd_form_keymap->AcceptChset->u_vdata =

View File

@ -89,7 +89,7 @@ private:
int otherkeymap; int otherkeymap;
/// ///
boost::scoped_ptr<FD_KeyMap> fd_form_keymap; FD_KeyMap * fd_form_keymap;
/// ///
boost::scoped_ptr<Combox> Language; boost::scoped_ptr<Combox> Language;
/// ///

View File

@ -121,9 +121,9 @@ int kb_keymap::lookup(unsigned int key,
unsigned int const msk0 = ((*cit).mod >> 16) & 0xffff; unsigned int const msk0 = ((*cit).mod >> 16) & 0xffff;
if ((*cit).code == key && (mod & ~msk0) == msk1) { if ((*cit).code == key && (mod & ~msk0) == msk1) {
// math found: // math found:
if ((*cit).table) { if ((*cit).table.get()) {
// this is a prefix key - set new map // this is a prefix key - set new map
seq->curmap = (*cit).table; seq->curmap = (*cit).table.get();
return 0; return 0;
} else { } else {
// final key - reset map // final key - reset map
@ -191,13 +191,12 @@ int kb_keymap::defkey(kb_sequence * seq, int action, int idx /*= 0*/)
<< buf << buf
<< "' is overriding old binding..." << "' is overriding old binding..."
<< endl; << endl;
if ((*it).table) { if ((*it).table.get()) {
delete (*it).table; (*it).table.reset(0);
(*it).table = 0;
} }
(*it).action = action; (*it).action = action;
return 0; return 0;
} else if (!(*it).table) { } else if (!(*it).table.get()) {
string buf; string buf;
seq->print(buf, true); seq->print(buf, true);
lyxerr << "Error: New binding for '" << buf lyxerr << "Error: New binding for '" << buf
@ -217,33 +216,15 @@ int kb_keymap::defkey(kb_sequence * seq, int action, int idx /*= 0*/)
(*newone).mod = modmsk; (*newone).mod = modmsk;
if (idx + 1 == seq->length) { if (idx + 1 == seq->length) {
(*newone).action = action; (*newone).action = action;
(*newone).table = 0; (*newone).table.reset(0);
return 0; return 0;
} else { } else {
(*newone).table = new kb_keymap; (*newone).table.reset(new kb_keymap);
return (*newone).table->defkey(seq, action, idx + 1); return (*newone).table->defkey(seq, action, idx + 1);
} }
} }
/* ---F+------------------------------------------------------------------ *\
Function : kb_keymap::~kb_keymap
Called by : [destructor]
Purpose : free keymap and its descendents
Parameters: none
Returns : nothing
\* ---F------------------------------------------------------------------- */
kb_keymap::~kb_keymap()
{
// This could be done by a destructor in kb_key.
Table::iterator end = table.end();
for (Table::iterator it = table.begin(); it != end; ++it) {
delete (*it).table;
}
}
string const kb_keymap::keyname(kb_key const & k) string const kb_keymap::keyname(kb_key const & k)
{ {
string buf; string buf;
@ -261,7 +242,7 @@ string const kb_keymap::findbinding(int act) const
Table::const_iterator end = table.end(); Table::const_iterator end = table.end();
for (Table::const_iterator cit = table.begin(); for (Table::const_iterator cit = table.begin();
cit != end; ++cit) { cit != end; ++cit) {
if ((*cit).table) { if ((*cit).table.get()) {
string suffix = (*cit).table->findbinding(act); string suffix = (*cit).table->findbinding(act);
suffix = strip(suffix, ' '); suffix = strip(suffix, ' ');
suffix = strip(suffix, ']'); suffix = strip(suffix, ']');

View File

@ -14,6 +14,7 @@
#endif #endif
#include <list> #include <list>
#include <boost/smart_ptr.hpp>
#include "LString.h" #include "LString.h"
@ -22,9 +23,6 @@ class kb_sequence;
/// Defines key maps and actions for key sequences /// Defines key maps and actions for key sequences
class kb_keymap { class kb_keymap {
public: public:
///
~kb_keymap();
/** Bind a key-sequence to an action. /** Bind a key-sequence to an action.
Returns 0 on success. Otherwise, position in string where Returns 0 on success. Otherwise, position in string where
error occured. */ error occured. */
@ -49,7 +47,7 @@ private:
unsigned int mod; unsigned int mod;
/// Keymap for prefix keys /// Keymap for prefix keys
kb_keymap * table; boost::shared_ptr<kb_keymap> table;
/// Action for !prefix keys /// Action for !prefix keys
int action; int action;

View File

@ -151,7 +151,7 @@ LyXGUI::LyXGUI(LyX * owner, int * argc, char * argv[], bool GUI)
ypos += HeightOfScreen(ScreenOfDisplay(fl_get_display(), fl_screen)) - height; //DefaultScreen(fl_get_display())) - height; ypos += HeightOfScreen(ScreenOfDisplay(fl_get_display(), fl_screen)) - height; //DefaultScreen(fl_get_display())) - height;
// Initialize the LyXColorHandler // Initialize the LyXColorHandler
lyxColorHandler = new LyXColorHandler; lyxColorHandler.reset(new LyXColorHandler);
} }

View File

@ -64,7 +64,7 @@ LyXServer * lyxserver = 0;
bool finished = false; // flag, that we are quitting the program bool finished = false; // flag, that we are quitting the program
// convenient to have it here. // convenient to have it here.
kb_keymap * toplevel_keymap; boost::scoped_ptr<kb_keymap> toplevel_keymap;
LyX::LyX(int * argc, char * argv[]) LyX::LyX(int * argc, char * argv[])
@ -78,8 +78,8 @@ LyX::LyX(int * argc, char * argv[])
bool gui = easyParse(argc, argv); bool gui = easyParse(argc, argv);
// Global bindings (this must be done as early as possible.) (Lgb) // Global bindings (this must be done as early as possible.) (Lgb)
toplevel_keymap = new kb_keymap; toplevel_keymap.reset(new kb_keymap);
defaultKeyBindings(toplevel_keymap); defaultKeyBindings(toplevel_keymap.get());
// Make the GUI object, and let it take care of the // Make the GUI object, and let it take care of the
// command line arguments that concerns it. // command line arguments that concerns it.
@ -432,7 +432,7 @@ void LyX::init(int */*argc*/, char **argv, bool gui)
// Bind the X dead keys to the corresponding LyX functions if // Bind the X dead keys to the corresponding LyX functions if
// necessary. // necessary.
if (lyxrc.override_x_deadkeys) if (lyxrc.override_x_deadkeys)
deadKeyBindings(toplevel_keymap); deadKeyBindings(toplevel_keymap.get());
if (lyxerr.debugging(Debug::LYXRC)) { if (lyxerr.debugging(Debug::LYXRC)) {
lyxrc.print(); lyxrc.print();

View File

@ -102,7 +102,7 @@ extern int greek_kb_flag;
extern bool selection_possible; extern bool selection_possible;
extern void MenuSendto(); extern void MenuSendto();
extern kb_keymap * toplevel_keymap; extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
extern void show_symbols_form(LyXFunc *); extern void show_symbols_form(LyXFunc *);
@ -1519,8 +1519,8 @@ exit_with_message:
void LyXFunc::setupLocalKeymap() void LyXFunc::setupLocalKeymap()
{ {
keyseq.stdmap = keyseq.curmap = toplevel_keymap; keyseq.stdmap = keyseq.curmap = toplevel_keymap.get();
cancel_meta_seq.stdmap = cancel_meta_seq.curmap = toplevel_keymap; cancel_meta_seq.stdmap = cancel_meta_seq.curmap = toplevel_keymap.get();
} }

View File

@ -40,7 +40,7 @@ using std::endl;
using std::vector; using std::vector;
extern LyXAction lyxaction; extern LyXAction lyxaction;
extern kb_keymap * toplevel_keymap; extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
static static

View File

@ -65,7 +65,7 @@ LyXScreen::LyXScreen(WorkArea & o)
void LyXScreen::setCursorColor() void LyXScreen::setCursorColor()
{ {
if (!lyxColorHandler) return; if (!lyxColorHandler.get()) return;
GC gc = lyxColorHandler->getGCForeground(LColor::cursor); GC gc = lyxColorHandler->getGCForeground(LColor::cursor);