summaryrefslogtreecommitdiffstats
path: root/lib/efl/native
diff options
context:
space:
mode:
Diffstat (limited to 'lib/efl/native')
-rw-r--r--lib/efl/native/emap.rb93
1 files changed, 93 insertions, 0 deletions
diff --git a/lib/efl/native/emap.rb b/lib/efl/native/emap.rb
new file mode 100644
index 0000000..7bad804
--- /dev/null
+++ b/lib/efl/native/emap.rb
@@ -0,0 +1,93 @@
+#! /usr/bin/env ruby
+# -*- coding: UTF-8 -*-
+#
+require 'efl/ffi'
+#
+module Efl
+ #
+ module EMap
+ #
+ FCT_PREFIX = 'emap_'
+ #
+ def self.method_missing m, *args, &block
+ sym, args_s = ModuleHelper.find_function m, FCT_PREFIX
+ self.module_eval "def self.#{m} *args, █ r=Efl::Native.#{sym}(#{args_s}); yield r if block_given?; r; end"
+ self.send m, *args, &block
+ end
+ #
+ end
+ #
+ module Native
+ #
+ extend Efl::FFIHelper
+ #
+ ffi_lib 'emap'
+ #
+ # ENUMS
+ # typedef enum emap_route_type {...} EMap_Route_Type;
+ enum :emap_route_type, [ :emap_track_type_gpx ]
+ #
+ # TYPEDEFS
+ # typedef struct emap_route EMap_Route;
+ typedef :pointer, :emap_route
+ typedef :pointer, :emap_route_p
+ # typedef struct emap_route_node EMap_Route_Node;
+ typedef :pointer, :emap_route_node
+ typedef :pointer, :emap_route_node_p
+ #
+ # CALLBACKS
+ #
+ # VARIABLES
+ #
+ # FUNCTIONS
+ fcts = [
+ # EAPI int emap_init();
+ [ :emap_init, [ ], :int ],
+ # EAPI int emap_shutdown();
+ [ :emap_shutdown, [ ], :int ],
+ # EAPI EMap_Route *emap_route_new();
+ [ :emap_route_new, [ ], :emap_route_p ],
+ # EAPI void emap_route_node_add(EMap_Route *route, EMap_Route_Node *node);
+ [ :emap_route_node_add, [ :emap_route_p, :emap_route_node_p ], :void ],
+ # EAPI void emap_route_free(EMap_Route *route);
+ [ :emap_route_free, [ :emap_route_p ], :void ],
+ # EAPI void emap_route_name_set(EMap_Route *route, const char *name);
+ [ :emap_route_name_set, [ :emap_route_p, :string ], :void ],
+ # EAPI const char *emap_route_name_get(EMap_Route *route);
+ [ :emap_route_name_get, [ :emap_route_p ], :string ],
+ # EAPI Eina_List *emap_route_nodes_get(EMap_Route *route);
+ [ :emap_route_nodes_get, [ :emap_route_p ], :eina_list_p ],
+ # EAPI double emap_route_distance_get(EMap_Route *route);
+ [ :emap_route_distance_get, [ :emap_route_p ], :double ],
+ # EAPI EMap_Route_Node *emap_route_node_new();
+ [ :emap_route_node_new, [ ], :emap_route_node_p ],
+ # EAPI void emap_route_node_lon_set(EMap_Route_Node *node, double lon);
+ [ :emap_route_node_lon_set, [ :emap_route_node_p, :double ], :void ],
+ # EAPI void emap_route_node_lat_set(EMap_Route_Node *node, double lat);
+ [ :emap_route_node_lat_set, [ :emap_route_node_p, :double ], :void ],
+ # EAPI double emap_route_node_lon_get(EMap_Route_Node *node);
+ [ :emap_route_node_lon_get, [ :emap_route_node_p ], :double ],
+ # EAPI double emap_route_node_lat_get(EMap_Route_Node *node);
+ [ :emap_route_node_lat_get, [ :emap_route_node_p ], :double ],
+ # EAPI void emap_route_node_elevation_set(EMap_Route_Node *node, double elevation);
+ [ :emap_route_node_elevation_set, [ :emap_route_node_p, :double ], :void ],
+ # EAPI double emap_route_node_elevation_get(EMap_Route_Node *node);
+ [ :emap_route_node_elevation_get, [ :emap_route_node_p ], :double ],
+ # EAPI void emap_route_node_time_set(EMap_Route_Node *node, time_t time);
+ [ :emap_route_node_time_set, [ :emap_route_node_p, :ulong ], :void ],
+ # EAPI time_t emap_route_node_time_get(EMap_Route_Node *node);
+ [ :emap_route_node_time_get, [ :emap_route_node_p ], :ulong ],
+ # EAPI double emap_route_nodes_distance_get(EMap_Route_Node *A, EMap_Route_Node *B);
+ [ :emap_route_nodes_distance_get, [ :emap_route_node_p, :emap_route_node_p ], :double ],
+ # EAPI void emap_route_node_free(EMap_Route_Node *node);
+ [ :emap_route_node_free, [ :emap_route_node_p ], :void ],
+ # EAPI EMap_Route * emap_route_gpx_new(const char *file);
+ [ :emap_route_gpx_new, [ :string ], :emap_route_p ],
+ ]
+ #
+ attach_fcts fcts
+ #
+ end
+end
+#
+# EOF