1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-09 18:50:54 +03:00
occt/src/Interface/Interface_ParamSet.cxx
aml b9280b8b27 0032969: Coding - get rid of unused headers [IMeshData to PLib]
Removed unused exception classes OSD_Exception_FLT_DIVIDE_BY_ZERO, OSD_Exception_INT_DIVIDE_BY_ZERO, OSD_Exception_FLT_DENORMAL_OPERAND, OSD_Exception_FLT_INEXACT_RESULT, OSD_Exception_FLT_INVALID_OPERATION, OSD_Exception_FLT_OVERFLOW, OSD_Exception_FLT_STACK_CHECK, OSD_Exception_FLT_UNDERFLOW.
2022-05-17 20:09:12 +03:00

160 lines
5.5 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.
//szv#4 S4163
#include <Interface_FileParameter.hxx>
#include <Interface_ParamList.hxx>
#include <Interface_ParamSet.hxx>
#include <Standard_Type.hxx>
IMPLEMENT_STANDARD_RTTIEXT(Interface_ParamSet,Standard_Transient)
Interface_ParamSet::Interface_ParamSet (const Standard_Integer nres, const Standard_Integer )//nst)
{
thelist = new Interface_ParamList;// (nst,nst+nres+2);
themxpar = nres;
thenbpar = 0;
thelnval = 0;
thelnres = 100; // *20; // 10 caracteres par Param (\0 inclus) : raisonnable
theval = new char[thelnres]; //szv#4:S4163:12Mar99 `thelnres+1` chars was wrong
}
// Append(CString) : Gestion des caracteres selon <lnval>
// Si lnval < 0, ParamSet passif, memoire geree de l exterieur, ParamSet
// se contente de s y referer
// Sinon, recopie dans une page locale
Standard_Integer Interface_ParamSet::Append (const Standard_CString val, const Standard_Integer lnval,
const Interface_ParamType typ, const Standard_Integer nument)
{
// Ici, gestion locale de String
thenbpar ++;
if (thenbpar > themxpar) {
thenext = new Interface_ParamSet (themxpar,1);
return (thenbpar + thenext->Append(val,lnval,typ,nument));
}
else if (lnval < 0) {
// .. Gestion externe des caracteres ..
Interface_FileParameter& FP = thelist->ChangeValue(thenbpar);
FP.Init(val,typ);
if (nument != 0) FP.SetEntityNumber(nument);
}
else {
// .. Gestion locale des caracteres ..
Standard_Integer i;
if (thelnval + lnval + 1 > thelnres) {
// Reservation de caracteres insuffisante : d abord augmenter
Standard_Integer newres = (Standard_Integer)(thelnres*2 + lnval);
char* newval = new char[newres];
for (i = 0; i < thelnval; i++)
newval[i] = theval[i]; //szv#4:S4163:12Mar99 `<= thelnres` was wrong
// et cepatou : il faut realigner les Params deja enregistres sur
// l ancienne reservation de caracteres ...
//Standard_Integer delta = (Standard_Integer) (newval - theval);
// difference a appliquer
char* poldVal = &theval[0];
char* pnewVal= &newval[0];
for (i = 1; i < thenbpar; i ++) {
Interface_FileParameter& OFP = thelist->ChangeValue(i);
Interface_ParamType otyp = OFP.ParamType();
char* oval = (char*)OFP.CValue();
Standard_Integer delta = (Standard_Integer) (oval - poldVal);
//if (oval < theval || oval >= (theval+thelnres))
// continue; //hors reserve //szv#4:S4163:12Mar99 `oval >` was wrong
Standard_Integer onum = OFP.EntityNumber();
OFP.Init(pnewVal+delta,otyp); // et voila; on remet dans la boite
if (onum != 0) OFP.SetEntityNumber(onum);
}
// Enteriner la nouvelle reservation
delete [] theval;
theval = newval;
thelnres = newres;
}
// Enregistrer ce parametre
for (i = 0; i < lnval; i ++) theval[thelnval + i] = val[i];
theval[thelnval+lnval] = '\0';
Interface_FileParameter& FP = thelist->ChangeValue(thenbpar);
FP.Init(&theval[thelnval],typ);
if (nument != 0) FP.SetEntityNumber(nument);
thelnval += (Standard_Integer)(lnval+1);
}
return thenbpar;
}
Standard_Integer Interface_ParamSet::Append (const Interface_FileParameter& FP)
{
// Ici, FP tout pret : pas de gestion memoire sur String (dommage)
thenbpar ++;
if (thenbpar > themxpar) {
thenext = new Interface_ParamSet (themxpar,1);
return thenbpar + thenext->Append(FP);
}
thelist->SetValue(thenbpar,FP);
return thenbpar;
}
Standard_Integer Interface_ParamSet::NbParams () const
{ return thenbpar; }
const Interface_FileParameter& Interface_ParamSet::Param (const Standard_Integer num) const
{
if (num > themxpar) return thenext->Param(num - themxpar);
else return thelist->Value(num);
}
Interface_FileParameter& Interface_ParamSet::ChangeParam (const Standard_Integer num)
{
if (num > themxpar) return thenext->ChangeParam(num - themxpar);
else return thelist->ChangeValue(num);
}
void Interface_ParamSet::SetParam (const Standard_Integer num, const Interface_FileParameter& FP)
{
if (num > themxpar) thenext->SetParam(num - themxpar, FP);
else thelist->SetValue(num,FP);
}
Handle(Interface_ParamList) Interface_ParamSet::Params (const Standard_Integer num,
const Standard_Integer nb) const
{
Standard_Integer i, n0 = num-1, nbp = nb;
if (num > themxpar)
return thenext->Params (num-themxpar,nb);
if (num == 0 && nb == 0) {
n0 = 0; nbp = thenbpar;
if (thenbpar <= themxpar)
return thelist; // et zou
}
Handle(Interface_ParamList) list = new Interface_ParamList;
if (nb == 0)
return list;
for (i = 1; i <= nbp; i ++) list->SetValue(i,Param(n0+i));
return list;
}
void Interface_ParamSet::Destroy ()
{
// if (!thenext.IsNull()) thenext->Destroy();
thenext.Nullify();
// Destruction "manuelle" (gestion memoire directe)
if (theval) delete [] theval;
theval = NULL;
thelist->Clear();
thelist.Nullify();
}