Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Encapsulate AppEnum to improve readability #11271

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions Fwk/AppFwk/cafProjectDataModel/cafPdmCore/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ set(PROJECT_FILES
cafAsyncObjectDeleter.inl
cafAsyncWorkerManager.h
cafAsyncWorkerManager.cpp
cafPdmEnumField.h
)

add_library(${PROJECT_NAME} ${PROJECT_FILES})
Expand Down
44 changes: 44 additions & 0 deletions Fwk/AppFwk/cafProjectDataModel/cafPdmCore/cafPdmEnumField.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@

#pragma once

#include "cafAppEnum.h"
#include "cafPdmValueField.h"

namespace caf
{
template <typename T>
class PdmEnumField : public PdmValueField
{
public:
// FieldDataType is differently than in PdmDataValueField, where the FieldDataType is defined as T.
// Similar concept is use in PdmPtrField and others.
using FieldDataType = caf::AppEnum<T>;

PdmEnumField() { static_assert( std::is_enum_v<T> == true ); };

QVariant toQVariant() const override
{
auto enumValue = static_cast<std::underlying_type_t<T>>( m_fieldValue.value() );
return enumValue;
}

void setFromQVariant( const QVariant& variant ) override { m_fieldValue = static_cast<T>( variant.toInt() ); }

bool isReadOnly() const override { return false; }

void setValue( const T& fieldValue ) { m_fieldValue = fieldValue; }

T value() const { return m_fieldValue; }

// Required to be able to assign a enum value to a PdmEnumField
PdmEnumField& operator=( T value )
{
m_fieldValue = value;
return *this;
}

private:
caf::AppEnum<T> m_fieldValue;
};

} // namespace caf
14 changes: 10 additions & 4 deletions Fwk/AppFwk/cafTests/cafTestApplication/MainWindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
#include "cafCmdFeatureMenuBuilder.h"
#include "cafFilePath.h"
#include "cafPdmDocument.h"
#include "cafPdmEnumField.h"
#include "cafPdmObject.h"
#include "cafPdmObjectGroup.h"
#include "cafPdmProxyValueField.h"
Expand Down Expand Up @@ -707,13 +708,17 @@ class SmallDemoPdmObjectA : public caf::PdmObject
"Enter some small number here",
"This is a place you can enter a small integer value if you want" );
CAF_PDM_InitField( &m_textField, "TextField", QString( "Small Demo Object A" ), "Name Text Field", "", "", "" );
CAF_PDM_InitField( &m_testEnumField,
CAF_PDM_InitField( &m_testAppEnumField,
"TestEnumValue",
caf::AppEnum<TestEnumType>( TestEnumType::T1 ),
"EnumField",
"",
"",
"" );

CAF_PDM_InitFieldNoDefault( &m_testEnumField, "TestAppEnumValue", "AppEnum Field" );
m_testEnumField = TestEnumType::T2;

CAF_PDM_InitFieldNoDefault( &m_ptrField, "m_ptrField", "PtrField", "", "", "" );

CAF_PDM_InitFieldNoDefault( &m_proxyEnumField, "ProxyEnumValue", "ProxyEnum", "", "", "" );
Expand All @@ -731,7 +736,8 @@ class SmallDemoPdmObjectA : public caf::PdmObject
caf::PdmField<double> m_doubleField;
caf::PdmField<int> m_intField;
caf::PdmField<QString> m_textField;
caf::PdmField<caf::AppEnum<TestEnumType>> m_testEnumField;
caf::PdmField<caf::AppEnum<TestEnumType>> m_testAppEnumField;
caf::PdmEnumField<TestEnumType> m_testEnumField;
caf::PdmPtrField<SmallDemoPdmObjectA*> m_ptrField;

caf::PdmProxyValueField<caf::AppEnum<TestEnumType>> m_proxyEnumField;
Expand Down Expand Up @@ -817,7 +823,7 @@ class SmallDemoPdmObjectA : public caf::PdmObject
// See PdmUiFieldSpecialization<caf::AppEnum<T>>
auto enumValue = static_cast<std::underlying_type_t<TestEnumType>>( value );

m_testEnumField.uiCapability()->enableAndSetAutoValue( enumValue );
m_testAppEnumField.uiCapability()->enableAndSetAutoValue( enumValue );
}

void enableAutoValueForDouble( double value ) { m_doubleField.uiCapability()->enableAndSetAutoValue( value ); }
Expand All @@ -830,7 +836,7 @@ class SmallDemoPdmObjectA : public caf::PdmObject
// See PdmUiFieldSpecialization<caf::AppEnum<T>>
auto enumValue = static_cast<std::underlying_type_t<TestEnumType>>( value );

m_testEnumField.uiCapability()->setAutoValue( enumValue );
m_testAppEnumField.uiCapability()->setAutoValue( enumValue );
}

void setAutoValueForDouble( double value )
Expand Down
1 change: 0 additions & 1 deletion Fwk/AppFwk/cafTests/cafTestApplication/TamComboBox.h
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@

#pragma once

#include "cafAppEnum.h"
#include "cafPdmField.h"
#include "cafPdmObject.h"

Expand Down
Loading