1
0
Fork 0
mirror of https://github.com/juce-framework/JUCE.git synced 2026-01-11 23:54:18 +00:00
JUCE/extras/Projucer/Source/Project/jucer_DependencyPathPropertyComponent.h

183 lines
6.5 KiB
C++

/*
==============================================================================
This file is part of the JUCE library.
Copyright (c) 2017 - ROLI Ltd.
JUCE is an open source library subject to commercial or open-source
licensing.
By using JUCE, you agree to the terms of both the JUCE 5 End-User License
Agreement and JUCE 5 Privacy Policy (both updated and effective as of the
27th April 2017).
End User License Agreement: www.juce.com/juce-5-licence
Privacy Policy: www.juce.com/juce-5-privacy-policy
Or: You may also use this code under the terms of the GPL v3 (see
www.gnu.org/licenses).
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
DISCLAIMED.
==============================================================================
*/
#pragma once
//==============================================================================
/** This ValueSource type implements the fallback logic required for dependency
path settings: use the project exporter value; if this is empty, fall back to
the global preference value; if the exporter is supposed to run on another
OS and we don't know what the global preferences on that other machine are,
fall back to a generic OS-specific fallback value.
*/
class DependencyPathValueSource : public Value::ValueSource,
private Value::Listener
{
public:
DependencyPathValueSource (const Value& projectSettingsPath,
Identifier globalSettingsKey,
DependencyPathOS osThisSettingAppliesTo);
/** This gets the currently used value, which may be either
the project setting, the global setting, or the fallback value. */
var getValue() const override
{
if (isUsingProjectSettings())
return projectSettingsValue.getValue();
if (isUsingGlobalSettings())
return globalSettingsValue.getValue();
return fallbackValue;
}
void setValue (const var& newValue) override
{
projectSettingsValue = newValue;
if (isUsingProjectSettings())
sendChangeMessage (false);
}
bool isUsingProjectSettings() const
{
return projectSettingsValueIsValid();
}
bool isUsingGlobalSettings() const
{
return ! projectSettingsValueIsValid() && globalSettingsValueIsValid();
}
bool isUsingFallbackValue() const
{
return ! projectSettingsValueIsValid() && !globalSettingsValueIsValid();
}
bool appliesToThisOS() const
{
return os == TargetOS::getThisOS();
}
bool isValidPath (const File& relativeTo) const;
bool isValidPath() const;
private:
void valueChanged (Value& value) override
{
if ((value.refersToSameSourceAs (globalSettingsValue) && isUsingGlobalSettings()))
{
sendChangeMessage (true);
setValue (String()); // make sure that the project-specific value is still blank
}
}
/** This defines when to use the project setting, and when to
consider it invalid and to fall back to the global setting or
the fallback value. */
bool projectSettingsValueIsValid() const
{
return ! projectSettingsValue.toString().isEmpty();
}
/** This defines when to use the global setting - given the project setting
is invalid, and when to fall back to the fallback value instead. */
bool globalSettingsValueIsValid() const
{
// only use the global settings if they are set on the same OS
// that this setting is for!
DependencyPathOS thisOS = TargetOS::getThisOS();
return thisOS == TargetOS::unknown ? false : os == thisOS;
}
/** the dependency path setting as set in this Projucer project. */
Value projectSettingsValue;
/** the global key used in the application settings for the global setting value.
needed for checking whether the path is valid. */
Identifier globalKey;
/** on what operating system should this dependency path be used?
note that this is *not* the os that is targeted by the project,
but rather the os on which the project will be compiled
(= on which the path settings need to be set correctly). */
DependencyPathOS os;
/** the dependency path global setting on this machine.
used when there value set for this project is invalid. */
Value globalSettingsValue;
/** the dependency path fallback setting. used instead of the global setting
whenever the latter doesn't apply, e.g. the setting is for another
OS than the ome this machine is running. */
String fallbackValue;
};
//==============================================================================
class DependencyPathPropertyComponent : public TextPropertyComponent,
private Value::Listener,
private Label::Listener
{
public:
DependencyPathPropertyComponent (const File& pathRelativeToUse,
const Value& value,
const String& propertyName);
private:
/** This function defines what colour the label text should assume
depending on the current state of the value the component tracks. */
Colour getTextColourToDisplay() const;
/** This function handles path changes because of user input. */
void textWasEdited() override;
/** This function handles path changes because the global path changed. */
void valueChanged (Value& value) override;
/** If the dependency path is relative, relative to which directory should
we check if an object is available. */
File pathRelativeTo;
/** the value that represents this dependency path setting. */
Value pathValue;
/** a reference to the value source that this value refers to. */
DependencyPathValueSource& pathValueSource;
// Label::Listener overrides:
void labelTextChanged (Label* labelThatHasChanged) override;
void editorShown (Label*, TextEditor&) override;
void editorHidden (Label*, TextEditor&) override;
void lookAndFeelChanged() override;
JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (DependencyPathPropertyComponent)
};