-
Notifications
You must be signed in to change notification settings - Fork 50
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
feat: Make Yaml nodes serializable #642
feat: Make Yaml nodes serializable #642
Conversation
EdwarDDay
commented
Nov 17, 2024
- fixes Make YamlNode serializable #641
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.
Thanks for the PR @EdwarDDay!
src/commonMain/kotlin/com/charleskorn/kaml/YamlNodeSerializer.kt
Outdated
Show resolved
Hide resolved
try { | ||
return encoder.encodeBoolean(value.toBoolean()) | ||
} catch (_: SerializationException) { | ||
} | ||
try { | ||
return encoder.encodeLong(value.toLong()) | ||
} catch (_: SerializationException) { | ||
} | ||
try { | ||
return encoder.encodeDouble(value.toDouble()) | ||
} catch (_: SerializationException) { | ||
} |
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.
Rather than this chain of try
/ catch
, couldn't we inspect the value and determine the best option to use?
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 didn't want to copy the parsing code, to avoid duplicated code. Do you have an idea how to implement this without duplicating most of the YamlScalar
code?
I mean Boolean
has extra parsing code, integer values extra checks for octal, decimal and hexadecimal numbers, floating point numbers have extra checks for infinity and NaN. This was too much code for me to copy. Else the library gets inconsistent with future changes.
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 if we just always encode the value as a string?
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.
Then we would encode a double 1.2
as "1.2"
, right? So the output might be unexpected to the user.
I could create toBooleanOrNull
, toByteOrNull
, … functions in the YamlScalar
class and use it in toBoolean
, toByte
, … functions and in the YamlScalarSerializer
. This way the code doesn't get duplicated and we don't have to try catch everything.
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 could create
toBooleanOrNull
,toByteOrNull
, … functions in theYamlScalar
class and use it intoBoolean
,toByte
, … functions and in theYamlScalarSerializer
. This way the code doesn't get duplicated and we don't have to try catch everything.
This sounds good to me.
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.
done
- fix small issues
value.content.singleOrNull()?.also { return encoder.encodeChar(it) } | ||
encoder.encodeString(value.content) |
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 a test for this special handling of characters?
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.
No, I just wanted to use the short version of encodeChar
, to not have the overhead from encodeString
. There are also no extra tests for encodeBoolean
, encodeLong
, encodeDouble
. I thought, these are properly tested in the tests for YamlOutput
.
But I can of course write extra tests, if you think, that's needed.
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 it'd be valuable to have a test that shows the expected behaviour when a value looks like it is a boolean or a number etc.
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 added some tests for encoding the primitives via the new serializer.
try { | ||
return encoder.encodeBoolean(value.toBoolean()) | ||
} catch (_: SerializationException) { | ||
} | ||
try { | ||
return encoder.encodeLong(value.toLong()) | ||
} catch (_: SerializationException) { | ||
} | ||
try { | ||
return encoder.encodeDouble(value.toDouble()) | ||
} catch (_: SerializationException) { | ||
} |
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 if we just always encode the value as a string?
- avoid exception catching in scalar serializer
- tests for scalar output
- fix formatting
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.
Thanks @EdwarDDay!
🎉 This PR is included in version 0.67.0 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |