|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T i
Length: 6151 (0x1807)
Types: TextFile
Names: »ibrect.c«
└─⟦8648bda34⟧ Bits:30007244 EUUGD5_II: X11R5
└─⟦87c3ac0e0⟧ »./contrib-3/contrib-3.00«
└─⟦de8ce1454⟧
└─⟦this⟧ »contrib/lib/iv/src/bin/ibuild/ibrect.c«
/*
* Copyright (c) 1991 Stanford University
*
* Permission to use, copy, modify, distribute, and sell this software and its
* documentation for any purpose is hereby granted without fee, provided
* that the above copyright notice appear in all copies and that both that
* copyright notice and this permission notice appear in supporting
* documentation, and that the name of Stanford not be used in advertising or
* publicity pertaining to distribution of the software without specific,
* written prior permission. Stanford makes no representations about
* the suitability of this software for any purpose. It is provided "as is"
* without express or implied warranty.
*
* STANFORD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
* IN NO EVENT SHALL STANFORD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
* DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/*
* IRect component definitions.
*/
#include "ibrect.h"
#include "ibclasses.h"
#include "ibvars.h"
#include <Unidraw/Graphic/polygons.h>
#include <stream.h>
#include <string.h>
/*****************************************************************************/
static const char* rectcomp_delim = "%rectcomp_delim";
/*****************************************************************************/
IRectComp::IRectComp (SF_Rect* graphic) {
GetClassNameVar()->SetName("SF_Rect");
GetClassNameVar()->SetBaseClass("SF_Rect");
if (!_release || graphic != nil) {
_target = new RectComp(graphic);
if (graphic != nil) {
Append(_target);
}
}
}
ClassId IRectComp::GetClassId () { return IRECT_COMP; }
ClassId IRectComp::GetSubstId(const char*& delim) {
delim = rectcomp_delim;
return RECT_COMP;
}
boolean IRectComp::IsA (ClassId id) {
return IRECT_COMP == id || IComp::IsA(id);
}
/*****************************************************************************/
ClassId RectCode::GetClassId () { return IRECT_CODE; }
boolean RectCode::IsA(ClassId id) {
return IRECT_CODE == id || CodeView::IsA(id);
}
RectCode::RectCode (IRectComp* subj) : CodeView(subj) {}
void RectCode::Update () {
CodeView::Update();
GetIRectComp()->Bequeath();
}
IRectComp* RectCode::GetIRectComp () {
return (IRectComp*) GetSubject();
}
boolean RectCode::Definition (ostream& out) {
boolean ok = true;
IRectComp* rectcomp = GetIRectComp();
RectComp* target = (RectComp*) rectcomp->GetTarget();
SF_Rect* rectgr= target->GetRect();
SubclassNameVar* snamer = rectcomp->GetClassNameVar();
MemberNameVar* mnamer = rectcomp->GetMemberNameVar();
const char* mname = mnamer->GetName();
const char* subclass = snamer->GetName();
if (_emitGraphicState) {
ok = WriteGraphicDecls(rectgr, out);
} else if (
_emitInstanceDecls || _emitForward ||
_emitClassHeaders || _emitHeaders
) {
ok = CodeView::Definition(out);
if (_emitInstanceDecls && _emitGraphicComp && !_emitExport) {
out << " RectComp* " << mname << "_comp;\n";
}
} else if (_emitExpHeader) {
if (!snamer->IsSubclass()) {
if (
_scope && mnamer->GetExport() &&
!_namelist->Search("polygons")
) {
_namelist->Append("polygons");
out << "#include <Unidraw/Graphic/polygons.h> \n";
}
} else {
ok = CodeView::Definition(out);
}
} else if (_emitCorehHeader) {
if (snamer->IsSubclass() && strcmp(subclass, _classname) == 0) {
if (!_namelist->Search("polygons")) {
_namelist->Append("polygons");
out << "#include <Unidraw/Graphic/polygons.h> \n";
}
}
} else if (_emitInstanceInits) {
Coord x0, y0, x1, y1;
rectgr->GetOriginal(x0, y0, x1, y1);
out << " {\n";
out << " " << mname << " = new " << subclass << "(";
out << x0 << ", " << y0 << ", " << x1 << ", " << y1 << ");\n";
ok = WriteGraphicInits(rectgr, out);
if (_emitGraphicComp) {
out << " " << mname << "_comp = new RectComp(";
out << mname << ");\n";
}
out << " }\n";
} else if (
_emitCoreDecls || _emitCoreInits || _emitClassDecls || _emitClassInits
) {
ok = ok && CodeView::Definition(out);
}
return ok && out.good();
}
boolean RectCode::CoreConstDecls(ostream& out) {
out << "(Coord x0, Coord y0, Coord x1, Coord y1, Graphic* = nil);\n";
return out.good();
}
boolean RectCode::CoreConstInits(ostream& out) {
IComp* icomp = GetIComp();
SubclassNameVar* snamer = icomp->GetClassNameVar();
const char* baseclass = snamer->GetBaseClass();
out <<"(\n Coord x0, Coord y0, Coord x1, Coord y1, Graphic* gr\n) : ";
out << baseclass << "(x0, y0, x1, y1, gr) {}\n\n";
return out.good();
}
boolean RectCode::ConstDecls(ostream& out) {
out << "(Coord x0, Coord y0, Coord x1, Coord y1, Graphic* = nil);\n";
return out.good();
}
boolean RectCode::ConstInits(ostream& out) {
char coreclass[CHARBUFSIZE];
GetCoreClassName(coreclass);
out <<"(\n Coord x0, Coord y0, Coord x1, Coord y1, Graphic* gr\n) : ";
out << coreclass << "(x0, y0, x1, y1, gr) {}\n\n";
return out.good();
}
boolean RectCode::EmitIncludeHeaders(ostream& out) {
SubclassNameVar* snamer = GetIComp()->GetClassNameVar();
if (!snamer->IsSubclass() && !_namelist->Search("polygons")) {
_namelist->Append("polygons");
out << "#include <Unidraw/Graphic/polygons.h> \n";
}
if (
strcmp(snamer->GetName(), _classname) != 0 &&
!_namelist->Search("rect") && _emitGraphicComp
) {
_namelist->Append("rect");
out << "#include <Unidraw/Components/rect.h> \n";
}
return out.good();
}