gfdnavi 1.3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (446) hide show
  1. data/ChangeLog +10949 -0
  2. data/LICENCE.txt +57 -0
  3. data/Makefile +18 -0
  4. data/TODO +132 -0
  5. data/app/controllers/analysis_controller.rb +700 -0
  6. data/app/controllers/application.rb +41 -0
  7. data/app/controllers/draw_method_controller.rb +172 -0
  8. data/app/controllers/explorer_controller.rb +197 -0
  9. data/app/controllers/finder_controller.rb +331 -0
  10. data/app/controllers/function_controller.rb +204 -0
  11. data/app/controllers/group_controller.rb +115 -0
  12. data/app/controllers/keyword_attributes_controller.rb +52 -0
  13. data/app/controllers/knowledge_controller.rb +928 -0
  14. data/app/controllers/nodes_controller.rb +515 -0
  15. data/app/controllers/search_controller.rb +341 -0
  16. data/app/controllers/user_controller.rb +337 -0
  17. data/app/helpers/analysis_helper.rb +2 -0
  18. data/app/helpers/application_helper.rb +105 -0
  19. data/app/helpers/description_helper.rb +2 -0
  20. data/app/helpers/function_helper.rb +2 -0
  21. data/app/helpers/group_helper.rb +2 -0
  22. data/app/helpers/search_helper.rb +3 -0
  23. data/app/helpers/user_helper.rb +2 -0
  24. data/app/helpers/work_flow_helper.rb +92 -0
  25. data/app/models/actual_file.rb +3 -0
  26. data/app/models/analysis.rb +715 -0
  27. data/app/models/analysis_history.rb +42 -0
  28. data/app/models/cross_array.rb +22 -0
  29. data/app/models/cross_result.rb +254 -0
  30. data/app/models/derived_spatial_attribute.rb +3 -0
  31. data/app/models/diagram_cache.rb +16 -0
  32. data/app/models/diagram_cache_datum.rb +4 -0
  33. data/app/models/diagram_cache_session.rb +8 -0
  34. data/app/models/directory.rb +21 -0
  35. data/app/models/draw_method.rb +48 -0
  36. data/app/models/draw_method_attribute.rb +8 -0
  37. data/app/models/draw_parameter.rb +12 -0
  38. data/app/models/explorer_query.rb +354 -0
  39. data/app/models/explorer_result.rb +312 -0
  40. data/app/models/function.rb +75 -0
  41. data/app/models/function_argument.rb +6 -0
  42. data/app/models/function_output.rb +4 -0
  43. data/app/models/group.rb +153 -0
  44. data/app/models/image.rb +20 -0
  45. data/app/models/keyword_attribute.rb +179 -0
  46. data/app/models/knowledge.rb +94 -0
  47. data/app/models/knowledge_backup.rb +32 -0
  48. data/app/models/knowledge_figure.rb +16 -0
  49. data/app/models/knowledge_figure_backup.rb +16 -0
  50. data/app/models/knowledge_parser.rb +392 -0
  51. data/app/models/node.rb +605 -0
  52. data/app/models/node_entity_abstract.rb +112 -0
  53. data/app/models/node_lineage.rb +6 -0
  54. data/app/models/node_relation.rb +4 -0
  55. data/app/models/path_node.rb +60 -0
  56. data/app/models/query.rb +193 -0
  57. data/app/models/query_history.rb +12 -0
  58. data/app/models/results.rb +48 -0
  59. data/app/models/sign_up_user.rb +25 -0
  60. data/app/models/spatial_and_time_attribute.rb +11 -0
  61. data/app/models/user.rb +115 -0
  62. data/app/models/user_mailer.rb +48 -0
  63. data/app/models/value_type.rb +3 -0
  64. data/app/models/variable.rb +70 -0
  65. data/app/models/virtual_node.rb +457 -0
  66. data/app/views/analysis/__help_analysis_tab.en.html +57 -0
  67. data/app/views/analysis/__help_draw_share.en.html +12 -0
  68. data/app/views/analysis/__help_draw_tab.en.html +6 -0
  69. data/app/views/analysis/_analysis_function_settings.rhtml +61 -0
  70. data/app/views/analysis/_analysis_settings.rhtml +28 -0
  71. data/app/views/analysis/_diagram.rhtml +70 -0
  72. data/app/views/analysis/_dimension_option.rhtml +59 -0
  73. data/app/views/analysis/_draw_general_settings.rhtml +217 -0
  74. data/app/views/analysis/_draw_settings.rhtml +73 -0
  75. data/app/views/analysis/_history.rhtml +19 -0
  76. data/app/views/analysis/_popular_diagrams.rhtml +42 -0
  77. data/app/views/analysis/_save_form.rhtml +44 -0
  78. data/app/views/analysis/_variables.rhtml +66 -0
  79. data/app/views/analysis/_variables_order.rhtml +56 -0
  80. data/app/views/analysis/index.rhtml +195 -0
  81. data/app/views/analysis/preview.rhtml +3 -0
  82. data/app/views/analysis/save.rhtml +73 -0
  83. data/app/views/analysis/show_diagram.rhtml +42 -0
  84. data/app/views/cross/_display_map.rhtml +201 -0
  85. data/app/views/cross/_result.rhtml +205 -0
  86. data/app/views/cross/_show_result_tree.rhtml +40 -0
  87. data/app/views/cross/_show_results.rhtml +80 -0
  88. data/app/views/cross/_style.rhtml +21 -0
  89. data/app/views/cross/index.rhtml +271 -0
  90. data/app/views/draw_method/_edit_form.rhtml +110 -0
  91. data/app/views/draw_method/create.rhtml +8 -0
  92. data/app/views/draw_method/details.rhtml +113 -0
  93. data/app/views/draw_method/edit.rhtml +8 -0
  94. data/app/views/draw_method/list.rhtml +80 -0
  95. data/app/views/explorer/_display_map.rhtml +199 -0
  96. data/app/views/explorer/_show_result_tree.rhtml +40 -0
  97. data/app/views/explorer/_show_results.rhtml +101 -0
  98. data/app/views/explorer/_style.rhtml +21 -0
  99. data/app/views/explorer/index.rhtml +214 -0
  100. data/app/views/finder/_children.html.erb +84 -0
  101. data/app/views/finder/_children_details.html.erb +74 -0
  102. data/app/views/finder/_children_details_tr.html.erb +196 -0
  103. data/app/views/finder/create_tree.html.erb +15 -0
  104. data/app/views/finder/flex.html.erb +52 -0
  105. data/app/views/finder/index.html.erb +47 -0
  106. data/app/views/finder/show_details.html.erb +3 -0
  107. data/app/views/finder/show_images.html.erb +3 -0
  108. data/app/views/function/_edit_form.rhtml +106 -0
  109. data/app/views/function/create.rhtml +8 -0
  110. data/app/views/function/details.rhtml +96 -0
  111. data/app/views/function/edit.rhtml +8 -0
  112. data/app/views/function/list.rhtml +80 -0
  113. data/app/views/group/add_member.rhtml +13 -0
  114. data/app/views/group/change_owner.rhtml +15 -0
  115. data/app/views/group/create.rhtml +11 -0
  116. data/app/views/group/delete_member.rhtml +14 -0
  117. data/app/views/group/list.rhtml +63 -0
  118. data/app/views/knowledge/_backup.rhtml +135 -0
  119. data/app/views/knowledge/_category.rhtml +58 -0
  120. data/app/views/knowledge/_category_list.rhtml +34 -0
  121. data/app/views/knowledge/_category_table.rhtml +23 -0
  122. data/app/views/knowledge/_comment.rhtml +64 -0
  123. data/app/views/knowledge/_comment_input_form.rhtml +19 -0
  124. data/app/views/knowledge/_comments.rhtml +84 -0
  125. data/app/views/knowledge/_form.rhtml +139 -0
  126. data/app/views/knowledge/_group_figure_form.rhtml +187 -0
  127. data/app/views/knowledge/_layout_figure.rhtml +61 -0
  128. data/app/views/knowledge/_layout_figures_in_a_row_above_text.rhtml +42 -0
  129. data/app/views/knowledge/_layout_figures_under_text.rhtml +45 -0
  130. data/app/views/knowledge/_layout_one_figure_above_text.rhtml +28 -0
  131. data/app/views/knowledge/_summary.rhtml +21 -0
  132. data/app/views/knowledge/edit.rhtml +37 -0
  133. data/app/views/knowledge/list.rhtml +287 -0
  134. data/app/views/knowledge/new.rhtml +23 -0
  135. data/app/views/knowledge/new_from_analysis.rhtml +21 -0
  136. data/app/views/knowledge/show.rhtml +196 -0
  137. data/app/views/layouts/gfdnavi.rhtml +105 -0
  138. data/app/views/nodes/_ancestors.html.erb +89 -0
  139. data/app/views/nodes/_description_methods_table.html.erb +75 -0
  140. data/app/views/nodes/_mode.html.erb +16 -0
  141. data/app/views/nodes/description.html.erb +181 -0
  142. data/app/views/nodes/description_methods.html.erb +1 -0
  143. data/app/views/nodes/edit.html.erb +73 -0
  144. data/app/views/nodes/index.html.erb +25 -0
  145. data/app/views/nodes/show.html.erb +20 -0
  146. data/app/views/search/_children_details_mapsearch.rhtml +68 -0
  147. data/app/views/search/_children_details_tr.rhtml +205 -0
  148. data/app/views/search/_show_grouplist.rhtml +74 -0
  149. data/app/views/search/_show_results.rhtml +43 -0
  150. data/app/views/search/_show_results_global.rhtml +36 -0
  151. data/app/views/search/_show_results_partial.rhtml +39 -0
  152. data/app/views/search/_show_results_partial_groupbyfile.rhtml +50 -0
  153. data/app/views/search/_show_variablelist.rhtml +28 -0
  154. data/app/views/search/mapsearch.rhtml +176 -0
  155. data/app/views/search/remapsearch.rjs +18 -0
  156. data/app/views/search/show_details.rhtml +3 -0
  157. data/app/views/user/add_user.rhtml +30 -0
  158. data/app/views/user/change_password.rhtml +25 -0
  159. data/app/views/user/edit.html.erb +50 -0
  160. data/app/views/user/index.rhtml +162 -0
  161. data/app/views/user/login.rhtml +41 -0
  162. data/app/views/user/logout.rhtml +4 -0
  163. data/app/views/user/signup.rhtml +36 -0
  164. data/app/views/user/signup_succeeded.rhtml +36 -0
  165. data/app/views/user_mailer/authorization_inform.rhtml +15 -0
  166. data/app/views/user_mailer/signup_accepted.rhtml +12 -0
  167. data/app/views/user_mailer/signup_confirm.rhtml +14 -0
  168. data/app/views/user_mailer/signup_inform.rhtml +13 -0
  169. data/app/views/user_mailer/signup_rejected.rhtml +11 -0
  170. data/app/views/work_flow/_push_wsdls.rhtml +55 -0
  171. data/app/views/work_flow/index.rhtml +46 -0
  172. data/config/database.yml.example +35 -0
  173. data/config/environment.rb +68 -0
  174. data/config/gfdnavi.yml.example +95 -0
  175. data/config/load_config.rb +151 -0
  176. data/config/routes.rb +35 -0
  177. data/consistency_checker.rb +129 -0
  178. data/data/gfdnavi_docs/how_to_draw_multiple_images.knlge +68 -0
  179. data/data/gfdnavi_docs/how_to_knowledge.knlge +138 -0
  180. data/data/gfdnavi_docs/how_to_write_document_about_Gfdnavi.knlge +30 -0
  181. data/data/samples/jmadata.SIGEN +8 -0
  182. data/data/samples/jmadata.yml +6 -0
  183. data/data/samples/jmadata/MSM-P/2006.nc.yml +2 -0
  184. data/data/samples/jmadata/MSM-P/2006.yml +17 -0
  185. data/data/samples/jmadata/MSM-P/2006/0101.nc +0 -0
  186. data/data/samples/jmadata/MSM-P/2006/0101.nc.yml +13 -0
  187. data/data/samples/jmadata/MSM-P/2006/0102.nc +0 -0
  188. data/data/samples/jmadata/MSM-P/2006/0103.nc +0 -0
  189. data/data/samples/jmadata/MSM-P/2006/0104.nc +0 -0
  190. data/data/samples/jmadata/MSM-P/2006/0105.nc +0 -0
  191. data/data/samples/jmadata/MSM-P/2006/010[1-3].nc.yml +2 -0
  192. data/data/samples/jmadata/MSM-P/2006/skip_data.rb +96 -0
  193. data/data/samples/jmadata/MSM-P/2006/skip_data.sh +6 -0
  194. data/data/samples/reanalysis.SIGEN +8 -0
  195. data/data/samples/reanalysis/era40.SIGEN +8 -0
  196. data/data/samples/reanalysis/era40.yml +2 -0
  197. data/data/samples/reanalysis/era40/t.jan.nc +0 -0
  198. data/data/samples/reanalysis/era40/t.jan.nc.yml +1 -0
  199. data/data/samples/reanalysis/ncep.SIGEN +9 -0
  200. data/data/samples/reanalysis/ncep/T.jan.100hPa.png +0 -0
  201. data/data/samples/reanalysis/ncep/T.jan.100hPa.png.yml +43 -0
  202. data/data/samples/reanalysis/ncep/T.jan.nc +0 -0
  203. data/data/samples/reanalysis/ncep/T.jan.zonal_mean.nc +0 -0
  204. data/data/samples/reanalysis/ncep/T.jan.zonal_mean.nc.yml +8 -0
  205. data/data/samples/reanalysis/ncep/T.jan_only_root.nc +0 -0
  206. data/data/samples/reanalysis/ncep/T.jan_only_root.nc.yml +4 -0
  207. data/data/samples/reanalysis/ncep/UV.jan.nc +0 -0
  208. data/data/samples/reanalysis/ncep/UV.jan.nc.yml +10 -0
  209. data/data/samples/reanalysis/ncep/UV.jan.nc.yml.ja +11 -0
  210. data/data/samples/sonde_operational.yml +5 -0
  211. data/data/samples/sonde_operational/std_plev.yml +12 -0
  212. data/data/samples/sonde_operational/std_plev/41256.spl.nc +0 -0
  213. data/data/samples/sonde_operational/std_plev/42410.spl.nc +0 -0
  214. data/data/samples/sonde_operational/std_plev/43333.spl.nc +0 -0
  215. data/data/samples/sonde_operational/std_plev/43346.spl.nc +0 -0
  216. data/data/samples/sonde_operational/std_plev/48698.spl.nc +0 -0
  217. data/data/samples/sonde_operational/std_plev/61641.spl.nc +0 -0
  218. data/data/samples/sonde_operational/std_plev/63741.spl.nc +0 -0
  219. data/data/samples/sonde_operational/std_plev/67083.spl.nc +0 -0
  220. data/data/samples/sonde_operational/std_plev/72261.spl.nc +0 -0
  221. data/data/samples/sonde_operational/std_plev/76805.spl.nc +0 -0
  222. data/data/samples/sonde_operational/std_plev/82193.spl.nc +0 -0
  223. data/data/samples/sonde_operational/std_plev/91165.spl.nc +0 -0
  224. data/data/samples/sonde_operational/std_plev/91610.spl.nc +0 -0
  225. data/data/samples/sonde_operational/std_plev/91948.spl.nc +0 -0
  226. data/data/samples/sonde_operational/std_plev/94294.spl.nc +0 -0
  227. data/db/NetCDFparser.rb +406 -0
  228. data/db/create_derived_spatial_attributes.sql +12 -0
  229. data/db/draw_methods/line.yml +6 -0
  230. data/db/draw_methods/scatter.yml +38 -0
  231. data/db/draw_methods/tone.yml +64 -0
  232. data/db/draw_methods/vector.yml +19 -0
  233. data/db/dump_db.rb +43 -0
  234. data/db/functions/additions.yml +10 -0
  235. data/db/functions/cut.yml +10 -0
  236. data/db/functions/division.yml +10 -0
  237. data/db/functions/mean.yml +28 -0
  238. data/db/functions/multiplication.yml +10 -0
  239. data/db/functions/stddev.yml +28 -0
  240. data/db/functions/subtraction.yml +10 -0
  241. data/db/migrate/001_initial_scheme.rb +289 -0
  242. data/db/migrate/002_add_open_id_authentication_tables.rb +20 -0
  243. data/db/register_directory_tree.rb +760 -0
  244. data/db/restore_db.rb +60 -0
  245. data/gfdnavi-install +828 -0
  246. data/install.rb +828 -0
  247. data/lib/activerecord_gfdnavi.rb +31 -0
  248. data/lib/basic_authorization.rb +50 -0
  249. data/lib/create_activeresources.rb +108 -0
  250. data/lib/execute_analysis.rb +472 -0
  251. data/lib/file_gfdnavi.rb +38 -0
  252. data/lib/gphys_gfdnavi.rb +81 -0
  253. data/lib/localdir.rb +110 -0
  254. data/lib/login_system.rb +110 -0
  255. data/lib/multibytes.rb +20 -0
  256. data/lib/narray_yaml.rb +58 -0
  257. data/lib/no_rdb_base.rb +40 -0
  258. data/lib/opendapdir.rb +171 -0
  259. data/lib/tar.rb +127 -0
  260. data/lib/tasks/clean.rake +65 -0
  261. data/lib/tasks/setup.rake +316 -0
  262. data/lib/tasks/update.rake +62 -0
  263. data/lib/vizshot_gfdnavi.rb +224 -0
  264. data/public/crossdomain.xml +4 -0
  265. data/public/flex/NodeTreeDescriptor.as +55 -0
  266. data/public/flex/TreeNode.as +253 -0
  267. data/public/flex/finder.mxml +304 -0
  268. data/public/flex/finder.swf +0 -0
  269. data/public/flex/gfdnavi.mxml +52 -0
  270. data/public/flex/gfdnavi.swf +0 -0
  271. data/public/images/Help_S-shots/dir_tree_with_add.jpg +0 -0
  272. data/public/images/analyze.gif +0 -0
  273. data/public/images/circle.gif +0 -0
  274. data/public/images/create_from_analysis_button.png +0 -0
  275. data/public/images/delete.png +0 -0
  276. data/public/images/down.png +0 -0
  277. data/public/images/drawbutton.gif +0 -0
  278. data/public/images/gfdnavi_home_logo.png +0 -0
  279. data/public/images/gfdnavi_logo_big.png +0 -0
  280. data/public/images/gfdnavi_logo_med.png +0 -0
  281. data/public/images/gfdnavi_logo_mini.png +0 -0
  282. data/public/images/gfdnavi_logo_nobg_big.png +0 -0
  283. data/public/images/gfdnavi_logo_nobg_med.png +0 -0
  284. data/public/images/gfdnavi_logo_nobg_small.png +0 -0
  285. data/public/images/gfdnavi_logo_small.png +0 -0
  286. data/public/images/gfdnavi_logo_xsmall.png +0 -0
  287. data/public/images/hbar.png +0 -0
  288. data/public/images/helpmark16.png +0 -0
  289. data/public/images/helpmark18.png +0 -0
  290. data/public/images/kikyu_g.gif +0 -0
  291. data/public/images/kikyu_r.gif +0 -0
  292. data/public/images/map_icon_g.gif +0 -0
  293. data/public/images/map_icon_r.gif +0 -0
  294. data/public/images/new_knowledge.png +0 -0
  295. data/public/images/openid.png +0 -0
  296. data/public/images/read_in_the_form.png +0 -0
  297. data/public/images/slider_f.gif +0 -0
  298. data/public/images/slider_f_red.gif +0 -0
  299. data/public/images/star1.gif +0 -0
  300. data/public/images/star2.gif +0 -0
  301. data/public/images/startanim.gif +0 -0
  302. data/public/images/stopanim.gif +0 -0
  303. data/public/images/tree/DL.png +0 -0
  304. data/public/images/tree/anal_viz.png +0 -0
  305. data/public/images/tree/analyze_visualize_checked_items.png +0 -0
  306. data/public/images/tree/binary.png +0 -0
  307. data/public/images/tree/details.png +0 -0
  308. data/public/images/tree/download_checked_items.png +0 -0
  309. data/public/images/tree/folder.png +0 -0
  310. data/public/images/tree/folder_close.gif +0 -0
  311. data/public/images/tree/image2.png +0 -0
  312. data/public/images/tree/knowledge.png +0 -0
  313. data/public/images/tree/knowledges.png +0 -0
  314. data/public/images/tree/last.gif +0 -0
  315. data/public/images/tree/last.png +0 -0
  316. data/public/images/tree/minus.gif +0 -0
  317. data/public/images/tree/minus_simple.gif +0 -0
  318. data/public/images/tree/none.gif +0 -0
  319. data/public/images/tree/none.png +0 -0
  320. data/public/images/tree/plus.gif +0 -0
  321. data/public/images/tree/plus_simple.gif +0 -0
  322. data/public/images/tree/show.png +0 -0
  323. data/public/images/tree/show_checked_items.png +0 -0
  324. data/public/images/tree/t.gif +0 -0
  325. data/public/images/tree/t.png +0 -0
  326. data/public/images/tree/tate.gif +0 -0
  327. data/public/images/tree/tate.png +0 -0
  328. data/public/images/up.png +0 -0
  329. data/public/images/vbar.png +0 -0
  330. data/public/images/white.bmp +0 -0
  331. data/public/images/x.gif +0 -0
  332. data/public/index.html +100 -0
  333. data/public/javascripts/AC_OETags.js +269 -0
  334. data/public/javascripts/analysis.js +751 -0
  335. data/public/javascripts/application.js +29 -0
  336. data/public/javascripts/directory_tree.js +102 -0
  337. data/public/javascripts/draw_method.js +83 -0
  338. data/public/javascripts/excanvas.js +704 -0
  339. data/public/javascripts/function.js +107 -0
  340. data/public/javascripts/gfdnavi.js +175 -0
  341. data/public/javascripts/knowledge.js +384 -0
  342. data/public/javascripts/mapsearch.js +313 -0
  343. data/public/javascripts/progress.js +42 -0
  344. data/public/javascripts/resizable_box.js +164 -0
  345. data/public/javascripts/slider.js +260 -0
  346. data/public/javascripts/tab.js +17 -0
  347. data/public/javascripts/work_flow.js +452 -0
  348. data/public/stylesheets/analysis.css +111 -0
  349. data/public/stylesheets/description.css +71 -0
  350. data/public/stylesheets/gfdnavi.css +141 -0
  351. data/public/stylesheets/knowledge.css +218 -0
  352. data/public/stylesheets/search.css +184 -0
  353. data/public/stylesheets/tree.css +45 -0
  354. data/public/stylesheets/tree_for_ie.css +3 -0
  355. data/public/stylesheets/work_flow.css +78 -0
  356. data/script/cleaner +11 -0
  357. data/script/server_ssl +131 -0
  358. data/test/fixtures/diagram_cache_data.yml +5 -0
  359. data/test/fixtures/diagram_cache_sessions.yml +6 -0
  360. data/test/fixtures/diagram_caches.yml +6 -0
  361. data/test/fixtures/directories.yml +57 -0
  362. data/test/fixtures/draw_parameters.yml +6 -0
  363. data/test/fixtures/function_arguments.yml +15 -0
  364. data/test/fixtures/function_outputs.yml +15 -0
  365. data/test/fixtures/functions.yml +29 -0
  366. data/test/fixtures/group_members.yml +33 -0
  367. data/test/fixtures/groups.yml +25 -0
  368. data/test/fixtures/images.yml +12 -0
  369. data/test/fixtures/keyword_attributes.yml +73 -0
  370. data/test/fixtures/knowledges.yml +10 -0
  371. data/test/fixtures/node_relations.yml +11 -0
  372. data/test/fixtures/nodes.yml +298 -0
  373. data/test/fixtures/sign_up_users.yml +8 -0
  374. data/test/fixtures/spatial_and_time_attributes.yml +29 -0
  375. data/test/fixtures/user_mailer/authorization_inform +11 -0
  376. data/test/fixtures/user_mailer/signup_accepted +10 -0
  377. data/test/fixtures/user_mailer/signup_confirm +17 -0
  378. data/test/fixtures/user_mailer/signup_inform +10 -0
  379. data/test/fixtures/user_mailer/signup_rejected +9 -0
  380. data/test/fixtures/users.yml +31 -0
  381. data/test/fixtures/value_types.yml +10 -0
  382. data/test/fixtures/variables.yml +17 -0
  383. data/test/functional/analysis_controller_test.rb +169 -0
  384. data/test/functional/description_controller_test.rb +18 -0
  385. data/test/functional/function_controller_test.rb +18 -0
  386. data/test/functional/group_controller_test.rb +18 -0
  387. data/test/functional/search_controller_test.rb +83 -0
  388. data/test/functional/user_controller_test.rb +77 -0
  389. data/test/functional/webservice_analysis_api_test.rb +12 -0
  390. data/test/functional/work_flow_controller_test.rb +18 -0
  391. data/test/test_helper.rb +28 -0
  392. data/test/unit/diagram_cache_datum_test.rb +10 -0
  393. data/test/unit/diagram_cache_session_test.rb +10 -0
  394. data/test/unit/diagram_cache_test.rb +10 -0
  395. data/test/unit/directory_test.rb +49 -0
  396. data/test/unit/draw_parameter_test.rb +10 -0
  397. data/test/unit/function_argument_test.rb +10 -0
  398. data/test/unit/function_output_test.rb +10 -0
  399. data/test/unit/function_test.rb +10 -0
  400. data/test/unit/group_test.rb +48 -0
  401. data/test/unit/image_test.rb +13 -0
  402. data/test/unit/keyword_attribute_test.rb +33 -0
  403. data/test/unit/knowledge_test.rb +13 -0
  404. data/test/unit/node_relation_test.rb +20 -0
  405. data/test/unit/node_test.rb +85 -0
  406. data/test/unit/sign_up_user_test.rb +20 -0
  407. data/test/unit/spatial_and_time_attribute_test.rb +29 -0
  408. data/test/unit/user_mailer_test.rb +101 -0
  409. data/test/unit/user_test.rb +134 -0
  410. data/test/unit/value_type_test.rb +10 -0
  411. data/test/unit/variable_test.rb +35 -0
  412. data/vendor/plugins/acts_as_list/README +23 -0
  413. data/vendor/plugins/acts_as_list/init.rb +3 -0
  414. data/vendor/plugins/acts_as_list/lib/active_record/acts/list.rb +256 -0
  415. data/vendor/plugins/acts_as_list/test/list_test.rb +332 -0
  416. data/vendor/plugins/acts_as_tree/README +26 -0
  417. data/vendor/plugins/acts_as_tree/Rakefile +22 -0
  418. data/vendor/plugins/acts_as_tree/init.rb +1 -0
  419. data/vendor/plugins/acts_as_tree/lib/active_record/acts/tree.rb +96 -0
  420. data/vendor/plugins/acts_as_tree/test/abstract_unit.rb +0 -0
  421. data/vendor/plugins/acts_as_tree/test/acts_as_tree_test.rb +219 -0
  422. data/vendor/plugins/acts_as_tree/test/database.yml +0 -0
  423. data/vendor/plugins/acts_as_tree/test/fixtures/mixin.rb +0 -0
  424. data/vendor/plugins/acts_as_tree/test/fixtures/mixins.yml +0 -0
  425. data/vendor/plugins/acts_as_tree/test/schema.rb +0 -0
  426. data/vendor/plugins/will_paginate/CHANGELOG +92 -0
  427. data/vendor/plugins/will_paginate/LICENSE +18 -0
  428. data/vendor/plugins/will_paginate/README.rdoc +131 -0
  429. data/vendor/plugins/will_paginate/Rakefile +62 -0
  430. data/vendor/plugins/will_paginate/examples/apple-circle.gif +0 -0
  431. data/vendor/plugins/will_paginate/examples/index.haml +69 -0
  432. data/vendor/plugins/will_paginate/examples/index.html +92 -0
  433. data/vendor/plugins/will_paginate/examples/pagination.css +90 -0
  434. data/vendor/plugins/will_paginate/examples/pagination.sass +91 -0
  435. data/vendor/plugins/will_paginate/init.rb +1 -0
  436. data/vendor/plugins/will_paginate/lib/will_paginate.rb +86 -0
  437. data/vendor/plugins/will_paginate/lib/will_paginate/array.rb +16 -0
  438. data/vendor/plugins/will_paginate/lib/will_paginate/collection.rb +145 -0
  439. data/vendor/plugins/will_paginate/lib/will_paginate/core_ext.rb +32 -0
  440. data/vendor/plugins/will_paginate/lib/will_paginate/finder.rb +247 -0
  441. data/vendor/plugins/will_paginate/lib/will_paginate/named_scope.rb +132 -0
  442. data/vendor/plugins/will_paginate/lib/will_paginate/named_scope_patch.rb +39 -0
  443. data/vendor/plugins/will_paginate/lib/will_paginate/version.rb +9 -0
  444. data/vendor/plugins/will_paginate/lib/will_paginate/view_helpers.rb +373 -0
  445. data/vendor/plugins/will_paginate/will_paginate.gemspec +21 -0
  446. metadata +586 -0
