Inviwo 0.9.12-pre
Inviwo documentation
Loading...
Searching...
No Matches
inviwo::FileProperty Class Reference

#include <fileproperty.h>

+ Inheritance diagram for inviwo::FileProperty:

Public Types

using value_type = std::filesystem::path
 

Public Member Functions

virtual std::string_view getClassIdentifier () const override
 
 FileProperty (std::string_view identifier, std::string_view displayName, Document help, const std::filesystem::path &value={}, AcceptMode acceptMode=AcceptMode::Open, FileMode fileMode=FileMode::AnyFile, std::string_view contentType=defaultContentType, InvalidationLevel invalidationLevel=InvalidationLevel::InvalidOutput, PropertySemantics semantics=PropertySemantics::Default)
 Constructor for the FileProperty.
 
 FileProperty (std::string_view identifier, std::string_view displayName, Document help, const std::filesystem::path &value, std::string_view contentType, InvalidationLevel invalidationLevel=InvalidationLevel::InvalidOutput, PropertySemantics semantics=PropertySemantics::Default)
 Constructor for the FileProperty.
 
 FileProperty (std::string_view identifier, std::string_view displayName, const std::filesystem::path &value={}, std::string_view contentType=defaultContentType, InvalidationLevel invalidationLevel=InvalidationLevel::InvalidOutput, PropertySemantics semantics=PropertySemantics::Default)
 Constructor for the FileProperty.
 
 FileProperty (const FileProperty &rhs)=default
 
FilePropertyoperator= (const std::filesystem::path &value)
 
virtual FilePropertyclone () const override
 
void set (const std::filesystem::path &file)
 
void set (const std::filesystem::path &file, const FileExtension &selectedExtension)
 
void set (const FileProperty *property)
 
void set (const MultiFileProperty *property)
 
virtual void set (const Property *property) override
 
 operator const std::filesystem::path & () const
 
const std::filesystem::path & get () const
 
const std::filesystem::path & operator* () const
 
const std::filesystem::path * operator-> () const
 
virtual void serialize (Serializer &s) const override
 
virtual void deserialize (Deserializer &d) override
 
virtual void requestFile ()
 
virtual Document getDescription () const override
 
virtual FilePropertysetCurrentStateAsDefault () override
 
FilePropertysetDefault (const std::filesystem::path &value)
 
virtual FilePropertyresetToDefaultState () override
 
virtual bool isDefaultState () const override
 
- Public Member Functions inherited from inviwo::Property
 Property (std::string_view identifier="", std::string_view displayName="", Document help={}, InvalidationLevel invalidationLevel=InvalidationLevel::InvalidOutput, PropertySemantics semantics=PropertySemantics::Default, ReadOnly readOnly=ReadOnly::No)
 
 Property (std::string_view identifier, std::string_view displayName, InvalidationLevel invalidationLevel, PropertySemantics semantics=PropertySemantics::Default)
 
virtual ~Property ()
 Removes itself from its PropertyOwner.
 
virtual PropertysetIdentifier (std::string_view identifier)
 
virtual const std::string & getIdentifier () const
 
const std::string & getPath () const
 Get the property path as string.
 
void getPath (std::pmr::string &out) const
 
virtual PropertysetDisplayName (std::string_view displayName)
 A property's name displayed to the user.
 
virtual const std::string & getDisplayName () const
 
virtual std::string_view getClassIdentifierForWidget () const
 Returns which property's widget should be used when the WidgetFactory tries to create a widget. Defaults to getClassIdentifier(), should only be overridden if a subclass want to reuse another property's widget.
 
virtual PropertysetSemantics (const PropertySemantics &semantics)
 
virtual PropertySemantics getSemantics () const
 
virtual PropertysetReadOnly (bool value)
 Enable or disable editing of property.
 
virtual bool getReadOnly () const
 
virtual PropertysetInvalidationLevel (InvalidationLevel invalidationLevel)
 
virtual InvalidationLevel getInvalidationLevel () const
 
virtual void setOwner (PropertyOwner *owner)
 
PropertyOwnergetOwner ()
 
const PropertyOwnergetOwner () const
 
void registerWidget (PropertyWidget *propertyWidget)
 
void deregisterWidget (PropertyWidget *propertyWidget)
 
