File.hx 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*
  2. * Copyright (c) 2005-2012, 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 sys.io;
  26. /**
  27. API for reading and writing to files.
  28. **/
  29. @:coreApi
  30. class File {
  31. public static function getContent( path : String ) : String
  32. {
  33. var f = read(path, false);
  34. var ret = f.readAll().toString();
  35. f.close();
  36. return ret;
  37. }
  38. public static function saveContent( path : String, content : String ) : Void
  39. {
  40. var f = write(path, false);
  41. f.writeString(content);
  42. f.close();
  43. }
  44. public static function getBytes( path : String ) : haxe.io.Bytes
  45. {
  46. var f = read(path, true);
  47. var ret = f.readAll();
  48. f.close();
  49. return ret;
  50. }
  51. public static function saveBytes( path : String, bytes : haxe.io.Bytes ) : Void
  52. {
  53. var f = write(path, true);
  54. f.writeBytes(bytes, 0, bytes.length);
  55. f.close();
  56. }
  57. public static function read( path : String, binary : Bool = true ) : FileInput
  58. {
  59. try
  60. {
  61. return new FileInput( new java.io.RandomAccessFile(new java.io.File(path), "r") );
  62. }
  63. catch (e:Dynamic) //swallow checked exceptions
  64. {
  65. throw e;
  66. }
  67. }
  68. public static function write( path : String, binary : Bool = true ) : FileOutput
  69. {
  70. var f = new java.io.File(path);
  71. if (f.exists())
  72. {
  73. f.delete();
  74. }
  75. try
  76. {
  77. return new FileOutput( new java.io.RandomAccessFile(f, "rw") );
  78. }
  79. catch (e:Dynamic) //swallow checked exceptions
  80. {
  81. throw e;
  82. }
  83. }
  84. public static function append( path : String, binary : Bool = true ) : FileOutput
  85. {
  86. var f = new java.io.File(path);
  87. try
  88. {
  89. var ra = new java.io.RandomAccessFile(f, "rw");
  90. if (f.exists())
  91. {
  92. ra.seek(f.length());
  93. }
  94. return new FileOutput( ra );
  95. }
  96. catch (e:Dynamic) //swallow checked exceptions
  97. {
  98. throw e;
  99. }
  100. }
  101. public static function copy( src : String, dst : String ) : Void
  102. {
  103. var r:FileInput = null;
  104. var w:FileOutput = null;
  105. try
  106. {
  107. r = read(src);
  108. w = write(dst);
  109. w.writeInput(r);
  110. }
  111. catch (e:Dynamic)
  112. {
  113. if (r != null) r.close();
  114. if (w != null) w.close();
  115. throw e;
  116. }
  117. }
  118. }