Resource.hx 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /*
  2. * Copyright (C)2005-2019 Haxe Foundation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  20. * DEALINGS IN THE SOFTWARE.
  21. */
  22. package haxe;
  23. /**
  24. Resource can be used to access resources that were added through the
  25. `--resource file@name` command line parameter.
  26. Depending on their type they can be obtained as `String` through
  27. `getString(name)`, or as binary data through `getBytes(name)`.
  28. A list of all available resource names can be obtained from `listNames()`.
  29. **/
  30. class Resource {
  31. static var content:Array<{name:String, data:String, str:String}>;
  32. /**
  33. Lists all available resource names. The resource name is the name part
  34. of the `--resource file@name` command line parameter.
  35. **/
  36. public static function listNames():Array<String> {
  37. return [for (x in content) x.name];
  38. }
  39. /**
  40. Retrieves the resource identified by `name` as a `String`.
  41. If `name` does not match any resource name, `null` is returned.
  42. **/
  43. public static function getString(name:String):String {
  44. for (x in content)
  45. if (x.name == name) {
  46. if (x.str != null)
  47. return x.str;
  48. var b:haxe.io.Bytes = haxe.crypto.Base64.decode(x.data);
  49. return b.toString();
  50. }
  51. return null;
  52. }
  53. /**
  54. Retrieves the resource identified by `name` as an instance of
  55. haxe.io.Bytes.
  56. If `name` does not match any resource name, `null` is returned.
  57. **/
  58. public static function getBytes(name:String):haxe.io.Bytes {
  59. for (x in content)
  60. if (x.name == name) {
  61. if (x.str != null)
  62. return haxe.io.Bytes.ofString(x.str);
  63. return haxe.crypto.Base64.decode(x.data);
  64. }
  65. return null;
  66. }
  67. static function __init__() {
  68. content = untyped __resources__();
  69. }
  70. }