const std::vector< PropertyWidget * > & getWidgets () const
 
void setInitiatingWidget (PropertyWidget *propertyWidget)
 
void clearInitiatingWidget ()
 
void updateWidgets ()
 
bool hasWidgets () const
 
virtual PropertysetSerializationMode (PropertySerializationMode mode)
 
virtual PropertySerializationMode getSerializationMode () const
 
virtual bool needsSerialization () const
 
virtual PropertypropertyModified ()
 
virtual void setValid ()
 
virtual PropertysetModified ()
 
virtual bool isModified () const
 
std::shared_ptr< std::function< void()> > onChangeScoped (std::function< void()> callback)
 
const BaseCallBack * onChange (std::function< void()> callback)
 
void removeOnChange (const BaseCallBack *callback)
 
virtual PropertysetVisible (bool val)
 
virtual bool getVisible () const
 
template<typename P , typename DecisionFunc >
PropertyvisibilityDependsOn (P &prop, DecisionFunc callback)
 
template<typename P , typename DecisionFunc >
PropertyreadonlyDependsOn (P &prop, DecisionFunc callback)
 
const DocumentgetHelp () const
 
DocumentgetHelp ()
 
PropertysetHelp (Document help)
 
template<typename P >
PropertyautoLinkToProperty (std::string_view propertyPath)
 
const std::vector< std::pair< std::string, std::string > > & getAutoLinkToProperty () const
 
virtual void accept (NetworkVisitor &visitor)
 Accept a NetworkVisitor, the visitor will visit this Property.
 
- Public Member Functions inherited from inviwo::Observable< PropertyObserver >
 Observable (const Observable< PropertyObserver > &other)
 
 Observable (Observable< PropertyObserver > &&other) noexcept
 
Observable< PropertyObserver > & operator= (const Observable< PropertyObserver > &other)
 
Observable< PropertyObserver > & operator= (Observable< PropertyObserver > &&other) noexcept
 
void addObserver (PropertyObserver *observer)
 
void removeObserver (PropertyObserver *observer)
 
virtual void startBlockingNotifications () override final
 
virtual void stopBlockingNotifications () override final
 
- Public Member Functions inherited from inviwo::ObservableInterface
- Public Member Functions inherited from inviwo::Serializable
- Public Member Functions inherited from inviwo::MetaDataOwner
 MetaDataOwner (const MetaDataOwner &rhs)=default
 
 MetaDataOwner (MetaDataOwner &rhs)=default
 
MetaDataOwneroperator= (const MetaDataOwner &rhs)=default
 
MetaDataOwneroperator= (MetaDataOwner &)=default
 
void copyMetaDataFrom (const MetaDataOwner &src)
 
void copyMetaDataTo (MetaDataOwner &dst)
 
template<typename T >
requires std::derived_from<T, MetaData>
T * createMetaData (std::string_view key)
 
template<typename T , typename U >
requires std::derived_from<T, MetaData> && Settable<T, U>
void setMetaData (std::string_view key, U value)
 
template<typename T >
requires std::derived_from<T, MetaData>
bool unsetMetaData (std::string_view key)
 unset, i.e. remove the metadata entry matching the given key and type
 
template<typename T , typename U >
requires std::derived_from<T, MetaData> && Gettable<T, U>
getMetaData (std::string_view key, U val) const
 
template<typename T >
requires std::derived_from<T, MetaData>
T * getMetaData (std::string_view key)
 
template<typename T >
requires std::derived_from<T, MetaData>
const T * getMetaData (std::string_view key) const
 
MetaDataMapgetMetaDataMap ()
 
const MetaDataMapgetMetaDataMap () const
 
bool hasMetaData (std::string_view key) const
 
template<typename T >
requires std::derived_from<T, MetaData>
bool hasMetaData (std::string_view key) const
 
void serialize (Serializer &s) const
 
void deserialize (Deserializer &d)
 
- Public Member Functions inherited from inviwo::FileBase
 FileBase (std::function< void()> onModified, AcceptMode acceptMode, FileMode fileMode, std::string_view contentType)
 
void addNameFilter (std::string_view filter)
 
void addNameFilter (FileExtension ext)
 
void addNameFilters (const std::vector< FileExtension > &filters)
 
void clearNameFilters ()
 
const std::vector< FileExtension > & getNameFilters () const
 
