dmd.common.file
File utilities.
Discussion
    Functions and objects dedicated to file I/O and management. TODO: Move here artifacts
 from places such as root/ so both the frontend and the backend have access to them.
  
License
Source: common/file.d
Documentation: https://dlang.org/phobos/dmd_common_file.html
- 
  DeclarationstructFileMapping(Datum);Encapsulated management of a memory-mapped file. ParametersDatumthe mapped data type: Use a POD of size 1 for read/write mapping and a constversion thereof for read-only mapping. Other primitive types should work, but have not been yet tested.- 
  Declarationthis(const char*filename);Open filenameDatumisconst, opens for read-only and maps the content in memory; no error is issued if the file does not exist. This makes it easy to treat a non-existing file as empty.DiscussionIf Datumis mutable, opens for read/write (creates file if it does not exist) and fails fatally on any error.
 Due to quirks inmmap, if the file is empty,handleis valid butdataisnull. This state is valid and accounted for.Parameterschar*filenamethe name of the file to be mapped in memory 
- 
  Declarationvoidclose();Frees resources associated with this mapping. However, it does not deallocate the name. Reinitializes thisas a fresh object that can be reused.
- 
  Declarationbooldiscard();Deletes the underlying file and frees all resources associated. Reinitializes thisas a fresh object that can be reused.DiscussionThis function does not abort if the file cannot be deleted, but does print a message on stderrand returnsfalseto the caller. The underlying rationale is to give the caller the option to continue execution if deleting the file is not important.Return Valuetrueiff the file was successfully deleted. If the file was not deleted, prints a message tostderrand returnsfalse.
- 
  Declarationconst pure nothrow @nogc boolactive();Queries whether thisis currently associated with a file.Return Valuetrueiff there is anactivemapping.
- 
  Declarationconst pure nothrow @nogc @safe size_tlength();Queries the lengthof the file associated with this mapping. If not active, returns 0.Return Valuethe lengthof the file, or 0 if no file associated.
- 
  Declarationpure nothrow @nogc @safe autoopSlice();Get a slice to the contents of the entire file. Return Valuethe contents of the file. If not active, returns the nullslice.
- 
  Declarationpure voidresize(size_tsize);Resizes the file and mapping to the specified sizeParameterssize_tsizenew length requested 
- 
  DeclarationboolmoveToFile(const char*filename);Unconditionally and destructively moves the underlying file to filenametrue. Upon failure, prints a message tostderrand returnsfalse. In all cases it closes the underlying file.Parameterschar*filenamezero-terminated name of the file to move to. Return Valuetrueiff the operation was successful.
 
- 
  
- 
  Declarationstatic nothrow boolwriteFile(const(char)*name, const void[]data);Write a file, returning trueon success.
- 
  Declarationnothrow booltouchFile(const char*namez);Touch a file to current date