blob: 89921c856c879b7608ab59548b5fbeb556b2d47e [file] [log] [blame]
// Copyright 2020 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package strconv
// FormatComplex converts the complex number c to a string of the
// form (a+bi) where a and b are the real and imaginary parts,
// formatted according to the format fmt and precision prec.
//
// The format fmt and precision prec have the same meaning as in [FormatFloat].
// It rounds the result assuming that the original was obtained from a complex
// value of bitSize bits, which must be 64 for complex64 and 128 for complex128.
func FormatComplex(c complex128, fmt byte, prec, bitSize int) string {
var buf [64]byte
return string(AppendComplex(buf[:0], c, fmt, prec, bitSize))
}
// AppendComplex appends the result of FormatComplex to dst.
// It is here for the runtime.
// There is no public strconv.AppendComplex.
func AppendComplex(dst []byte, c complex128, fmt byte, prec, bitSize int) []byte {
if bitSize != 64 && bitSize != 128 {
panic("invalid bitSize")
}
bitSize >>= 1 // complex64 uses float32 internally
dst = append(dst, '(')
dst = AppendFloat(dst, real(c), fmt, prec, bitSize)
i := len(dst)
dst = AppendFloat(dst, imag(c), fmt, prec, bitSize)
// Check if imaginary part has a sign. If not, add one.
if dst[i] != '+' && dst[i] != '-' {
dst = append(dst, 0)
copy(dst[i+1:], dst[i:])
dst[i] = '+'
}
dst = append(dst, "i)"...)
return dst
}