std::vector< FileExtension > & getNameFilters ()
 
bool matchesAnyNameFilter (const std::filesystem::path &file) const
 
void setAcceptMode (AcceptMode mode)
 
AcceptMode getAcceptMode () const
 
void setFileMode (FileMode mode)
 
FileMode getFileMode () const
 
void setContentType (std::string_view contentType)
 
const std::string & getContentType () const
 
const FileExtensiongetSelectedExtension () const
 
void setSelectedExtension (const FileExtension &ext)
 

Static Public Attributes

static constexpr std::string_view classIdentifier {"org.inviwo.FileProperty"}
 
- Static Public Attributes inherited from inviwo::FileBase
static constexpr std::string_view defaultContentType = "default"
 

Friends

std::ostream & operator<< (std::ostream &os, const FileProperty &prop)
 

Additional Inherited Members

- Static Public Member Functions inherited from inviwo::Property
template<typename T , typename U >
static void setStateAsDefault (T &property, const U &state)
 
- Protected Member Functions inherited from inviwo::Property
 Property (const Property &rhs)
 
Propertyoperator= (const Property &that)=delete
 
void notifyAboutChange ()
 
- Protected Member Functions inherited from inviwo::PropertyObservable
void notifyObserversOnSetIdentifier (Property *property, const std::string &identifier)
 
void notifyObserversOnSetDisplayName (Property *property, const std::string &displayName)
 
void notifyObserversOnSetSemantics (Property *property, const PropertySemantics &semantics)
 
void notifyObserversOnSetReadOnly (Property *property, bool readonly)
 
void notifyObserversOnSetVisible (Property *property, bool visible)
 
- Protected Member Functions inherited from inviwo::Observable< PropertyObserver >
void forEachObserver (C callback)
 
- Protected Member Functions inherited from inviwo::ObservableInterface
void addObservationHelper (Observer *observer)
 
void removeObservationHelper (Observer *observer)
 
- Protected Member Functions inherited from inviwo::FileBase
bool setFileBase (const FileBase &base)
 
bool updateExtension (const std::filesystem::path &file)
 
void setAsDefault ()
 
bool reset ()
 
void serialize (Serializer &s, PropertySerializationMode mode) const
 
bool deserialize (Deserializer &d, PropertySerializationMode mode)
 
std::unique_ptr< FileDialogcreateFileDialog (std::string_view title, const std::filesystem::path &file) const
 
- Static Protected Member Functions inherited from inviwo::FileBase
template<typename Arg , typename... Args>
static constexpr bool any_of (Arg &&arg, Args &&... args)
 
- Protected Attributes inherited from inviwo::Property
CallBackList onChangeCallback_
 
PropertySerializationMode serializationMode_
 
- Protected Attributes inherited from inviwo::MetaDataOwner
MetaDataMap metaData_
 
- Protected Attributes inherited from inviwo::FileBase
std::vector< FileExtensionnameFilters_
 
ValueWrapper< FileExtensionselectedExtension_
 
ValueWrapper< AcceptMode > acceptMode_
 
ValueWrapper< FileMode > fileMode_
 
ValueWrapper< std::string > contentType_
 

Detailed Description

A class for a file/directory path

Constructor & Destructor Documentation

◆ FileProperty() [1/3]

inviwo::FileProperty::FileProperty ( std::string_view identifier,
std::string_view displayName,
Document help,
const std::filesystem::path & value = {},
AcceptMode acceptMode = AcceptMode::Open,
FileMode fileMode = FileMode::AnyFile,
std::string_view contentType = defaultContentType,
InvalidationLevel invalidationLevel = InvalidationLevel::InvalidOutput,
PropertySemantics semantics = PropertySemantics::Default )

Constructor for the FileProperty.

The PropertySemantics can be set to TextEditor. Then a TextEditorWidget will be used instead of a FilePropertyWidget

Parameters
identifieridentifier for the property
displayNamedisplayName for the property
helpdescriptive text
valuethe path to the file
acceptMode
See also
AcceptMode
Parameters
fileMode
See also
FileMode
Parameters
contentType
invalidationLevel
semanticsCan be set to Editor

◆ FileProperty() [2/3]

