EgtMachKernel 1.6k5 :

- aggiunta gestione DB lavorazioni.
This commit is contained in:
Dario Sassi
2015-11-14 16:24:20 +00:00
parent 2a7370bde8
commit 7640eab85e
23 changed files with 1652 additions and 153 deletions
+254 -10
View File
@@ -15,7 +15,6 @@
#include "stdafx.h"
#include "SawingData.h"
#include "MachiningDataFactory.h"
#include "/EgtDev/Include/EMkMachiningConst.h"
#include "/EgtDev/Include/EmkToolConst.h"
#include "/EgtDev/Include/EGkGeoConst.h"
#include "/EgtDev/Include/EGnStringUtils.h"
@@ -61,7 +60,78 @@ static const std::array<std::string,KEY_ZZZ> sSawingKey = {
"WS"} ;
//----------------------------------------------------------------------------
MCHDATA_REGISTER( "SAWING", SawingData) ;
MCHDATA_REGISTER( MT_SAWING, "SAWING", SawingData) ;
//----------------------------------------------------------------------------
SawingData*
SawingData::Clone( void) const
{
// alloco oggetto
SawingData* pSdata = new(nothrow) SawingData ;
// copio i dati
if ( pSdata != nullptr) {
}
return pSdata ;
}
//----------------------------------------------------------------------------
bool
SawingData::CopyFrom( const MachiningData* pMdata)
{
// è inutile copiare se sorgente coincide con destinazione
if ( pMdata == this)
return true ;
// la sorgente deve essere dello stesso tipo
const SawingData* pSdata = dynamic_cast<const SawingData*>( pMdata) ;
if ( pSdata == nullptr)
return false ;
// eseguo copia
m_Uuid = pSdata->m_Uuid ;
m_sName = pSdata->m_sName ;
m_ToolUuid = pSdata->m_ToolUuid ;
m_sToolName = pSdata->m_sToolName ;
m_bInvert = pSdata->m_bInvert ;
m_nWorkSide = pSdata->m_nWorkSide ;
m_nHeadSide = pSdata->m_nHeadSide ;
m_bToAndFrom = pSdata->m_bToAndFrom ;
m_sDepth = pSdata->m_sDepth ;
m_dSideAngle = pSdata->m_dSideAngle ;
m_nLeadInType = pSdata->m_nLeadInType ;
m_nExtLinkType = pSdata->m_nExtLinkType ;
m_nLeadOutType = pSdata->m_nLeadOutType ;
m_nCurveUse = pSdata->m_nCurveUse ;
m_dApprox = pSdata->m_dApprox ;
return true ;
}
//----------------------------------------------------------------------------
bool
SawingData::SameAs(const MachiningData* pMdata) const
{
// se coincide con altro -> uguali
if ( pMdata == this)
return true ;
// se sono di tipo diverso -> diversi
const SawingData* pSdata = dynamic_cast<const SawingData*>( pMdata) ;
if ( pSdata == nullptr)
return false ;
// confronto termine a termine
return ( m_Uuid == pSdata->m_Uuid &&
m_sName == pSdata->m_sName &&
m_ToolUuid == pSdata->m_ToolUuid &&
m_sToolName == pSdata->m_sToolName &&
m_bInvert == pSdata->m_bInvert &&
m_nWorkSide == pSdata->m_nWorkSide &&
m_nHeadSide == pSdata->m_nHeadSide &&
m_bToAndFrom == pSdata->m_bToAndFrom &&
m_sDepth == pSdata->m_sDepth &&
m_dSideAngle == pSdata->m_dSideAngle &&
m_nLeadInType == pSdata->m_nLeadInType &&
m_nExtLinkType == pSdata->m_nExtLinkType &&
m_nLeadOutType == pSdata->m_nLeadOutType &&
m_nCurveUse == pSdata->m_nCurveUse &&
m_dApprox == pSdata->m_dApprox) ;
}
//----------------------------------------------------------------------------
int
@@ -107,7 +177,8 @@ SawingData::FromString( const string& sString, int& nKey)
break ;
case KEY_DH :
m_sDepth = sVal ;
bOk = ! m_sDepth.empty() ;
if ( m_sDepth.empty())
m_sDepth = "0" ;
break ;
case KEY_HS :
bOk = ::FromString( sVal, m_nHeadSide) ;
@@ -136,7 +207,6 @@ SawingData::FromString( const string& sString, int& nKey)
break ;
case KEY_TNAME :
m_sToolName = sVal ;
bOk = ! m_sToolName.empty() ;
break ;
case KEY_TUUID :
bOk = ::FromString( sVal, m_ToolUuid) ;
@@ -231,17 +301,191 @@ SawingData::VerifySideAngle( double dVal) const
//----------------------------------------------------------------------------
bool
SawingData::VerifyTool( MachMgr* pMachMgr, const std::string& sVal, const ToolData*& pTdata) const
SawingData::VerifyTool( const ToolsMgr* pToolsMgr, const std::string& sVal, const ToolData*& pTdata) const
{
if ( pMachMgr == nullptr)
if ( pToolsMgr == nullptr)
return false ;
ToolsMgr* pTMgr = pMachMgr->GetCurrToolsMgr() ;
if ( pTMgr == nullptr)
return false ;
pTdata = pTMgr->GetTool( sVal) ;
pTdata = pToolsMgr->GetTool( sVal) ;
if ( pTdata == nullptr)
return false ;
if ( ( pTdata->m_nType & TF_SAWBLADE) == 0)
return false ;
return true ;
}
//----------------------------------------------------------------------------
bool
SawingData::SetParam( int nType, bool bVal)
{
switch ( nType) {
case MPA_INVERT :
m_bInvert = bVal ;
return true ;
case MPA_TOANDFROM :
m_bToAndFrom = bVal ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::SetParam( int nType, int nVal)
{
switch ( nType) {
case MPA_WORKSIDE :
if ( ! VerifyWorkSide( nVal))
return false ;
m_nWorkSide = nVal ;
return true ;
case MPA_HEADSIDE :
if ( ! VerifyHeadSide( nVal))
return false ;
m_nHeadSide = nVal ;
return true ;
case MPA_LEADINTYPE :
if ( ! VerifyLeadInType( nVal))
return false ;
m_nLeadInType = nVal ;
return true ;
case MPA_EXTLINKTYPE :
if ( ! VerifyExtLinkType( nVal))
return false ;
m_nExtLinkType = nVal ;
return true ;
case MPA_LEADOUTTYPE :
if ( ! VerifyLeadOutType( nVal))
return false ;
m_nLeadOutType = nVal ;
return true ;
case MPA_CURVEUSE :
if ( ! VerifyCurveUse( nVal))
return false ;
m_nCurveUse = nVal ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::SetParam( int nType, double dVal)
{
switch ( nType) {
case MPA_DEPTH :
m_sDepth = ::ToString( dVal) ;
return true ;
case MPA_SIDEANGLE :
if ( ! VerifySideAngle( dVal))
return false ;
m_dSideAngle = dVal ;
return true ;
case MPA_APPROX :
m_dApprox = dVal ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::SetParam( int nType, const string& sVal)
{
switch ( nType) {
case MPA_NAME :
m_sName = sVal ;
return true ;
case MPA_TOOL :
m_sToolName = sVal ;
return true ;
case MPA_DEPTH_STR :
m_sDepth = sVal ;
return true ;
case MPA_TUUID :
return ::FromString( sVal, m_ToolUuid) ;
case MPA_UUID :
return ::FromString( sVal, m_Uuid) ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::GetParam( int nType, bool& bVal) const
{
switch ( nType) {
case MPA_INVERT :
bVal = m_bInvert ;
return true ;
case MPA_TOANDFROM :
bVal = m_bToAndFrom ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::GetParam( int nType, int& nVal) const
{
switch ( nType) {
case MPA_WORKSIDE :
nVal = m_nWorkSide ;
return true ;
case MPA_HEADSIDE :
nVal = m_nHeadSide ;
return true ;
case MPA_LEADINTYPE :
nVal = m_nLeadInType ;
return true ;
case MPA_EXTLINKTYPE :
nVal = m_nExtLinkType ;
return true ;
case MPA_LEADOUTTYPE :
nVal = m_nLeadOutType ;
return true ;
case MPA_CURVEUSE :
nVal = m_nCurveUse ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::GetParam( int nType, double& dVal) const
{
switch ( nType) {
case MPA_SIDEANGLE :
dVal = m_dSideAngle ;
return true ;
case MPA_APPROX :
dVal = m_dApprox ;
return true ;
}
return false ;
}
//----------------------------------------------------------------------------
bool
SawingData::GetParam( int nType, string& sVal) const
{
switch ( nType) {
case MPA_NAME :
sVal = m_sName ;
return true ;
case MPA_TOOL :
sVal = m_sToolName ;
return true ;
case MPA_DEPTH_STR :
sVal = m_sDepth ;
return true ;
case MPA_TUUID :
sVal = ::ToString( m_ToolUuid) ;
return true ;
case MPA_UUID :
sVal = ::ToString( m_Uuid) ;
return true ;
}
return false ;
}