mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
Add preferences setting for maximum search depth in script folders. Clean up context menu a bit. (#9012)
This commit is contained in:
@@ -37,7 +37,7 @@ RimCalcScript::RimCalcScript()
|
||||
CAF_PDM_InitObject( "CalcScript", ":/OctaveScriptFile16x16.png", "Calc Script", "" );
|
||||
|
||||
CAF_PDM_InitField( &absoluteFileName, "AbsolutePath", QString(), "Location" );
|
||||
|
||||
absoluteFileName.uiCapability()->setUiReadOnly( true );
|
||||
absoluteFileName.uiCapability()->setUiEditorTypeName( caf::PdmUiFilePathEditor::uiEditorTypeName() );
|
||||
}
|
||||
|
||||
|
||||
@@ -376,7 +376,7 @@ bool RimProject::writeProjectFile()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
/// Support list of multiple script paths divided by ';'
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimProject::setScriptDirectories( const QString& scriptDirectories )
|
||||
void RimProject::setScriptDirectories( const QString& scriptDirectories, int maxFolderDepth )
|
||||
{
|
||||
scriptCollection->calcScripts().deleteChildren();
|
||||
scriptCollection->subDirectories().deleteChildren();
|
||||
@@ -391,7 +391,7 @@ void RimProject::setScriptDirectories( const QString& scriptDirectories )
|
||||
sharedScriptLocation->directory = path;
|
||||
sharedScriptLocation->setUiName( dir.dirName() );
|
||||
|
||||
sharedScriptLocation->readContentFromDisc();
|
||||
sharedScriptLocation->readContentFromDisc( maxFolderDepth );
|
||||
|
||||
scriptCollection->subDirectories.push_back( sharedScriptLocation );
|
||||
}
|
||||
|
||||
@@ -113,7 +113,7 @@ public:
|
||||
|
||||
bool writeProjectFile();
|
||||
|
||||
void setScriptDirectories( const QString& scriptDirectories );
|
||||
void setScriptDirectories( const QString& scriptDirectories, int maxFolderDepth );
|
||||
void setPlotTemplateFolders( const QStringList& plotTemplateFolders );
|
||||
|
||||
QString projectFileVersionString() const;
|
||||
|
||||
@@ -38,14 +38,13 @@ RimScriptCollection::RimScriptCollection()
|
||||
CAF_PDM_InitObject( "ScriptLocation", ":/Folder.png" );
|
||||
|
||||
CAF_PDM_InitFieldNoDefault( &directory, "ScriptDirectory", "Folder" );
|
||||
directory.uiCapability()->setUiReadOnly( true );
|
||||
directory.uiCapability()->setUiEditorTypeName( caf::PdmUiFilePathEditor::uiEditorTypeName() );
|
||||
|
||||
CAF_PDM_InitFieldNoDefault( &calcScripts, "CalcScripts", "" );
|
||||
calcScripts.uiCapability()->setUiTreeHidden( true );
|
||||
CAF_PDM_InitFieldNoDefault( &subDirectories, "SubDirectories", "" );
|
||||
subDirectories.uiCapability()->setUiTreeHidden( true );
|
||||
|
||||
CAF_PDM_InitField( &m_searchSubFolders, "SearchSubFolders", false, "Add Subfolders" );
|
||||
|
||||
directory.uiCapability()->setUiEditorTypeName( caf::PdmUiFilePathEditor::uiEditorTypeName() );
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@@ -60,15 +59,19 @@ RimScriptCollection::~RimScriptCollection()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimScriptCollection::readContentFromDisc()
|
||||
void RimScriptCollection::readContentFromDisc( int folderLevelsLeft )
|
||||
{
|
||||
calcScripts.deleteChildren();
|
||||
subDirectories.deleteChildren();
|
||||
|
||||
folderLevelsLeft--;
|
||||
if ( folderLevelsLeft < 0 ) return;
|
||||
|
||||
if ( directory().isEmpty() )
|
||||
{
|
||||
for ( size_t i = 0; i < subDirectories.size(); ++i )
|
||||
{
|
||||
if ( subDirectories[i] ) subDirectories[i]->readContentFromDisc();
|
||||
if ( subDirectories[i] ) subDirectories[i]->readContentFromDisc( folderLevelsLeft );
|
||||
}
|
||||
return;
|
||||
}
|
||||
@@ -104,9 +107,7 @@ void RimScriptCollection::readContentFromDisc()
|
||||
}
|
||||
}
|
||||
|
||||
subDirectories.deleteChildren();
|
||||
|
||||
if ( m_searchSubFolders() )
|
||||
if ( folderLevelsLeft > 0 )
|
||||
{
|
||||
QDir dir( directory );
|
||||
QFileInfoList fileInfoList = dir.entryInfoList( QDir::AllDirs | QDir::NoDotAndDotDot | QDir::Readable );
|
||||
@@ -120,7 +121,7 @@ void RimScriptCollection::readContentFromDisc()
|
||||
RimScriptCollection* scriptLocation = new RimScriptCollection;
|
||||
scriptLocation->directory = fi.absoluteFilePath();
|
||||
scriptLocation->setUiName( fi.baseName() );
|
||||
scriptLocation->readContentFromDisc();
|
||||
scriptLocation->readContentFromDisc( folderLevelsLeft );
|
||||
|
||||
subDirectories.push_back( scriptLocation );
|
||||
}
|
||||
@@ -128,25 +129,6 @@ void RimScriptCollection::readContentFromDisc()
|
||||
}
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimScriptCollection::fieldChangedByUi( const caf::PdmFieldHandle* changedField,
|
||||
const QVariant& oldValue,
|
||||
const QVariant& newValue )
|
||||
{
|
||||
if ( &directory == changedField )
|
||||
{
|
||||
QFileInfo fi( directory );
|
||||
this->setUiName( fi.baseName() );
|
||||
this->readContentFromDisc();
|
||||
}
|
||||
else if ( &m_searchSubFolders == changedField )
|
||||
{
|
||||
this->readContentFromDisc();
|
||||
}
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
|
||||
@@ -43,23 +43,17 @@ public:
|
||||
RimScriptCollection();
|
||||
~RimScriptCollection() override;
|
||||
|
||||
public: // Pdm Fields
|
||||
public:
|
||||
caf::PdmField<QString> directory;
|
||||
caf::PdmChildArrayField<RimCalcScript*> calcScripts;
|
||||
|
||||
caf::PdmChildArrayField<RimScriptCollection*> subDirectories;
|
||||
|
||||
public: // Methods
|
||||
void readContentFromDisc();
|
||||
|
||||
// Overrides from PdmObject
|
||||
void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override;
|
||||
public:
|
||||
void readContentFromDisc( int folderLevelsLeft );
|
||||
|
||||
protected:
|
||||
void defineEditorAttribute( const caf::PdmFieldHandle* field,
|
||||
QString uiConfigName,
|
||||
caf::PdmUiEditorAttribute* attribute ) override;
|
||||
|
||||
private:
|
||||
caf::PdmField<bool> m_searchSubFolders;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user