inviwo::FileProperty::FileProperty ( std::string_view identifier,
std::string_view displayName,
Document help,
const std::filesystem::path & value,
std::string_view contentType,
InvalidationLevel invalidationLevel = InvalidationLevel::InvalidOutput,
PropertySemantics semantics = PropertySemantics::Default )

Constructor for the FileProperty.

The PropertySemantics can be set to TextEditor. Then a TextEditorWidget will be used instead of a FilePropertyWidget

Parameters
identifieridentifier for the property
displayNamedisplayName for the property
helpdescriptive text
valuethe path to the file
contentType
invalidationLevel
semanticsCan be set to Editor

◆ FileProperty() [3/3]

inviwo::FileProperty::FileProperty ( std::string_view identifier,
std::string_view displayName,
const std::filesystem::path & value = {},
std::string_view contentType = defaultContentType,
InvalidationLevel invalidationLevel = InvalidationLevel::InvalidOutput,
PropertySemantics semantics = PropertySemantics::Default )

Constructor for the FileProperty.

The PropertySemantics can be set to TextEditor. Then a TextEditorWidget will be used instead of a FilePropertyWidget

Parameters
identifieridentifier for the property
displayNamedisplayName for the property
valuethe path to the file
contentType
invalidationLevel
semanticsCan be set to Editor

Member Function Documentation

◆ clone()

virtual FileProperty * inviwo::FileProperty::clone ( ) const
overridevirtual

Creates a clone of this property. The clone will have the same identifier, hence the identifier must be changed if the clone should be added to the same owner as this. The new clone does not have any owner set.

Implements inviwo::Property.

Reimplemented in inviwo::DirectoryProperty, and inviwo::ImageEditorProperty.

◆ deserialize()

virtual void inviwo::FileProperty::deserialize ( Deserializer & d)
overridevirtual

Reimplemented from inviwo::Property.

◆ getClassIdentifier()

virtual std::string_view inviwo::FileProperty::getClassIdentifier ( ) const
overridevirtual

Implements inviwo::Property.

◆ getDescription()

virtual Document inviwo::FileProperty::getDescription ( ) const
overridevirtual

This function should describe the state of the property By default this will return a document describing all the state. i.e. Identifier, DisplayName, Help, InvalidationLevel, PropertySemantics, etc. Derived properties should extend this function and add their state, usually values etc. The description is usually shown as a tooltip in the GUI.

Reimplemented from inviwo::Property.

◆ isDefaultState()

virtual bool inviwo::FileProperty::isDefaultState ( ) const
overridevirtual

Check if the property is in it's default state, i.e. resetToDefaultState would do nothing

See also
setCurrentStateAsDefault
resetToDefaultState

Reimplemented from inviwo::Property.

◆ requestFile()

virtual void inviwo::FileProperty::requestFile ( )
virtual

Request a file from the user through the use of a widget or a FileDialog.

◆ resetToDefaultState()

virtual FileProperty & inviwo::FileProperty::resetToDefaultState ( )
overridevirtual

Reset the state of the property back to it's default value. It is important that all overriding properties make sure to call the base class implementation.

Reimplemented from inviwo::Property.

◆ serialize()

virtual void inviwo::FileProperty::serialize ( Serializer & s) const
overridevirtual

Reimplemented from inviwo::Property.

◆ set() [1/3]

virtual void inviwo::FileProperty::set ( const Property * src)
overridevirtual

Set the value of this to that of src. The "value" is in this case considered to be for example the string in a StringProperty or the float value in a FloatProperty. But not things like the identifier of display name.

Reimplemented from inviwo::Property.

◆ set() [2/3]

void inviwo::FileProperty::set ( const std::filesystem::path & file)

Set the file name and also update the selected extension to the first one matching file.

◆ set() [3/3]

void inviwo::FileProperty::set ( const std::filesystem::path & file,
const FileExtension & selectedExtension )

Set the file name and the selected extension.

◆ setCurrentStateAsDefault()

virtual FileProperty & inviwo::FileProperty::setCurrentStateAsDefault ( )
overridevirtual

Save the current state of the property as the default. This state will then be used as a reference when serializing, only state different from the default will be serialized. This method should usually only be called once directly after construction in the processor constructor after setting property specific state. It is important that all overriding properties make sure to call the base class implementation.

Reimplemented from inviwo::Property.


The documentation for this class was generated from the following file: