about summary refs log tree commit diff
path: root/src/libstd/sys/unix/stack_overflow.rs
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2016-07-21 16:19:54 -0700
committerGitHub <noreply@github.com>2016-07-21 16:19:54 -0700
commit62690b3c3fa6e157daa7f7c5a3af005f37eb4199 (patch)
tree3781e11e755200990ea0a30f08df95f5f7c88d3b /src/libstd/sys/unix/stack_overflow.rs
parent75886537858530447051b9c1ef595c4ba59017c5 (diff)
parentede39aeb331bf6efb3739d22a60c1844e9c2c3d6 (diff)
downloadrust-62690b3c3fa6e157daa7f7c5a3af005f37eb4199.tar.gz
rust-62690b3c3fa6e157daa7f7c5a3af005f37eb4199.zip
Auto merge of #34544 - 3Hren:issue/xx/reinterpret-format-precision-for-strings, r=alexcrichton
feat: reinterpret `precision` field for strings

This commit changes the behavior of formatting string arguments with both width and precision fields set.

Documentation says that the `width` field is the "minimum width" that the format should take up. If the value's string does not fill up this many characters, then the padding specified by fill/alignment will be used to take up the required space.

This is true for all formatted types except string, which is truncated down to `precision` number of chars and then all of `fill`, `align` and `width` fields are completely ignored.

For example: `format!("{:/^10.8}", "1234567890);` emits "12345678". In the contrast Python version works as the expected:
```python
>>> '{:/^10.8}'.format('1234567890')
'/12345678/'
```

This commit gives back the `Python` behavior by changing the `precision` field meaning to the truncation and nothing more. The result string *will* be prepended/appended up to the `width` field with the proper `fill` char.

__However, this is the breaking change, I admit.__ Feel free to close it, but otherwise it should be mentioned in the `std::fmt` documentation somewhere near of `fill/align/width` fields description.
Diffstat (limited to 'src/libstd/sys/unix/stack_overflow.rs')
0 files changed, 0 insertions, 0 deletions