File.hx 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. * Copyright (c) 2005, The haXe Project Contributors
  3. * All rights reserved.
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions are met:
  6. *
  7. * - Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * - Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. *
  13. * THIS SOFTWARE IS PROVIDED BY THE HAXE PROJECT CONTRIBUTORS "AS IS" AND ANY
  14. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  15. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  16. * DISCLAIMED. IN NO EVENT SHALL THE HAXE PROJECT CONTRIBUTORS BE LIABLE FOR
  17. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  18. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  19. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  20. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  21. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  22. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  23. * DAMAGE.
  24. */
  25. package php.io;
  26. enum FileHandle {
  27. }
  28. enum FileSeek {
  29. SeekBegin;
  30. SeekCur;
  31. SeekEnd;
  32. }
  33. /**
  34. API for reading and writing to files.
  35. **/
  36. class File {
  37. public static function getContent( path : String ) : String {
  38. return untyped __call__("file_get_contents", path);
  39. }
  40. public static function getBytes( path : String ) {
  41. return haxe.io.Bytes.ofString(getContent(path));
  42. }
  43. public static function putContent( path : String, content : String) : String {
  44. return untyped __call__("file_put_contents", path, content);
  45. }
  46. public static function read( path : String, binary : Bool ) {
  47. return new FileInput(untyped __call__('fopen', path, binary ? "rb" : "r"));
  48. }
  49. public static function write( path : String, binary : Bool ) {
  50. return new FileOutput(untyped __call__('fopen', path, binary ? "wb" : "w"));
  51. }
  52. public static function append( path : String, binary : Bool ) {
  53. return new FileOutput(untyped __call__('fopen', path, binary ? "ab" : "a"));
  54. }
  55. public static function copy( src : String, dst : String ) {
  56. return untyped __call__("copy", src, dst);
  57. }
  58. public static function stdin() {
  59. return new FileInput(untyped __php__('STDIN'));
  60. }
  61. public static function stdout() {
  62. return new FileOutput(untyped __call__('STDOUT'));
  63. }
  64. public static function stderr() {
  65. return new FileOutput(untyped __call__('STDERR'));
  66. }
  67. /*
  68. * TODO: what is this for?
  69. public static function getChar( echo : Bool ) : Int {
  70. return getch(echo);
  71. }
  72. */
  73. }