Created on 2016-11-10.00:00:00 last changed 94 months ago
Proposed resolution:
This wording is relative to N4606.
Edit [fs.path.concat] as follows:
path& operator+=(const path& x); path& operator+=(const string_type& x); path& operator+=(basic_string_view<value_type> x); path& operator+=(const value_type * x); path& operator+=(value_type x); template <class Source> path& operator+=(const Source& x); template <class EcharT> path& operator+=(EcharT x); template <class Source> path& concat(const Source& x);template <class InputIterator> path& concat(InputIterator first, InputIterator last);-1-
Postcondition: native() == prior_native + effective-argument, where prior_native is native() prior to the call to operator+=, and effective-argument is:
if x is present and is const path&, x.native(); otherwise,if source is present, the effective range of source path.req; otherwise,>if first and last are present, the range [first, last); otherwise,x.-2- Returns: *this.
If the value type of effective-argument would not be path::value_type, the acctual argument or argument range is first converted path.type.cvt so that effective-argument has value type path::value_type.Effects: Equivalent to pathname.append(path(x).native()) [Note: This directly manipulates the value of native() and may not be portable between operating systems. — end note]template <class InputIterator> path& concat(InputIterator first, InputIterator last);-?- Effects: Equivalent to pathname.append(path(first, last).native()) [Note: This directly manipulates the value of native() and may not be portable between operating systems. — end note]
-?- Returns: *this.
[ Kona, 2017-03 ]
This is resolved by p0492r2.
[ Issues Telecon 16-Dec-2016 ]
Priority 2; should be addressed by omnibus Filesystem paper.
[ 2016-11-12, Issaquah ]
Sat PM: "Looks good"
Addresses US 44, LWG 2734
The explicit definition of path in terms of a string requires that the abstraction be leaky. Consider that the meaning of the expression p += '/' has very different behavior in the case that p is empty; that a path can uselessly contain null characters; and that iterators must be constant to avoid having to reshuffle the packed string.Suggested resolution:
Define member functions to express a path as a string, but define its state in terms of the abstract sequence of components (including the leading special components) already described by the iterator interface. Remove members that rely on arbitrary manipulation of a string value.History | |||
---|---|---|---|
Date | User | Action | Args |
2017-03-19 19:53:31 | admin | set | status: open -> resolved |
2017-03-19 19:35:20 | admin | set | status: resolved -> open |
2017-03-19 15:23:27 | admin | set | messages: + msg9135 |
2017-03-19 15:23:27 | admin | set | status: open -> resolved |
2016-12-16 20:56:38 | admin | set | messages: + msg8728 |
2016-11-21 05:09:01 | admin | set | messages: + msg8673 |
2016-11-21 05:09:01 | admin | set | status: new -> open |
2016-11-10 05:34:43 | admin | set | messages: + msg8607 |
2016-11-10 00:00:00 | admin | create |