std::experimental::filesystem::copy_symlink
From cppreference.com
                    
                                        
                    < cpp | experimental | fs
                    
                                                            
                    |   Defined in header  
<experimental/filesystem>
  | 
||
|   void copy_symlink( const path& from, const path& to); 
 | 
(1) | (filesystem TS) | 
|   void copy_symlink( const path& from, const path& to, 
error_code& ec );  | 
(2) | (filesystem TS) | 
Copies a symlink to another location.
1) Effectively calls f(read_symlink(from), to) where 
f is create_symlink() or create_directory_symlink depending on whether from resolves to a file or directory.
2) Effectively calls f(read_symlink(from, ec), to, ec) where 
f is create_symlink() or create_directory_symlink depending on whether from resolves to a file or directory.
Contents | 
[edit] Parameters
| from | - | path to a symbolic link to copy | 
| to | - | destination path of the new symlink | 
| ec | - | out-parameter for error reporting in the non-throwing overload | 
[edit] Return value
(none)
[edit] Exceptions
The overload that does not take aerror_code& parameter throws filesystem_error on underlying OS API errors, constructed with from as the first argument, to as the second argument, and the OS error code as the error code argument. std::bad_alloc may be thrown if memory allocation fails. The overload taking a error_code& parameter sets it to the OS API error code if an OS API call fails, and executes ec.clear() if no errors occur. This overload has 
noexcept specification:  
noexcept
  [edit] See also
|    copies files or directories  (function)  | 
|
|    copies file contents  (function)  | 
|
|    creates a symbolic link  (function)  | 
|
|    obtains the target of a symbolic link  (function)  |