1. Credits
2. Introduction
This paper aims to solve three problems: Encoding and portability problems with command line arguments, an interface for
accessing arguments outside of main, and a modern interface for accessing arguments. It does so by introducing a global 
Encoding: The only standard way to access command-line arguments in C++ is via 
Access outside main: It’s often desirable to be able to access command line arguments outside of 
Modernity: Passing arrays via a pointer and length argument is a very antiquated pattern rendered obsolete by modern
solutions such as 
3. Previous Straw Polls and Discussion
Early polling surrounding an alternative to 
POLL: A trivial library solution for iterating parameters?
SF F N A SA 2 12 14 2 1 
POLL: A non--based way of fetching command line arguments?main 
SF F N A SA 7 9 9 1 2 
Polls on [P1275] by LEWGI:
POLL: We should promise more committee time to the
part.std :: arguments 
Unanimous consent
Attendance: 11
POLL:should be available before mainstd :: arguments Attendance: 11
SF F N A SA 6 0 3 1 0 
Polls on [P1275] by SG16:
POLL:andstd :: environments should follow the precedent set bystd :: arguments .std :: filesystem :: path Attendance: 14
SF F N A SA 4 6 1 0 2 
POLL:andstd :: environment should return a bag-o-bytes and conversion is up to the user.std :: arguments Attendance: 14
SF F N A SA 3 4 2 1 2 
Key concerns discussed included mutability of arguments, overhead of initializing data structures before 
4. Design
This paper introduces a global 
While it is not uncommon practice to modify the contents of 
4.1. Future Interface Expansion
Author’s note: While most large applications should probably use a library for argument parsing, it is my hope that in
the case of more ad-hoc argument parsing it would be possible to portably write a check such as 
Because encoding will vary between systems and 
// The overhead here is unfortunate but OK for 99% of uses if ( std :: arguments . at ( 1 ). string () == "--help" ) { // ... } // or: #ifdef _WIN32 #define ARG(str) L##str #else #define ARG(str) str #endif if ( std :: arguments . at ( 1 ). native () == ARG ( "--help" )) { // ... } 
A UDL could also be considered, however, this is a more general problem that, in the author’s opinion, should be addressed directly rather than through a bespoke solution. The problem of operations between strings of different encodings would best be tackled in another paper.
5. Implementability
On Windows, 
6. Proposed Wording
Wording is relative to [N4950] and borrows extensively from existing wording.
Insert into [headers] table 24:
    < arguments > 
   Insert a new section [arguments]:
Header < arguments > 
namespace std { class arguments_view ; class argument ; // [arguments.access] arguments access const arguments_view & arguments (); } 
Arguments access [arguments.access]
Returns: A reference to an 
Throws: May throw 
Class arguments_view 
    An 
All member functions of 
namespace std { class arguments_view { public : using value_type = argument ; using size_type = size_t ; using difference_type = ptrdiff_t ; using reference = value_type ; using const_reference = value_type ; using const_iterator = /* implementation-defined */ ; // see [arguments.view.iterators] using iterator = const_iterator ; using const_reverse_iterator = std :: reverse_iterator < const_iterator > ; using reverse_iterator = const_reverse_iterator ; arguments_view ( const arguments_view & ) = delete ; arguments_view & operator = ( const arguments_view & ) = delete ; // [arguments.view.access], access reference operator []( size_type index ) const noexcept ; reference at ( size_type index ) const ; // [arguments.view.obs], observers size_type size () const noexcept ; bool empty () const noexcept ; // [arguments.view.iterators], iterators const_iterator begin () const noexcept ; const_iterator end () const noexcept ; const_iterator cbegin () const noexcept ; const_iterator cend () const noexcept ; const_reverse_iterator rbegin () const noexcept ; const_reverse_iterator rend () const noexcept ; const_reverse_iterator crbegin () const noexcept ; const_reverse_iterator crend () const noexcept ; }; } 
Access [arguments.view.access]
Preconditions: true.
Returns: The argument at index 
Throws: Nothing.
Effects: Equivalent to: true.
Throws: true.
Observers [arguments.view.obs]
Returns: The number of program argument.
Effects: Equivalent to: 
Iterators [arguments.view.iterators]
 The type models a constant 
 All requirements on container iterators ([container.reqmts]) apply to 
 
 
 Returns: An iterator referring to the first program argument. If true, then it returns the same value
  as 
 
 
Returns: An iterator which is the past-the-end value.
 
 
 Effects: Equivalent to: 
 
 
 Effects: Equivalent to: 
Class argument 
    An object of class 
It is implementation-defined whether, in a 
namespace std { class argument { public : using value_type = /* see below */ ; using string_type = basic_string < value_type > ; using string_view_type = basic_string_view < value_type > ; argument ( const argument & ) noexcept = default ; argument & operator = ( const argument & ) noexcept = default ; // [arguments.argument.native], native observers const string_view_type native () const noexcept ; const string_type native_string () const ; const value_type * c_str () const noexcept ; explicit operator string_type () const ; explicit operator string_view_type () const noexcept ; // [arguments.argument.obs], converting observers template < class EcharT , class traits = char_traits < EcharT > , class Allocator = allocator < EcharT >> basic_string < EcharT , traits , Allocator > string ( const Allocator & a = Allocator ()) const ; std :: string string () const ; std :: wstring wstring () const ; std :: u8string u8string () const ; std :: u16string u16string () const ; std :: u32string u32string () const ; // [arguments.argument.compare], comparison friend bool operator == ( const argument & lhs , const argument & rhs ) noexcept ; friend strong_ordering operator <=> ( const argument & lhs , const argument & rhs ) noexcept ; // [arguments.argument.ins], inserter template < class charT , class traits > friend basic_ostream < charT , traits >& operator << ( basic_ostream < charT , traits >& os , const argument & a ); }; // [arguments.argument.fmt], formatter template < typename charT > struct formatter < argument , charT > : formatter < argument :: string_view_type , charT > { template < class FormatContext > typename FormatContext :: iterator format ( const argument & argument , FormatContext & ctx ) const ; }; } 
Conversion [arguments.argument.cvt]
The native encoding of an ordinary character string is the operating system dependent current encoding for arguments. The native encoding for wide character strings is the implementation-defined execution wide-character set encoding ([character.seq]).
 For member functions returning strings, value type and encoding conversion is performed if the value type of the
  argument or return value differs from 
-  char 
-  wchar_t 
-  char8_t 
-  char16_t 
-  char32_t 
If the encoding being converted to has no representation for source characters, the resulting converted characters, if any, are unspecified.
Native Observers [arguments.argument.native]
The string returned by all native observers is in the native default argument encoding ([arguments.argument.cvt]).
Returns: A 
Returns: A 
Returns: A pointer to a null-terminated array of 
Returns: A 
Returns: A 
Converting Observers [arguments.argument.obs]
 
           
   
     
Returns: A string representing the argument.
Remarks: All memory allocation, including for the return value, shall be performed by a. Conversion, if any, is specified by [arguments.argument.cvt].
 
 
 
 
 
Returns: A string representing the argument.
Remarks: Conversion, if any, is specified by [arguments.argument.cvt].
Comparison [arguments.view.compare]
Effects: Equivalent to: 
Effects: Equivalent to: 
Inserter [arguments.argument.ins]
 
   
     
Effects: Equivalent to: 
Formatter [arguments.argument.fmt]
 
   
     
Effects: Equivalent to: