-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[YamahaReceiver] Compatibility fixes and improvements for 2.3.0 #3264
[YamahaReceiver] Compatibility fixes and improvements for 2.3.0 #3264
Conversation
This pull request has been mentioned on openHAB Community. There might be relevant details there: https://community.openhab.org/t/yamahareceiver-zone-discovery-not-working-with-rx-v3900/38350/4 |
ff3d30a
to
2e1ea86
Compare
2e1ea86
to
ea068e5
Compare
<default></default> | ||
<advanced>true</advanced> | ||
</parameter> | ||
<parameter name="INPUT_MAP" type="text" required="false"> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm a litte disappointed here, that this is not happening in a more automated fashion. But it doesn't hurt if we give the user the choice to do his own mapping, as long as we also do auto-detection, too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do not be disappointed :) There is an actual auto detection happening by analyzing the AVR descriptor and other featues, see DeviceInformationXML, DeviceDescriptorXML, InputConverterXML.
This hidden setting, is an extra layer that will give user ability to remap and fine tune input names for his AVR. That said, this will be the last resort and I think the autodetection worked well on all the tested models.
/** | ||
* Model HTR-xxxx has a Zone_2 concept but realized as an extension to Main_Zone | ||
*/ | ||
ZONE_B |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The dialog level of the other PR will need an entry in this feature enum later on. Just a reminder.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What other PR do you have in mind?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
} | ||
|
||
if (refreshTimer != null) { | ||
refreshTimer.cancel(false); | ||
} | ||
refreshTimer = scheduler.scheduleWithFixedDelay(() -> updateAllZoneInformation(), initialWaitTime, | ||
refrehInterval, TimeUnit.SECONDS); | ||
refreshTimer = scheduler.scheduleWithFixedDelay(() -> updateAllZoneInformation(), initialWaitTime, settings.getRefreshInterval(), TimeUnit.SECONDS); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The line break limit of this commit is different to how my eclipse was configured through the oomph setup. Does the PR conforms to the OH style guidelines?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am using IntelliJ. The project passed style checks in maven/Jenkins. Wouldn't this be catched if style would be violated?
.collect(Collectors.toSet()); | ||
.of( | ||
// Note (TM): Not sure why we have NET_RADIO, we should only have one 'NET RADIO' (as the canonical input name) | ||
INPUT_NET_RADIO, "NET_RADIO", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NET_RADIO was the original input, that worked on the RX-V671. "NET RADIO" will work as well in the current addon, I guess.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems the comment of @davidgraeff is still applicable, or not?
NET_RADIO was the original input, that worked on the RX-V671. "NET RADIO" will work as well in the current addon, I guess.
* @param setting | ||
* @return | ||
*/ | ||
private Map<String, String> createMapFromSetting(String setting) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hm. I don't like this. If the framework does not support a valid use-case, the framework should be extended. This is clearly support code to workaround the limitation of missing list-like configuration entries.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
By saying the framework, you mean ESH?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes I do. An ESH implementation could take some time and I don't want to block this PR, so this is not required to be changed right now :)
|
||
connection.setUseCaches(false); | ||
connection.setDoInput(true); | ||
connection.setDoOutput(true); | ||
|
||
// Send request | ||
DataOutputStream wr = new DataOutputStream(connection.getOutputStream()); | ||
try { | ||
// ToDo: This should be sent using proper UTF-8 encoding |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I doubt, that Yamaha implemented a proper UTF8 character-set support. The only think that users can provide own strings for, is for the input names?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, this is a left over comment. At some point I rewrote this and added encoding based on the returned Content-Type. As far as I remember, my yamaha was reporting and sending proper UTF-8. I am not sure I got to a point to send UTF-8 thus this left over comment.
Either way, as it is now, how about I remove the comment?
* @author Tomasz Maruszak - Initial contribution | ||
*/ | ||
public class XMLProtocolService { | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Almost all those public methods of this class do not have a documentation. The included public class doesn't as well.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, will add documentations.
* @author Tomasz Maruszak - Initial contribution | ||
*/ | ||
public class YamahaSettingsUtil { | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hm, this class should go in my opinion. Configuration should be read/parsed/assigned to fields by the Configuration ESH class. If required configuration is missing, the mentioned class will complain.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you please point me at an example how to achieve such "autobinding" to a class by ESH?
@@ -25,5 +25,6 @@ | |||
public String inputID = VALUE_EMPTY; | |||
public String surroundProgram = VALUE_EMPTY; | |||
public float volume = 0.0f; // volume in percent | |||
public float volumeDB = 0.0f; // volume in dB |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The volume should either be stored in db or in percentage, but not in both. Because of the introduced minDB and maxDB I would favour the volumeDB field. The percentage can be computed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually both are supported. If the user sets volumeDB the volume percentage is calculated, and vice versa. The actual updates from Yamaha come back in DB if I remember correctly. Both are used to update state on the two volume channels we have.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree to have both channels, I just disagree to save both values, especially if one can be computed that easily.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the way it is right now fits into the existing design.
Note that in order to move the volume conversion logic out of ZoneControlXML the YamahaZoneConfiguration is also required (for min/max volume DB). Furthermore, if a set volume % command is made then similar conversion needs to be performed to dB in ZoneControlXML.
Not sure where this logic would sit? The only other option I see is a getter were to be exposed under ZineControlState but then you bring in the config class and break apart the from dB and the to dB conversion.
Please let me know what exactly you have in mind.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- remove volume
- Move the conversion logic into a method YamahaZoneConfiguration.getPercentageVolume(float volumeInDB)->float
- Use YamahaZoneConfiguration.getPercentageVolume(zoneState.volumeDB) within the handler to return a percentage value
Is that a viable option?
Redundant values are risky for fellow developers who refactor code and forget about keeping those values consistent.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Taking aside that the simple config holder is going to be in the business of volume conversion, yes this is viable. Check the change please.
@@ -0,0 +1,45 @@ | |||
/** |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
More of a note: The framework and other bindings prefer "configuration" over "settings" or "preferences". What do you thing?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, will change to "Configuration" for sake of consistency.
ecdbcd1
to
c3fa9a8
Compare
c3fa9a8
to
0604e62
Compare
private final DeviceDescriptorXML.ZoneDescriptor zoneDescriptor; | ||
|
||
protected String powerCmd = "<Power_Control><Power>%s</Power></Power_Control>"; | ||
protected String powerPath = "Power_Control/Power"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Those command template strings should be static, shouldn't they?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, they might be changed by subclasses. Nevermind.
0604e62
to
d284e4f
Compare
@martinvw LGTM |
This pull request has been mentioned on openHAB Community. There might be relevant details there: https://community.openhab.org/t/yamahareceiver-binding-has-issue-with-zone-2/19731/54 |
What are the next steps? |
This pull request has been mentioned on openHAB Community. There might be relevant details there: https://community.openhab.org/t/yamahareceiver-zone-discovery-not-working-with-rx-v3900/38350/7 |
I have it open already for a week but I did not yet find time, the +19.000 lines of code feels kind of depressing to me as a reviewer 😁 It will be included in the next release. |
@martinvw This is the OpenHab repository, not the ESH one :D Not every code line needs to be perfect. Trust your
We don't have a test suite here, that is correct. But users have tested the changes. And there are Yamaha models with 2 zones that do not work currently, and will work with this PR. And OMG this is really 19k changes. Luckily 17.5k is just xml device documentation. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry that it took me so long, but I was able to review it.
I added some remarks, please let me know it anything is unclear.
@@ -0,0 +1,3259 @@ | |||
<?xml version="1.0" encoding="utf-8"?> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is this and do we need it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These XML files are feature descriptors I have collected from various Yamaha models from the community users. It is good to have them as part of the binding documentation, since they give insight for developers on the protocol and feature variations that should be supported.
I think it's good to keep them next to the binding code. Also people will be able to refer to this by linking to github pages.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there maybe a way to describe this in a developer readme because the goal was not clear to me at first sight
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's already there. See the docs/README.md file in the PR.
try { | ||
updateDeviceInformation(); | ||
} catch (IOException | ReceivedMessageParseException e) { | ||
logger.error("Communication error", e); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In E.4 of the coding guidelines we listed what kind of logging level should be used when. Error should only be used:
error
logging should only be used to inform the user that something is tremendously wrong in his setup, the system cannot function normally anymore, and there is a need for immediate action.
Please change this to use the correct logging levels
updateState(grpZone(CHANNEL_VOLUME_DB), new DecimalType(zoneState.volumeDB)); | ||
updateState(grpZone(CHANNEL_VOLUME), new PercentType((int) zoneConfiguration.getVolumePercentage(zoneState.volumeDB))); | ||
updateState(grpZone(CHANNEL_MUTE), zoneState.mute ? OnOffType.ON : OnOffType.OFF); | ||
updateState(grpZone(CHANNEL_DIALOGUE_LEVEL), new DecimalType(zoneState.dialogueLevel)); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This line looks misformatted
* @param <T> | ||
* @return true when the setting was present | ||
*/ | ||
public static <T> boolean readSettingOptional(Thing thing, String settingName, Consumer<T> consumer) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think overloading the method name here is a bit confusing
} | ||
|
||
updateConfiguration(configuration); | ||
|
||
YamahaConfigurationUtil.<BigDecimal>readSettingOptional(thing, CONFIG_RELVOLUMECHANGE, v -> zoneConfiguration.setVolumeRelativeChangeFactor(v.floatValue())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To me this feels quite magical, why do you do it like this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How else would you avoid the boiler plate of pulling a value from settings, converting to decimal and setting a property? Does anything like this exist in ESH?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We support mapping configuration to a configuration class, it would cover some or more parts of your use case. Its not needed to change, then I should have joined earlier.
@wborn do you have any advice for a next PR how to handle the configuration, would using the config class solve this (partly)?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Configuration beans (there's still no good name for this pattern within esh), make the code much more readable. They do automatic conversions and can have default values.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes using binding specific configuration objects simplifies the code. When you override updateConfiguration(..)
instead you can easily get the configuration object and map it to a binding specific configuration:
@Override
protected void updateConfiguration(Configuration configuration) {
zoneConfiguration = configuration.as(YamahaZoneConfiguration.class);
super.updateConfiguration(configuration);
}
Calling the super is also important to keep the handler behaving like a default BaseThingHandler. I used something similar in the PlugwiseRelayDeviceHandler.
When the handler is initialized you get the configuration with:
@Override
public void initialize() {
zoneConfiguration = getConfigAs(YamahaZoneConfiguration.class);
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@wborn this is really neat, but how can I make it map a config value let say "ZONE" (or "VOLUME_DB_MIN") to the config bean property (zone, volumeDbMin)? Is there some annotation I could use to define the mapping?
Looking at ConfigMapper source from ESH, it seems expect naming in config to match bean properties.
Without this, I would have to rename the configs (breaking backwards compatibility) or set weird property names.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I proposed annotations for the configuration parser, but they got denied. Configuration keys should be lowercase, latin letters anyway, so it might be necessary to break backwards compatibility for the purpose of clean maintainable code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinvw @davidgraeff given the limitations of configuration bean mappings (bean properties need to match settings name) and your advise to refactor this, I have introduced the breaking change. Documentation has been updated. Essentially, users will be forced to re-update their settings when migrating to this version. I hope this will not cause too much issues for the users.
} | ||
} | ||
|
||
logger.trace("The charset {} will be used to parse the response", charset.name()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will give a NPE if we just logged on line 190, maybe just log charset and trust the toString
implementation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm the charset would never be null. It is assigned a default charset on beginning of method regardless of line 188.
Either way I change the implementations, so it will be different (along with relying on toString on the logging).
value = value.trim(); | ||
|
||
if (value.toLowerCase().startsWith("charset=")) { | ||
charsetName = value.substring("charset=".length() + 1, value.length() - 1); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This feels pretty wasted: "charset=".length() + 1
maybe make it constant?
public static final String POWER_STANDBY = "Standby"; | ||
public static final Map<String, Feature> FEATURE_BY_YNC_TAG; | ||
|
||
static { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I personally dislike this construct, can you just call a method which returns the complete list, now it can have all values in between in a multi-threaded env
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wanted to avoid Guava to help with map initialization and also wanted to have just one map instance.
Static class constructors are executed once per class loader thus are thread safe, so it should be good. If it's a matter of preference I could change it to a method call (or one line in guava), but then it violates the first sentence :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Static class constructors are executed once per class loader thus are thread safe,
What a great language :-)
Lets leave it then, if there is no reason for change except my personal preference :-)
inputs.add(new InputDto(param, writable)); | ||
} | ||
|
||
if (LOGGER.isTraceEnabled()) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍
*/ | ||
public class YamahaConfigurationUtil { | ||
|
||
private final static Logger LOGGER = LoggerFactory.getLogger(YamahaConfigurationUtil.class); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
private static final
please check all
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It was just this place :)
@martinvw , @davidgraeff do you guys know where should the built JAR be with this PR changes? The JAR from here does not seem to have changes from this PR: https://openhab.jfrog.io/openhab/libs-pullrequest-local/org/openhab/binding/org.openhab.binding.yamahareceiver/ The Jenkins links is also broken (maybe the build history expired). Someone on community is asking for a binary to test. I could provide my own build, but I believe something should exist by now. |
Forcing a rebuild |
That sounds likely, can you check whether it’s fine now? |
Still no luck. The JAR (https://openhab.jfrog.io/openhab/libs-pullrequest-local/org/openhab/binding/org.openhab.binding.yamahareceiver/2.3.0-SNAPSHOT/) Also, I followed the Jenkins build and ended up on this artifactory artifact. Yet, I don't seem to have permissions to download the JAR and confirm if this one has the changes. |
It completely overwrote all bindings when building: https://github.com/openhab/openhab2-addons/pull/3137 I don't know whether that was caused by the change in the pom.xml but that could sound like our process is broken 😢 |
@zarusz its there now, but looking at the history it might be overwritten again later: https://openhab.jfrog.io/openhab/webapp/#/builds/PR-openHAB2-Addons/9735/1524776821513/published/ |
As Yamaha introduces new models there may be variations between XML structure. | ||
In an attempt to improve the addon maintenance and troubleshooting selected model's `desc.xml`' has been collected from community users: | ||
|
||
* [RX-S601D](desc_RX-S601D.xml) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinvw here is the developer documentation that mentions these XML files...
This pull request has been mentioned on openHAB Community. There might be relevant details there: https://community.openhab.org/t/yamahareceiver-zone-discovery-not-working-with-rx-v3900/38350/8 |
d284e4f
to
c0a151e
Compare
* Feature: Introduced zone channel settings for minimum and maximum volume in dB. | ||
* Feature: Added setting for default album image URL. | ||
* Minor improvement (compatibility discovery, optimizations, [developer documentation](README.md)). | ||
* **Compatibility break**: Changed underlying settings name to follow the lower camel case convention (see discussion [here](https://github.com/openhab/openhab2-addons/pull/3264)). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@davidgraeff @martinvw here is the breaking change mentioned in the new release notes page. The binding documentation is also upgraded.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Imho we should not have a releasenotes per binding, please add the breaking change to:
https://github.com/openhab/openhab-distro/wiki/%5BDRAFT%5D-openHAB-2.3-Release-Notes
The rest will were needed be included it in the global releasenotes but please do not add this file here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree, please remove the release notes from this PR.
Besides adding the breaking change info to the wiki that @martinvw has mentioned, please also add a line to the update.lst as this will be shown on the console during the update process.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@zarusz if this is done I'm ready to merge :-)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinvw lst file update submitted, global release wiki updated, and removed the release notes file from here (along with references).
Thing zone ZoneID2 "Zone 2 Thing Name" @ "location" [ZONE="Zone_2"] | ||
Thing zone ZoneID3 "Zone 3 Thing Name" @ "location" [ZONE="Zone_3"] | ||
Thing zone ZoneID4 "Zone 4 Thing Name" @ "location" [ZONE="Zone_4"] | ||
Bridge yamahareceiver:yamahaAV:ReceiverID "Yamaha Receiver Bridge Name" [host="a.b.c.d"] { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@davidgraeff @martinvw here are the new settings that follow the configuration bean requirements...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@kaikreuzer this breaking change is a result of the limitations of the configuration class mapping, do you agree that it is worth it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In OpenHab 1.x times, it was fancy to use uppercase configuration keys. That has changed with ESH and OpenHab 2.x were the majority of all extensions and bindings are using camelcase configuration keys. Should be unified in my opinion.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinvw yes, the braking change is dictated by the limitation of the config class mapping. Having a feature in ESH that David suggested would really help here. Also looking at ESH it should be easy to add to ESH.
@davidgraeff let me know if in case something doesn't look good.
In general, given all this conversations around this and the fact I already made the effort to change this, let's stick with the unification and introduce this one time break.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this one time break
@zarusz
This binding has quite a history of breaking changes 😆 . Partly because it was a port of OH1 but also because the design lacked zone support etc.
But seriously, why is it "host" on most bindings and HOST here. That confuses users.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@kaikreuzer this breaking change is a result of the limitations of the configuration class mapping, do you agree that it is worth it?
I leave that decision to the authors - any outcome is fine with me.
} | ||
|
||
updateConfiguration(configuration); | ||
|
||
YamahaConfigurationUtil.<BigDecimal>readSettingOptional(thing, CONFIG_RELVOLUMECHANGE, v -> zoneConfiguration.setVolumeRelativeChangeFactor(v.floatValue())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinvw @davidgraeff given the limitations of configuration bean mappings (bean properties need to match settings name) and your advise to refactor this, I have introduced the breaking change. Documentation has been updated. Essentially, users will be forced to re-update their settings when migrating to this version. I hope this will not cause too much issues for the users.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please see the compatibility breaks mentioned.
c0a151e
to
0c2a790
Compare
Thanks for your great work, is there some community testing needed, or do you feel confident about the changes? |
I am fairly confident about these changes. Also tested on my AVR model. Either way, I plan to add some more features in the near term. If anything I will keep an eye on the community. Glad to be of help for openHAB 👍 |
This pull request has been mentioned on openHAB Community. There might be relevant details there: https://community.openhab.org/t/yamahareceiver-binding-problems/34628/53 |
0c2a790
to
1bbf55d
Compare
- Problem with HDMI input openhab#2758 (input mapping fixes for HDMIx, AUDIOx, NET RADIO) - VolumeDB is not updated openhab#3034 - ‘Zone_2’ of Yamaha HTR-xxx receiver completely incontrollable openhab#3062 - Fixing Tuner compatibility with HTR-xxxx - Adding support for RX-V3900 - Added Spotify, Server as supported preset inputs - Added Server as supported playback inputs - Added user defined custom mapping for inputs - Adding STRAIGHT surround program - Adding default album URL setting - Developer documentation cleanup Signed-off-by: Tomasz Maruszak <maruszaktomasz@gmail.com>
1bbf55d
to
6321217
Compare
Thanks again for your work and patience! |
- Problem with HDMI input openhab#2758 (input mapping fixes for HDMIx, AUDIOx, NET RADIO) - VolumeDB is not updated openhab#3034 - ‘Zone_2’ of Yamaha HTR-xxx receiver completely incontrollable openhab#3062 - Fixing Tuner compatibility with HTR-xxxx - Adding support for RX-V3900 - Added Spotify, Server as supported preset inputs - Added Server as supported playback inputs - Added user defined custom mapping for inputs - Adding STRAIGHT surround program - Adding default album URL setting - Developer documentation cleanup fixes openhab#3034 fixes openhab#3062 fixes openhab#2758 Signed-off-by: Tomasz Maruszak <maruszaktomasz@gmail.com>
- Problem with HDMI input openhab#2758 (input mapping fixes for HDMIx, AUDIOx, NET RADIO) - VolumeDB is not updated openhab#3034 - ‘Zone_2’ of Yamaha HTR-xxx receiver completely incontrollable openhab#3062 - Fixing Tuner compatibility with HTR-xxxx - Adding support for RX-V3900 - Added Spotify, Server as supported preset inputs - Added Server as supported playback inputs - Added user defined custom mapping for inputs - Adding STRAIGHT surround program - Adding default album URL setting - Developer documentation cleanup fixes openhab#3034 fixes openhab#3062 fixes openhab#2758 Signed-off-by: Tomasz Maruszak <maruszaktomasz@gmail.com>
- Problem with HDMI input openhab#2758 (input mapping fixes for HDMIx, AUDIOx, NET RADIO) - VolumeDB is not updated openhab#3034 - ‘Zone_2’ of Yamaha HTR-xxx receiver completely incontrollable openhab#3062 - Fixing Tuner compatibility with HTR-xxxx - Adding support for RX-V3900 - Added Spotify, Server as supported preset inputs - Added Server as supported playback inputs - Added user defined custom mapping for inputs - Adding STRAIGHT surround program - Adding default album URL setting - Developer documentation cleanup fixes openhab#3034 fixes openhab#3062 fixes openhab#2758 Signed-off-by: Tomasz Maruszak <maruszaktomasz@gmail.com>
This PR has a bunch of fixes and improvements to the YamahaReceiver addon:
Straight
surround programTesting was done on few Yamaha models (RX-V3900, HTR-4069, RX-S601D). Many thanks to everyone from the community who helped with verifying fixes and testing regressions!
Follow the Jenkins build link to access artifactory where you could download the JAR.
Signed-off-by: Tomasz Maruszak maruszaktomasz@gmail.com