Mercurial > hg > svcore
changeset 245:4cd620bd4c61 sv1-1.0pre1
* Make getPropertyRangeAndValue return the default separately from the current
value. Previously some contexts were incorrectly treating the current value
as a default.
author | Chris Cannam |
---|---|
date | Fri, 02 Mar 2007 14:00:12 +0000 (2007-03-02) |
parents | 85bf384db35f |
children | d7eeffbb8aaf |
files | base/Preferences.cpp base/Preferences.h base/PropertyContainer.cpp base/PropertyContainer.h |
diffstat | 4 files changed, 14 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- a/base/Preferences.cpp Fri Mar 02 13:01:41 2007 +0000 +++ b/base/Preferences.cpp Fri Mar 02 14:00:12 2007 +0000 @@ -113,11 +113,12 @@ int Preferences::getPropertyRangeAndValue(const PropertyName &name, - int *min, int *max) const + int *min, int *max, int *deflt) const { if (name == "Smooth Spectrogram") { if (min) *min = 0; if (max) *max = 1; + if (deflt) *deflt = 1; return m_smoothSpectrogram ? 1 : 0; } @@ -126,18 +127,21 @@ if (name == "Property Box Layout") { if (min) *min = 0; if (max) *max = 1; + if (deflt) *deflt = 0; return m_propertyBoxLayout == Layered ? 1 : 0; } if (name == "Window Type") { if (min) *min = int(RectangularWindow); if (max) *max = int(BlackmanHarrisWindow); + if (deflt) *deflt = int(HanningWindow); return int(m_windowType); } if (name == "Resample Quality") { if (min) *min = 0; if (max) *max = 2; + if (deflt) *deflt = 1; return m_resampleQuality; }
--- a/base/Preferences.h Fri Mar 02 13:01:41 2007 +0000 +++ b/base/Preferences.h Fri Mar 02 14:00:12 2007 +0000 @@ -30,7 +30,7 @@ virtual PropertyList getProperties() const; virtual QString getPropertyLabel(const PropertyName &) const; virtual PropertyType getPropertyType(const PropertyName &) const; - virtual int getPropertyRangeAndValue(const PropertyName &, int *, int *) const; + virtual int getPropertyRangeAndValue(const PropertyName &, int *, int *, int *) const; virtual QString getPropertyValueLabel(const PropertyName &, int value) const; virtual QString getPropertyContainerName() const; virtual QString getPropertyContainerIconName() const;
--- a/base/PropertyContainer.cpp Fri Mar 02 13:01:41 2007 +0000 +++ b/base/PropertyContainer.cpp Fri Mar 02 14:00:12 2007 +0000 @@ -47,10 +47,12 @@ } int -PropertyContainer::getPropertyRangeAndValue(const PropertyName &, int *min, int *max) const +PropertyContainer::getPropertyRangeAndValue(const PropertyName &, + int *min, int *max, int *deflt) const { if (min) *min = 0; if (max) *max = 0; + if (deflt) *deflt = 0; return 0; } @@ -75,7 +77,7 @@ void PropertyContainer::setPropertyWithCommand(const PropertyName &name, int value) { - int currentValue = getPropertyRangeAndValue(name, 0, 0); + int currentValue = getPropertyRangeAndValue(name, 0, 0, 0); if (value == currentValue) return; CommandHistory::getInstance()->addCommand @@ -176,7 +178,7 @@ case ValueProperty: { int min, max; - getPropertyRangeAndValue(name, &min, &max); + getPropertyRangeAndValue(name, &min, &max, 0); for (int i = min; i <= max; ++i) { if (valueString == getPropertyValueLabel(name, i)) { value = i; @@ -211,7 +213,7 @@ if (success) return true; int min, max; - getPropertyRangeAndValue(name, &min, &max); + getPropertyRangeAndValue(name, &min, &max, 0); bool ok = false; int i = valueString.toInt(&ok); @@ -240,7 +242,7 @@ void PropertyContainer::SetPropertyCommand::execute() { - m_oldValue = m_pc->getPropertyRangeAndValue(m_pn, 0, 0); + m_oldValue = m_pc->getPropertyRangeAndValue(m_pn, 0, 0, 0); m_pc->setProperty(m_pn, m_value); }
--- a/base/PropertyContainer.h Fri Mar 02 13:01:41 2007 +0000 +++ b/base/PropertyContainer.h Fri Mar 02 14:00:12 2007 +0000 @@ -76,7 +76,7 @@ * passed as NULL if their values are not required. */ virtual int getPropertyRangeAndValue(const PropertyName &, - int *min, int *max) const; + int *min, int *max, int *deflt) const; /** * If the given property is a ValueProperty, return the display