mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-05-01 10:26:12 +03:00
Update empty method guards to new style with regex (see PR). Used clang-format 18.1.8. New actions to validate code formatting is added. Update .clang-format with disabling of include sorting. It is temporary changes, then include will be sorted. Apply formatting for /src and /tools folder. The files with .hxx,.cxx,.lxx,.h,.pxx,.hpp,*.cpp extensions.
156 lines
4.9 KiB
C++
156 lines
4.9 KiB
C++
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <Interface_EntityIterator.hxx>
|
|
#include <Interface_GeneralModule.hxx>
|
|
#include <Interface_Graph.hxx>
|
|
#include <Interface_GTool.hxx>
|
|
#include <Interface_InterfaceModel.hxx>
|
|
#include <Interface_Protocol.hxx>
|
|
#include <Interface_ReportEntity.hxx>
|
|
#include <Interface_ShareFlags.hxx>
|
|
#include <Standard_DomainError.hxx>
|
|
#include <Standard_Transient.hxx>
|
|
|
|
Interface_ShareFlags::Interface_ShareFlags(const Handle(Interface_InterfaceModel)& amodel,
|
|
const Interface_GeneralLib& lib)
|
|
: theflags(amodel->NbEntities())
|
|
{
|
|
Handle(Interface_GTool) gtool; // null
|
|
themodel = amodel;
|
|
Evaluate(lib, gtool);
|
|
}
|
|
|
|
Interface_ShareFlags::Interface_ShareFlags(const Handle(Interface_InterfaceModel)& amodel,
|
|
const Handle(Interface_GTool)& gtool)
|
|
: theflags(amodel->NbEntities())
|
|
{
|
|
themodel = amodel;
|
|
Evaluate(gtool->Lib(), gtool);
|
|
}
|
|
|
|
Interface_ShareFlags::Interface_ShareFlags(const Handle(Interface_InterfaceModel)& amodel,
|
|
const Handle(Interface_Protocol)& protocol)
|
|
: theflags(amodel->NbEntities())
|
|
{
|
|
Handle(Interface_GTool) gtool; // null
|
|
themodel = amodel;
|
|
Evaluate(Interface_GeneralLib(protocol), gtool);
|
|
}
|
|
|
|
Interface_ShareFlags::Interface_ShareFlags(const Handle(Interface_InterfaceModel)& amodel)
|
|
: theflags(amodel->NbEntities())
|
|
{
|
|
Handle(Interface_GTool) gtool = themodel->GTool();
|
|
gtool->Reservate(amodel->NbEntities());
|
|
themodel = amodel;
|
|
Evaluate(gtool->Lib(), gtool);
|
|
}
|
|
|
|
Interface_ShareFlags::Interface_ShareFlags(const Interface_Graph& agraph)
|
|
: theflags(agraph.Model()->NbEntities())
|
|
{
|
|
themodel = agraph.Model();
|
|
Standard_Integer nb = themodel->NbEntities();
|
|
if (nb == 0)
|
|
return;
|
|
theroots = new TColStd_HSequenceOfTransient();
|
|
for (Standard_Integer i = 1; i <= nb; i++)
|
|
{
|
|
// Resultat obtenu depuis le Graph
|
|
Handle(Standard_Transient) ent = themodel->Value(i);
|
|
Handle(TColStd_HSequenceOfTransient) list = agraph.GetSharings(ent);
|
|
|
|
if (!list.IsNull() && list->Length() > 0)
|
|
theflags.SetTrue(i);
|
|
else
|
|
theroots->Append(ent);
|
|
}
|
|
}
|
|
|
|
void Interface_ShareFlags::Evaluate(const Interface_GeneralLib& lib,
|
|
const Handle(Interface_GTool)& gtool)
|
|
{
|
|
Standard_Boolean patool = gtool.IsNull();
|
|
Standard_Integer nb = themodel->NbEntities();
|
|
if (nb == 0)
|
|
return;
|
|
theroots = new TColStd_HSequenceOfTransient();
|
|
Standard_Integer i; // svv Jan11 2000 : porting on DEC
|
|
for (i = 1; i <= nb; i++)
|
|
{
|
|
|
|
// ATTENTION : Si Entite non chargee donc illisible, basculer sur son
|
|
// "Contenu" equivalent
|
|
Handle(Standard_Transient) ent = themodel->Value(i);
|
|
if (themodel->IsRedefinedContent(i))
|
|
ent = themodel->ReportEntity(i)->Content();
|
|
|
|
// Resultat obtenu via GeneralLib
|
|
Interface_EntityIterator iter;
|
|
Handle(Interface_GeneralModule) module;
|
|
Standard_Integer CN;
|
|
if (patool)
|
|
{
|
|
if (lib.Select(ent, module, CN))
|
|
module->FillShared(themodel, CN, ent, iter);
|
|
}
|
|
else
|
|
{
|
|
if (gtool->Select(ent, module, CN))
|
|
module->FillShared(themodel, CN, ent, iter);
|
|
}
|
|
|
|
// Entites partagees par <ent> : reste a noter chacune comme "Shared"
|
|
for (iter.Start(); iter.More(); iter.Next())
|
|
{
|
|
Standard_Integer num = themodel->Number(iter.Value());
|
|
theflags.SetTrue(num); // Et Voila
|
|
}
|
|
}
|
|
for (i = 1; i <= nb; i++)
|
|
{
|
|
if (!theflags.Value(i))
|
|
theroots->Append(themodel->Value(i));
|
|
}
|
|
}
|
|
|
|
Handle(Interface_InterfaceModel) Interface_ShareFlags::Model() const
|
|
{
|
|
return themodel;
|
|
}
|
|
|
|
Standard_Boolean Interface_ShareFlags::IsShared(const Handle(Standard_Transient)& ent) const
|
|
{
|
|
Standard_Integer num = themodel->Number(ent);
|
|
if (num == 0 || num > themodel->NbEntities())
|
|
throw Standard_DomainError("Interface ShareFlags : IsShared");
|
|
return theflags.Value(num);
|
|
}
|
|
|
|
Interface_EntityIterator Interface_ShareFlags::RootEntities() const
|
|
{
|
|
Interface_EntityIterator iter(theroots);
|
|
return iter;
|
|
}
|
|
|
|
Standard_Integer Interface_ShareFlags::NbRoots() const
|
|
{
|
|
return (theroots.IsNull() ? 0 : theroots->Length());
|
|
}
|
|
|
|
Handle(Standard_Transient) Interface_ShareFlags::Root(const Standard_Integer num) const
|
|
{
|
|
return theroots->Value(num);
|
|
}
|