/usr/include/fox-1.6/FXDelegator.h is in libfox-1.6-dev 1.6.50-1+b1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | /********************************************************************************
* *
* D e l e g a t o r T a r g e t *
* *
*********************************************************************************
* Copyright (C) 2000,2006 by Jeroen van der Zijp. All Rights Reserved. *
*********************************************************************************
* This library is free software; 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; either *
* version 2.1 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 *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser 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. *
*********************************************************************************
* $Id: FXDelegator.h,v 1.15 2006/01/22 17:58:00 fox Exp $ *
********************************************************************************/
#ifndef FXDELEGATOR_H
#define FXDELEGATOR_H
#ifndef FXOBJECT_H
#include "FXObject.h"
#endif
namespace FX {
/**
* A delegator forwards messages to a delegate object.
* Delegators are used when you need to multiplex messages
* toward any number of target objects.
* For example, many controls may be connected to FXDelegator,
* instead of directly to the document object. Changing the
* delegate in FXDelegator will then reconnect the controls with their
* new target.
*/
class FXAPI FXDelegator : public FXObject {
FXDECLARE(FXDelegator)
protected:
FXObject *delegate;
private:
FXDelegator(const FXDelegator&);
FXDelegator &operator=(const FXDelegator&);
public:
virtual long onDefault(FXObject*,FXSelector,void*);
public:
/// Construct a delegator
FXDelegator(FXObject* target=NULL):delegate(target){ }
/// Return delegate object
FXObject* getDelegate() const { return delegate; }
/// Change delegate object
void setDelegate(FXObject* target){ delegate=target; }
/// Always trash during detroy
virtual ~FXDelegator(){ delegate=(FXObject*)-1L; }
};
}
#endif
|