The use of Q_ASSERT(false) is bogus as we don't need to test here, but want to signal unreachability. Q_UNREACHABLE_RETURN allows us to tell the compiler that the point can't be reached while also getting rid of the no return error. Task-number: QTBUG-114689 Change-Id: I007cd243055237bcc21772a4130a6c1a44fd882d Reviewed-by: Ulf Hermann <ulf.hermann@qt.io> (cherry picked from commit ce39beea0cd49bb93b0e345194265dd8081094cd) Reviewed-by: Qt Cherry-pick Bot <cherrypick_bot@qt-project.org>
51 lines
1.1 KiB
C++
51 lines
1.1 KiB
C++
// Copyright (C) 2021 The Qt Company Ltd.
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
|
|
|
|
#include "bindablesubscription.h"
|
|
#include "bindableuser.h"
|
|
|
|
//! [binding-expressions]
|
|
|
|
BindableSubscription::BindableSubscription(BindableUser *user) : m_user(user)
|
|
{
|
|
Q_ASSERT(user);
|
|
|
|
m_price.setBinding([this] { return qRound(calculateDiscount() * m_duration * basePrice()); });
|
|
|
|
m_isValid.setBinding([this] {
|
|
return m_user->country() != BindableUser::Country::AnyCountry && m_user->age() > 12;
|
|
});
|
|
}
|
|
|
|
//! [binding-expressions]
|
|
|
|
//! [set-duration]
|
|
|
|
void BindableSubscription::setDuration(Duration newDuration)
|
|
{
|
|
m_duration = newDuration;
|
|
}
|
|
|
|
//! [set-duration]
|
|
|
|
double BindableSubscription::calculateDiscount() const
|
|
{
|
|
switch (m_duration) {
|
|
case Monthly:
|
|
return 1;
|
|
case Quarterly:
|
|
return 0.9;
|
|
case Yearly:
|
|
return 0.6;
|
|
}
|
|
Q_UNREACHABLE_RETURN(-1);
|
|
}
|
|
|
|
int BindableSubscription::basePrice() const
|
|
{
|
|
if (m_user->country() == BindableUser::Country::AnyCountry)
|
|
return 0;
|
|
|
|
return (m_user->country() == BindableUser::Country::Norway) ? 100 : 80;
|
|
}
|