/* * $Id$ */ /* * Harbour Project source code: * Header file for Class commands * * Copyright 1999 Antonio Linares * www - http://www.harbour-project.org * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version, with one exception: * * The exception is that if you link the Harbour Runtime Library (HRL) * and/or the Harbour Virtual Machine (HVM) with other files to produce * an executable, this does not by itself cause the resulting executable * to be covered by the GNU General Public License. Your use of that * executable is in no way restricted on account of linking the HRL * and/or HVM code into it. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA (or visit * their web site at http://www.gnu.org/). * */ #ifndef HB_CLASS_CH_ #define HB_CLASS_CH_ #xcommand CLASS [ ] => ; function () ;; static oClass ;; if oClass == nil ;; oClass = TClass():New( <(ClassName)> [,<(SuperClass)>] ) ;; #define _CLASS_NAME_ ;; #translate CLSMETH () => @_() ; [ ; #translate Super : => ::: ] ; [ ; extern ] #xcommand DATA [,] [ AS ] [ INIT ] => ; [ oClass:SetType( <(type)> ) ; ][ oClass:SetInit( ) ; ] ; oClass:AddData( <(DataName1)> ) ; [; oClass:AddData( <(DataNameN)> ) ] ; [; oClass:SetInit(,) ] [ ; oClass:SetType(,<(type)>) ] // Note the use of commas ',' on the above two rules to avoid their call // if there are no AS ... or INIT clauses specified. As we just use // those methods first parameter, the second one supplied acts as a dummy one #xcommand CLASSDATA [,] [ AS ] [ INIT ] => ; [ oClass:SetType( <(type)> ) ; ][ oClass:SetInit( ) ; ] ; oClass:AddClassData( <(DataName1)> ) ; [; oClass:AddClassData( <(DataNameN)> ) ] ; [; oClass:SetInit(,) ] [ ; oClass:SetType(,<(type)>) ] // Note the use of commas ',' on the above two rules to avoid their call // if there are no AS ... or INIT clauses specified. As we just use // those methods first parameter, the second one supplied acts as a dummy one #xcommand METHOD ( [] ) [ CONSTRUCTOR ] => ; oClass:AddMethod( <(MethodName)>, CLSMETH _CLASS_NAME_ () ) #xcommand METHOD ( [] ) BLOCK => ; oClass:AddInline( <(MethodName)>, ) #xcommand METHOD ( [] ) EXTERN ( [] ) => ; oClass:AddMethod( <(MethodName)>, @() ) #xcommand METHOD ( [] ) INLINE => ; oClass:AddInline( <(MethodName)>, {|Self [,] | } ) #xcommand METHOD ( [] ) VIRTUAL => ; oClass:AddVirtual( <(MethodName)> ) #xcommand METHOD ( [] ) SETGET => ; oClass:AddMethod( <(MethodName)>, CLSMETH _CLASS_NAME_ () ) ;; oClass:AddMethod( "_" + <(MethodName)>, CLSMETH _CLASS_NAME_ () ) #xcommand METHOD ( [] ) OPERATOR => ; oClass:AddMethod( <(MethodName)>, CLSMETH _CLASS_NAME_ () ) ;; oClass:AddInline( <(op)>, {|Self [,] | ::( [] ) } ) #xcommand MESSAGE METHOD ( [] ) => ; oClass:AddMethod( <(MessageName)>, CLSMETH _CLASS_NAME_ () ) #xcommand MESSAGE () METHOD ( [] ) => ; oClass:AddMethod( <(MessageName)>, CLSMETH _CLASS_NAME_ () ) #xcommand ENDCLASS => oClass:Create() ;; endif ;; return oClass:Instance() #xcommand METHOD ( [] ) CLASS => ; static function _( [] ) ;; local Self := QSelf() #endif /* HB_CLASS_CH_ */