// -*- mode:C++; tab-width:2; c-basic-offset:2; indent-tabs-mode:nil -*-
//
// Copyright (C) 2000-2005 by Roger Rene Kommer / artefaktur, Kassel, Germany.
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Library General Public License (LGPL).
//
//
// 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
// License ACDK-FreeLicense document enclosed in the distribution
// for more for more details.
// This file is part of the Artefaktur Component Development Kit:
// ACDK
//
// Please refer to
// - http://www.acdk.de
// - http://www.artefaktur.com
// - http://acdk.sourceforge.net
// for more information.
//
#ifndef acdk_tools_mc_ClazzNameAttribute_h
#define acdk_tools_mc_ClazzNameAttribute_h
#include "mc.h"
#include "CodeAttribute.h"
namespace acdk {
namespace tools {
namespace mc {
ACDK_DECL_CLASS(ClazzNameAttribute);
/**
This attribute can be used to set the
name of a MetaInfo to given name.
It may be useable to export a given
class, field, method, argument with
another name via DMI than implemented in
ACDK C++.
*/
class ACDK_TOOLS_MC_PUBLIC ClazzNameAttribute
: extends CodeAttribute
{
ACDK_WITH_METAINFO(ClazzNameAttribute)
public:
RString _name;
ClazzNameAttribute(IN(RString) name = "");
static void initAttribute(IN(RMetaCompiler) mc); // will be called via DMI
foreign virtual bool apply(IN(RCodeInfo) cm);
foreign virtual bool apply(IN(RModuleInfo) cm);
foreign virtual bool apply(IN(RClassInfo) cm);
foreign virtual bool apply(IN(RMethodInfo) cm);
foreign virtual bool apply(IN(RArgumentInfo) cm);
foreign virtual bool apply(IN(RFieldInfo) cm);
foreign bool attachAttribute(IN(RCodeInfo) ci);
};
} // namespace mc
} // namespace tools
} // namespace acdk
#endif //acdk_tools_mc_ClazzNameAttribute_h |