Jeśli znasz strukturę swojego BSON, możesz utworzyć niestandardowy typ, który implementuje json.Marshaler
i json.Unmarshaler
interfejsów i obsługuje NaN, jak chcesz. Przykład:
type maybeNaN struct{
isNan bool
number float64
}
func (n maybeNaN) MarshalJSON() ([]byte, error) {
if n.isNan {
return []byte("null"), nil // Or whatever you want here
}
return json.Marshal(n.number)
}
func (n *maybeNan) UnmarshalJSON(p []byte) error {
if string(p) == "NaN" {
n.isNan = true
return nil
}
return json.Unmarshal(p, &n.number)
}
type myStruct struct {
someNumber maybeNaN `json:"someNumber" bson:"someNumber"`
/* ... */
}
Jeśli masz dowolną strukturę swojego BSON, jedyną opcją jest przechodzenie przez tę strukturę za pomocą odbicia i przekonwertowanie wszelkich wystąpień NaN na typ (prawdopodobnie typ niestandardowy, jak opisano powyżej)