import Quickshell.Io A reader for small to medium files that don’t need seeking/cursor access, suitable for most text files.
FileView {
  id: jsonFile
  path: Qt.resolvedUrl("./your.json")
  // Forces the file to be loaded by the time we call JSON.parse().
  // see blockLoading's property documentation for details.
  blockLoading: true
}
readonly property var jsonData: JSON.parse(jsonFile.text())Also see JsonAdapter for an alternative way to handle reading and writing JSON files.
In addition to directly reading/writing the file as text, adapters can be used to expose a file’s content in new ways.
An adapter will automatically be given the loaded file’s content. Its state may be saved with writeAdapter().
Currently the only adapter is JsonAdapter.
If true (default), read or write errors will be printed to the quickshell logs. If false, all known errors will not be printed.
If text() and data() should block all operations while a file loads. Defaults to false.
This is nearly identical to blockLoading, but will additionally block when a file is loaded and path changes.
WARNING
We cannot think of a valid use case for this. You almost definitely want blockLoading.
The path to the file that should be read, or an empty string to unload the file.
If true (defaule false), fileChanged() will be called whenever the content of the file changes on disk, including when setText() or setData() are used.
NOTE
You can reload the file’s content whenever it changes on disk like so:
FileView {
  // ...
  watchChanges: true
  onFileChanged: this.reload()
}If text() and data() should block all operations until the file is loaded. Defaults to false.
If the file is already loaded, no blocking will occur. If a file was loaded, and path was changed to a new file, no blocking will occur.
WARNING
Blocking operations should be used carefully to avoid stutters and other performance degradations. Blocking means that your interface WILL NOT FUNCTION during the call.
We recommend you use a blocking load ONLY for files loaded before the windows of your shell
are loaded, which happens after Component.onCompleted runs for the root component of your shell.
The most reasonable use case would be to load things like configuration files that the program must have available.
If the file should be loaded in the background immediately when set. Defaults to true.
This may either increase or decrease the amount of time it takes to load the file depending on how large the file is, how fast its storage is, and how you access its data.
Returns the data of the file specified by path as an ArrayBuffer.
If blockAllReads is true, all changes to path will cause the program to block when this function is called.
If blockLoading is true, reading this property before the file has been loaded will block, but changing path or calling reload() will return the old data until the load completes.
If neither is true, an empty buffer will be returned if no file is loaded, otherwise it will behave as in the case above.
NOTE
Due to technical limitations, data() could not be a property,
however you can treat it like a property, it will trigger property updates
as a property would, and the signal dataChanged() is present.
Unload the loaded file and reload it, usually in response to changes.
This will not block if blockLoading is set, only if blockAllReads is true. It acts the same as changing path to a new file, except loading the same file.
Sets the content of the file specified by path as an [ArrayBuffer].
atomicWrites and blockWrites affect the behavior of this function.
saved() or saveFailed() will be emitted on completion.
  
Sets the content of the file specified by path as text.
atomicWrites and blockWrites affect the behavior of this function.
saved() or saveFailed() will be emitted on completion.
Returns the data of the file specified by path as text.
If blockAllReads is true, all changes to path will cause the program to block when this function is called.
If blockLoading is true, reading this property before the file has been loaded will block, but changing path or calling reload() will return the old data until the load completes.
If neither is true, an empty string will be returned if no file is loaded, otherwise it will behave as in the case above.
NOTE
Due to technical limitations, text() could not be a property,
however you can treat it like a property, it will trigger property updates
as a property would, and the signal textChanged() is present.
Block all operations until the currently running load completes.
WARNING
See blockLoading for an explanation and warning about blocking.
Write the content of the current adapter to the selected file.
Emitted if the file changes on disk and watchChanges is true.
  
Emitted if the file failed to save.
Emitted if the file was saved successfully.
Emitted when the active adapter’s data is changed.
  
Emitted if the file failed to load.
Emitted if the file was loaded successfully.