@@ -0,0 +1,13 @@
1
+ description:
2
+ Derived from the http://davis.rish.kyoto-u.ac.jp/arch/jmadata/data/gpv/netcdf/MSM-P/2006/.
3
+ contains:
4
+ temp:
5
+ missing_value: 999.0e+0
6
+ gfdnavi:
7
+ draw_parameters:
8
+ tone_contour: false
9
+ tone_max: 5
10
+ tone_min: -5
11
+ user: root
12
+ %:
13
+ remark: number of grid points are significantly reduced by thinning.
@@ -0,0 +1,2 @@
1
+ ---
2
+ remark: This is a vertual united file
@@ -0,0 +1,96 @@
1
+ #!/usr/bin/env ruby
2
+ require "optparse"
3
+ require "numru/gphys"
4
+ include NumRu
5
+
6
+ opt = OptionParser.new
7
+ OPTS = {}
8
+ ARGV.options{|opt|
9
+ opt.on( '-o=VAL', '--output=VAL',
10
+ "Output file"
11
+ ){|v| OPTS[:output] = v.gsub(/^=/, '')}
12
+
13
+ opt.on( '-s=VAL', '--skip=VAL',
14
+ "Skip interval
15
+ (ex. \"10,5,8,0\". 0 is not skipped)"
16
+ ){|v| OPTS[:skip] = v.gsub(/^=/, '')}
17
+
18
+ opt.on( '--copy-dims=VAL',
19
+ "Copy dimensions additionally
20
+ (ex. \"ref_time,lon_weight\")"
21
+ ){|v| OPTS[:copy_dims] = v.gsub(/^=/, '')}
22
+
23
+ opt.on_tail('-h', '-H', '--help',
24
+ "This help message is output"
25
+ ){|v| OPTS[:help] = v}
26
+ opt.parse!
27
+ }
28
+
29
+ if OPTS[:help] || !(OPTS[:output]) || ARGV.size < 1 || !(OPTS[:skip])
30
+ print <<-"EOF"
31
+
32
+ #{File.basename($0.to_s)}:
33
+
34
+ USAGE: #{File.basename($0.to_s)} [options] input_url -o output_file -s skip_interval
35
+
36
+ OPTION: \n#{opt.to_a[1..-1].join("")}
37
+ EOF
38
+ exit
39
+ end
40
+
41
+ #=== �e��ݒ�
42
+ input_url = ARGV[0]
43
+ output_file = OPTS[:output]
44
+ skip_intervals = OPTS[:skip].split(',')
45
+ skip_intervals.collect!{|skipchar|
46
+ skipint = skipchar.to_i
47
+ if skipint > 0
48
+ skipint
49
+ else
50
+ 1
51
+ end
52
+ }
53
+ copy_dims = []
54
+ copy_dims = OPTS[:copy_dims].split(',') if OPTS[:copy_dims]
55
+
56
+ #=== �ǂݍ���, �������݃t�@�C���̃I�[�v��
57
+ gphys = GPhys::IO.open_gturl(input_url)
58
+ outfile = NetCDF.create(output_file)
59
+
60
+ #=== ��摮���R�s�[
61
+ gphys.data.file.each_att{|att|
62
+ outfile.put_att(att.name, att.get)
63
+ }
64
+
65
+ #=== �f�[�^�̊Ԉ��� (�[�����Ƃ͍l����)
66
+ reduced_size_array = Array.new(gphys.rank)
67
+ gphys.rank.times{ |dim_index|
68
+ dim_size = gphys.coord(dim_index).val.size
69
+ interval = skip_intervals[dim_index] || 1
70
+ if dim_size < interval
71
+ reduced_size_array[dim_index] = 0
72
+ next
73
+ elsif interval == 1
74
+ reduced_size_array[dim_index] = 0..-1
75
+ next
76
+ end
77
+ reduced_size = dim_size / interval
78
+ reduced_size_array[dim_index] = Array.new(reduced_size)
79
+ reduced_size.times{|n| reduced_size_array[dim_index][n] = n*interval}
80
+ }
81
+
82
+ gphys = gphys[*reduced_size_array]
83
+
84
+ #=== �t�@�C���o��
85
+ if File.exist?(output_file)
86
+ print " *** MESSAGE *** \"#{output_file}\" is overwritten.\n"
87
+ end
88
+ GPhys::NetCDF_IO.write(outfile, gphys)
89
+
90
+ #=== �lj��̎����ϐ������o��
91
+ copy_dims.each{|dim|
92
+ gphys_dim = GPhys::IO.open_gturl(input_url.sub(/@\w+$/, "@#{dim}"))
93
+ GPhys::NetCDF_IO.write_grid(outfile, gphys_dim)
94
+ }
95
+
96
+ outfile.close
@@ -0,0 +1,6 @@
1
+ #!/bin/sh
2
+ for nc in `ls orig/????.nc` ; do
3
+ new_file=`basename $nc`
4
+ echo "$nc -> $new_file"
5
+ ruby skip_data.rb $nc@temp -o $new_file -s 10,10,2 --copy-dims=ref_time
6
+ done
@@ -0,0 +1,8 @@
1
+ Subject: �ĉ�̓f�[�^
2
+ Maintainer: �X�� ����
3
+ Description:
4
+ Note:
5
+ Update: 2006/09/12
6
+
7
+ ����
8
+ 2006/09/12 �X�� ����
@@ -0,0 +1,8 @@
1
+ Subject: ERA40 �ĉ�̓f�[�^
2
+ Maintainer: ���V�@����
3
+ Description: ERA �Ō��J����Ă���ĉ�̓f�[�^
4
+ Note:
5
+ Update: 2007/01/26
6
+
7
+ ����
8
+ 2007/01/26 ���V�@����
@@ -0,0 +1,2 @@
1
+ gfdnavi:
2
+ downloadable: false
@@ -0,0 +1 @@
1
+ --- {}
@@ -0,0 +1,9 @@
1
+ Subject: NCEP �ĉ�̓f�[�^
2
+ Maintainer: �X�� ����
3
+ Description: �č��‹��\���Z���^�[ (NCEP) �Ō��J����Ă���
4
+ �ĉ�̓f�[�^
5
+ Note:
6
+ Update: 2006/09/13
7
+
8
+ ����
9
+ 2006/09/13 �X�� ����
@@ -0,0 +1,43 @@
1
+ ---
2
+ gfdnavi:
3
+ vizshot: |
4
+ --- !ruby/object:NumRu::VizShot
5
+ plots:
6
+ - :file: /samples/reanalysis/ncep/T.jan.nc
7
+ :cut:
8
+ lon: !ruby/range
9
+ begin: 0.0
10
+ end: 350.0
11
+ excl: false
12
+ level: 1000.0
13
+ lat: !ruby/range
14
+ begin: 90.0
15
+ end: -90.0
16
+ excl: false
17
+ log: false
18
+ :tone: true
19
+ :var: T
20
+ :color_bar: true
21
+ :contour: true
22
+ :method: :tone_cont
23
+ set:
24
+ :tone:
25
+ tonf: true
26
+ :fig:
27
+ itr: 1
28
+ viewport:
29
+ - 0.2
30
+ - 0.8
31
+ - 0.2
32
+ - 0.8
33
+ :admin:
34
+ :ydiv: 1
35
+ :basename: temp
36
+ :iwidth: 550
37
+ :iheight: 550
38
+ :xdiv: 1
39
+ user: root
40
+ references:
41
+ - name: draw
42
+ path: /samples/reanalysis/ncep/T.jan.nc/T
43
+ description: Longitude-latitude cross section of climatorogy temperature in January
@@ -0,0 +1,8 @@
1
+ ---
2
+ contains:
3
+ T_mean:
4
+ gfdnavi:
5
+ references:
6
+ - name: analyze
7
+ path: /samples/reanalysis/ncep/T.jan.nc/T
8
+ analysis: mean calculated from T
@@ -0,0 +1,4 @@
1
+ test: test
2
+ gfdnavi:
3
+ user: root
4
+ other_mode: 0
@@ -0,0 +1,10 @@
1
+ title: ncep climatology
2
+ description:
3
+ Derived from the ncep reanalysis climatology data.
4
+ contains:
5
+ U:
6
+ long_name: Zonal Wind
7
+ V:
8
+ long_name: Merional Wind
9
+ %:
10
+ remark: number of grid points are significantly reduced by thinning.
@@ -0,0 +1,11 @@
1
+ title: �č��‹��\���Z���^�[ (NCEP) / �č�������C�����Z���^�[ (NCAR)
2
+ �ĉ�̓f�[�^����̋C��l
3
+ comments: ���̃f�[�^��, �I���W�i���f�[�^���Ԉ����������̂ł�.
4
+ #contains:
5
+ # U:
6
+ # ������: ������
7
+ # �����l: -9.96921e+36f
8
+ # V:
9
+ # ������: �q�ߖʕ�
10
+ # *:
11
+ # remark: number of grid points are significantly reduced by thinning.
@@ -0,0 +1,5 @@
1
+ title: operation radiosonde data archive
2
+
3
+ description:
4
+ Archive of operational radiosonde data transmitted originally
5
+ through WMO's GTS network.
@@ -0,0 +1,12 @@
1
+ title: starndard pressure level data
2
+
3
+ creator: N. Hashiguchi, RISH, Kyoto Univ.
4
+
5
+ description:
6
+ The raw data obtained from NCEP were screened
7
+ with an algorithm suitable for the tropical conditions.
8
+ The files archived here contains data only at the
9
+ standard pressure levels.
10
+
11
+ See http://dss.ucar.edu/datasets/ds353.4/ for more
12
+ info on the original data.
@@ -0,0 +1,406 @@
1
+ #
2
+ # NetCDF�t�@�C����gfdnavi�f�[�^�x�[�X�ɓo�^����
3
+ # ���߂̃N���X
4
+ #
5
+ class NetCDFparser
6
+
7
+ def initialize(file,rw="r",topdir="/",quiet=false)
8
+ @filename=file
9
+ @rw=rw
10
+ @io=NetCDF.open(@filename,@rw)
11
+ @temporal_rangeinfo={}
12
+ @spatial_rangeinfo={}
13
+ # @topdir=File.expand_path(topdir)
14
+ @topdir=File.expand_path(GFDNAVI_DATA_PATH)
15
+ @quiet=quiet
16
+
17
+ #�ܓx�o�x���Ԃ̑��������i�b��I�ɒ������j
18
+ @varname={}
19
+ @varname["longitude"]=["lon","longitude"]
20
+ @varname["latitude"]=["lat","latitude"]
21
+ @varname["time"]=["time"]
22
+ end
23
+
24
+ def close
25
+ @io.close
26
+ end
27
+
28
+ # �t�@�C��@filename���f�[�^�x�[�X�ɓo�^����
29
+ def regist
30
+ regist_directory(@filename)
31
+ regist_globalattributes
32
+
33
+ find_spatial_variables("longitude")
34
+ find_spatial_variables("latitude")
35
+ find_temporal_variable
36
+
37
+ @io.each_var do |var|
38
+ vardb=regist_variable(var)
39
+ end
40
+ end
41
+
42
+ #�t�@�C������directories�e�[�u���ɓo�^����
43
+ def regist_directory(fname)
44
+ @dir = Directory.new
45
+ @dir.name = File.basename(fname)
46
+ @dir.path = File.expand_path(fname).sub(/^#{@topdir}\//,'/')
47
+ pdir=Directory.find(:first, :conditions => "path=\"#{File.dirname(File.expand_path(fname))}\"")
48
+ if pdir==nil
49
+ #pdir=regist_directory(File.dirname(fname))
50
+ print "WARNING: #{File.dirname(File.expand_path(fname))} is not found in Directory table.\n"
51
+ else
52
+ @dir.parent_id = pdir.id
53
+ @dir.save
54
+ end
55
+ if !@quiet
56
+ print "Directory #{@dir.name} is registered (id=#{@dir.id}).\n"
57
+ end
58
+ end
59
+
60
+ #�t�@�C���̃O���[�o������directory�ɑ΂���L�[���[�h�����Ƃ���
61
+ #keyword_attributes�e�[�u���ɓo�^����
62
+ def regist_globalattributes
63
+ @io.each_att do |att|
64
+ key = KeywordAttribute.new
65
+ key.directory = @dir
66
+ key.name=att.name
67
+ key.data_type=att.atttype
68
+ key.value=att.get.to_s
69
+ key.save
70
+ end
71
+ end
72
+
73
+ #�evariable�̃L�[���[�h������keyword_attributes�e�[�u���ɓo�^����
74
+ def regist_keyword_attributes(var,vardb)
75
+ var.each_att do |att|
76
+ key = KeywordAttribute.new
77
+ key.variable=vardb
78
+ key.name = att.name
79
+ key.data_type = att.atttype
80
+ key.value = att.get.to_s
81
+ key.save
82
+ end
83
+ end
84
+
85
+ #nc�t�@�C�����Œ�`����Ă��鎞�ԑ��������o��
86
+ #@temporal_rangeinfo�ɂ���Ă���
87
+ #@temporal_rangeinfo�̓n�b�V���e�[�u���̑��d�z��
88
+ # @temporal_rangeinfo[varname][type]
89
+ # varname:������
90
+ # type:{"start_time","end_time","ndims"}������
91
+ # ndims�͑����̎�����
92
+ def find_temporal_variable
93
+ @varname["time"].each do |v|
94
+ var=@io.var(v)
95
+ if var!=nil then
96
+ if var.ndims==0 then
97
+ start_time=end_time=var.get()[0]
98
+ elsif var.ndims==1 then
99
+ timearray=var.get()
100
+ start_time = timearray.min()
101
+ end_time = timearray.max()
102
+ else
103
+ print "Error: time attribute' dimensions cannot be more than 2.\n"
104
+ return
105
+ end
106
+ unit=var.att("units").get
107
+ if unit!=nil then
108
+ start_time=parse_time_since(start_time,unit)
109
+ end_time=parse_time_since(end_time,unit)
110
+ end
111
+ info={}
112
+ info["ndims"]=var.ndims
113
+ info["start_time"]=start_time
114
+ info["end_time"]=end_time
115
+ @temporal_rangeinfo[v]=info
116
+ end
117
+ end
118
+ end
119
+
120
+ #nc�t�@�C�����Œ�`����Ă����ԑ��������o��
121
+ #@spatial_rangeinfo�ɂ���Ă���
122
+ # @spatial_rangeinfo[category][varname][type]
123
+ # category:{"longitude","latitude"}�̂����ꂩ
124
+ #�@�@varname:������
125
+ # type:{"var","range"}�̂����ꂩ������
126
+ # "var"�F�������̂���
127
+ #�@�@�@"range"�F�����l�̂Ƃ肤��͈͂̔z��
128
+ # [[min_0,max_0],...,[min_n,max_n]]
129
+ def find_spatial_variables(category)
130
+ ranges = Array.new
131
+ @varname[category].each do |v|
132
+ var=@io.var(v)
133
+ if var!=nil then
134
+ unit=var.att("units").get
135
+ if var.ndims<2 then
136
+ #point or grid
137
+ values=var.get()
138
+ ranges.push([spunit_convert(category,values.min,unit),spunit_convert(category,values.max,unit)])
139
+ elsif var.ndims()==2 then
140
+ #swath
141
+ dnum=Array.new()
142
+ each_dim do |d|
143
+ dnum.push(d.length_u10())
144
+ end
145
+ i=0
146
+ interval=dnum[0]
147
+ while i<dnum[1]-1 do
148
+ endpoint=i+interval
149
+ if endpoint>=dnum[1] then
150
+ endpoint=dnum[1]-1
151
+ end
152
+ var.get({"start"=>[0,i],"end"=>[dnum[0]-1,endpoint]})
153
+ values.sort()
154
+ ranges.push([spunit_convert(category,values.first,unit),spunit_convert(category,values.last,unit)])
155
+ i=endpoint
156
+ end
157
+ end
158
+ if @spatial_rangeinfo[category]==nil
159
+ @spatial_rangeinfo[category]={}
160
+ end
161
+ if @spatial_rangeinfo[category][v]==nil
162
+ @spatial_rangeinfo[category][v]={}
163
+ end
164
+ @spatial_rangeinfo[category][v]["var"]=var
165
+ @spatial_rangeinfo[category][v]["range"]=ranges
166
+ end
167
+ #check gloval attributes
168
+ att=@io.att(v)
169
+ if att!=nil then
170
+ @spatial_rangeinfo[category][v]["var"]=att
171
+ @spatial_rangeinfo[category][v]["range"]=[[att.get,att.get]]
172
+ end
173
+ end
174
+ end
175
+
176
+ #spunit_convert(category,value,unit)
177
+ def spunit_convert(category,value,unit)
178
+ if unit!=nil
179
+ if category=="latitude"
180
+ if unit!="degree_east"
181
+ ud_to=Units.new('degree_east')
182
+ ud_from=Units.new(unit)
183
+ value=ud_from.convert(value,ud_to)
184
+ end
185
+ elsif category="longitude"
186
+ if unit!="degree_north"
187
+ ud_to=Units.new('degree_north')
188
+ ud_from=Units.new(unit)
189
+ value=ud_from.convert(value,ud_to)
190
+ end
191
+ end
192
+ end
193
+ return value
194
+ end
195
+
196
+ #variable����variables�e�[�u���ɓo�^����
197
+ def regist_variable(var)
198
+ vardb = Variable.new
199
+ vardb.path = "#{@dir.path}"+'@'+"#{var.name}"
200
+ vardb.name = var.name
201
+ vardb.directory = @dir
202
+ unless vardb.save
203
+ $stderr.print vardb.errors.full_messages.join(", "), "\n"
204
+ end
205
+
206
+ regist_spatial_attributes(var,vardb)
207
+ regist_temporal_attribute(var,vardb)
208
+ regist_keyword_attributes(var,vardb)
209
+
210
+ if !@quiet
211
+ print "Variable #{vardb.path} is registered (id=#{vardb.id})\n"
212
+ end
213
+ end
214
+
215
+ #variable�̎��ԏ���variables�e�[�u���ɒlj�����
216
+ def regist_temporal_attribute(var,vardb)
217
+ if @io.dim(var.name)!=nil then
218
+ return
219
+ end
220
+ dnames=var.dim_names
221
+ dnames.each do |dname|
222
+ if @temporal_rangeinfo[dname]!=nil then
223
+ vardb.starttime=@temporal_rangeinfo[dname]["start_time"]
224
+ vardb.endtime=@temporal_rangeinfo[dname]["end_time"]
225
+ vardb.save
226
+ return
227
+ end
228
+ end
229
+ @temporal_rangeinfo.each_value do |rangeinfo|
230
+ if rangeinfo["ndims"]==0 then
231
+ vardb.starttime=rangeinfo["start_time"]
232
+ vardb.endtime=rangeinfo["end_time"]
233
+ vardb.save
234
+ return
235
+ end
236
+ end
237
+ end
238
+
239
+ #variable�̋�ԏ���spatial_attribute�ɓo�^����
240
+ def regist_spatial_attributes(var,vardb)
241
+ #�������p�̃f�[�^�Z�b�g�������ꍇ�͓o�^���Ȃ�
242
+ @io.each_dim do |d|
243
+ if d.name==var.name
244
+ return
245
+ end
246
+ end
247
+
248
+ if var.dims==0 then
249
+ #0�����̏ꍇ��Dir��KeywordAttribute�ɂ��Ă��܂�
250
+ keyattr=KeywordAttribute.new
251
+ keyattr.directory=@dir
252
+ keyattr.name=var.name
253
+ keyattr.data_type=var.vartype
254
+ keyattr.value=var.value
255
+ keyattr.save
256
+ end
257
+
258
+ lon=get_spatial_rangeinfo_by_dims("longitude",var)
259
+ lat=get_spatial_rangeinfo_by_dims("latitude",var)
260
+ #(1) lon,lat�Ƃ��Ɏ�����Ȃ�
261
+ if lon==nil && lat==nil then
262
+ lon0th=get_spatial_rangeinfo_by_ndims("longitude",0)
263
+ lat0th=get_spatial_rangeinfo_by_ndims("latitude",0)
264
+ if lon0th!=nil && lat0th!=nil then
265
+ #(1-a) lon,lat�Ƃ��ɂO�����̑��������遨point�^
266
+ add_spatial_attribute(vardb,lon0th["range"][0],lat0th["range"][0])
267
+ return
268
+ elsif lon0th!=nil then
269
+ #(1-b) lon,lat�̂ǂ��炩���O�����̑�����grid�^
270
+ add_spatial_attribute(vardb,lon0th["range"][0],[-90,90])
271
+ return
272
+ elsif lat0th!=nil then
273
+ add_spatial_attribute(vardb,[0,360],lat0th["range"][0])
274
+ return
275
+ end
276
+ #(1-c) lon,lat��1�����ł��̎����f�[�^�Z�b�g�̎��Ɠ�����point�^
277
+ lon1st=get_spatial_rangeinfo_by_ndims("longitude",1)
278
+ lat1st=get_spatial_rangeinfo_by_ndims("latitude",1)
279
+ if lon1st!=nil && lat1st!=nil && be_present_in(lon1st["var"].dims,var.dims) && be_present_in(lat1st["var"].dims,var.dims) then
280
+ i=0
281
+ lon1st["range"].each do |l|
282
+ add_spatial_attribute(vardb,l,lat1st["range"][i])
283
+ i+=1
284
+ end
285
+ end
286
+ #(1-d) lon,lat��2�����ł��̎����f�[�^�Z�b�g�̎��Ɠ�����swath�^
287
+ lon2nd=get_spatial_rangeinfo_by_ndims("longitude",2)
288
+ lat2nd=get_spatial_rangeinfo_by_ndims("latitude",2)
289
+ if lon2nd!=nil && lat2nd!=nil && be_present_in(lon2nd["var"].dims,var.dims) && be_present_in(lat2nd["var"],var.dims) then
290
+ i=0
291
+ lon2nd["range"].each do |range|
292
+ add_spatial_attribute(vardb,range,lat2nd["range"][i])
293
+ i+=1
294
+ end
295
+ return
296
+ end
297
+ #(2) latitude����
298
+ elsif lon==nil
299
+ lon0th=get_spatial_rangeinfo_by_ndims("longitude",0)
300
+ if lon0th!=nil
301
+ add_spatial_attribute(vardb,lon0th["range"][0],lat["range"][0])
302
+ else
303
+ add_spatial_attribute(vardb,[0,360],lat["range"][0])
304
+ end
305
+ #(3) longitude����
306
+ elsif lat==nil
307
+ lat0th=get_spatial_rangeinfo_by_ndims("latitude",0)
308
+ if lat0th!=nil
309
+ add_spatial_attribute(vardb,lon["range"][0],lat0th["range"][0])
310
+ else
311
+ add_spatial_attribute(vardb,lon["range"][0],[-90,90])
312
+ end
313
+ #(4) longitude,latitude�Ƃ��Ɏ�
314
+ else
315
+ add_spatial_attribute(vardb,lon["range"][0],lat["range"][0])
316
+ end
317
+ end
318
+
319
+ #@spatial_rangeinfo�ɂ����ԑ����̃��X�g����
320
+ #��������ndims�ł�����̂����o��
321
+ #�o�͂����̂̓n�b�V���e�[�u��
322
+ # rangeinfo[type]
323
+ # type: "var","range"�̂����ꂩ
324
+ def get_spatial_rangeinfo_by_ndims(category,ndims)
325
+ @spatial_rangeinfo[category].each_value do |info|
326
+ if info["var"].ndims==ndims then
327
+ return info
328
+ end
329
+ end
330
+ return
331
+ end
332
+
333
+ #@spatial_rangeinfo�ɂ����ԑ����̃��X�g����
334
+ #������var�ł�����͈̂̔͏������o��
335
+ #�o�͂����̂̓n�b�V���e�[�u��
336
+ # rangeinfo[type]
337
+ # type: "var","range"�̂����ꂩ
338
+ def get_spatial_rangeinfo_by_dims(category,var)
339
+ @spatial_rangeinfo[category].each_key do |v|
340
+ dims=var.dims
341
+ dims.each do |d|
342
+ if d.name==v then
343
+ return @spatial_rangeinfo[category][v]
344
+ end
345
+ end
346
+ end
347
+ return
348
+ end
349
+
350
+ #dimb�̒���dima�̗v�f���S���͂����Ă�����true
351
+ #�����łȂ����false��Ԃ�
352
+ def be_present_in(dima,dimb)
353
+ i=0; j=0;
354
+ while i<dima.size do
355
+ flg=false
356
+ while j<dimb.size do
357
+ if dima[i].name==dimb[j].name
358
+ flg=true
359
+ end
360
+ j+=1
361
+ end
362
+ if flg==false then
363
+ return false
364
+ end
365
+ i+=1
366
+ end
367
+ return true
368
+ end
369
+
370
+ #spatial_attributes�e�[�u���ւ̒lj�
371
+ def add_spatial_attribute(var,lon,lat)
372
+ sp=SpatialAttribute.new
373
+ sp.variable=var
374
+ sp.longitude_lb=lon[0]
375
+ sp.longitude_rt=lon[1]
376
+ sp.latitude_lb=lat[0]
377
+ sp.latitude_rt=lat[1]
378
+ sp.save
379
+ end
380
+
381
+ #udunits�\���ɂ�鎞��time�ƒP��units�̒l��
382
+ #�f�[�^�x�[�X��DateTime�^�ŔF���ł���`�ɂ���
383
+ def parse_time_since(time, units)
384
+ if /(\w+) since (.*)/ =~ units
385
+ units = $1
386
+ since = $2
387
+ else
388
+ raise ArgumentError,
389
+ "units '#{units}' is not in the expected form: units since date&time"
390
+ end
391
+ case units
392
+ when /^s$/i,/^sec/i
393
+ time = time/86400.0
394
+ when /^min/i
395
+ time = time/1440.0
396
+ when /^h$/i,/^hour/i
397
+ time = time/24.0
398
+ when /^day/i
399
+ else
400
+ raise ArgumentError, "Sorry, #{units} is not supported. Is it a time unit?"
401
+ end
402
+ eps = 1e-7 # adjuster to avoid unwanted round off
403
+ DateTime.parse(since) + ( time + eps )
404
+ end
405
+
406
+ end