gfdnavi 1.3.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/ChangeLog +10949 -0
- data/LICENCE.txt +57 -0
- data/Makefile +18 -0
- data/TODO +132 -0
- data/app/controllers/analysis_controller.rb +700 -0
- data/app/controllers/application.rb +41 -0
- data/app/controllers/draw_method_controller.rb +172 -0
- data/app/controllers/explorer_controller.rb +197 -0
- data/app/controllers/finder_controller.rb +331 -0
- data/app/controllers/function_controller.rb +204 -0
- data/app/controllers/group_controller.rb +115 -0
- data/app/controllers/keyword_attributes_controller.rb +52 -0
- data/app/controllers/knowledge_controller.rb +928 -0
- data/app/controllers/nodes_controller.rb +515 -0
- data/app/controllers/search_controller.rb +341 -0
- data/app/controllers/user_controller.rb +337 -0
- data/app/helpers/analysis_helper.rb +2 -0
- data/app/helpers/application_helper.rb +105 -0
- data/app/helpers/description_helper.rb +2 -0
- data/app/helpers/function_helper.rb +2 -0
- data/app/helpers/group_helper.rb +2 -0
- data/app/helpers/search_helper.rb +3 -0
- data/app/helpers/user_helper.rb +2 -0
- data/app/helpers/work_flow_helper.rb +92 -0
- data/app/models/actual_file.rb +3 -0
- data/app/models/analysis.rb +715 -0
- data/app/models/analysis_history.rb +42 -0
- data/app/models/cross_array.rb +22 -0
- data/app/models/cross_result.rb +254 -0
- data/app/models/derived_spatial_attribute.rb +3 -0
- data/app/models/diagram_cache.rb +16 -0
- data/app/models/diagram_cache_datum.rb +4 -0
- data/app/models/diagram_cache_session.rb +8 -0
- data/app/models/directory.rb +21 -0
- data/app/models/draw_method.rb +48 -0
- data/app/models/draw_method_attribute.rb +8 -0
- data/app/models/draw_parameter.rb +12 -0
- data/app/models/explorer_query.rb +354 -0
- data/app/models/explorer_result.rb +312 -0
- data/app/models/function.rb +75 -0
- data/app/models/function_argument.rb +6 -0
- data/app/models/function_output.rb +4 -0
- data/app/models/group.rb +153 -0
- data/app/models/image.rb +20 -0
- data/app/models/keyword_attribute.rb +179 -0
- data/app/models/knowledge.rb +94 -0
- data/app/models/knowledge_backup.rb +32 -0
- data/app/models/knowledge_figure.rb +16 -0
- data/app/models/knowledge_figure_backup.rb +16 -0
- data/app/models/knowledge_parser.rb +392 -0
- data/app/models/node.rb +605 -0
- data/app/models/node_entity_abstract.rb +112 -0
- data/app/models/node_lineage.rb +6 -0
- data/app/models/node_relation.rb +4 -0
- data/app/models/path_node.rb +60 -0
- data/app/models/query.rb +193 -0
- data/app/models/query_history.rb +12 -0
- data/app/models/results.rb +48 -0
- data/app/models/sign_up_user.rb +25 -0
- data/app/models/spatial_and_time_attribute.rb +11 -0
- data/app/models/user.rb +115 -0
- data/app/models/user_mailer.rb +48 -0
- data/app/models/value_type.rb +3 -0
- data/app/models/variable.rb +70 -0
- data/app/models/virtual_node.rb +457 -0
- data/app/views/analysis/__help_analysis_tab.en.html +57 -0
- data/app/views/analysis/__help_draw_share.en.html +12 -0
- data/app/views/analysis/__help_draw_tab.en.html +6 -0
- data/app/views/analysis/_analysis_function_settings.rhtml +61 -0
- data/app/views/analysis/_analysis_settings.rhtml +28 -0
- data/app/views/analysis/_diagram.rhtml +70 -0
- data/app/views/analysis/_dimension_option.rhtml +59 -0
- data/app/views/analysis/_draw_general_settings.rhtml +217 -0
- data/app/views/analysis/_draw_settings.rhtml +73 -0
- data/app/views/analysis/_history.rhtml +19 -0
- data/app/views/analysis/_popular_diagrams.rhtml +42 -0
- data/app/views/analysis/_save_form.rhtml +44 -0
- data/app/views/analysis/_variables.rhtml +66 -0
- data/app/views/analysis/_variables_order.rhtml +56 -0
- data/app/views/analysis/index.rhtml +195 -0
- data/app/views/analysis/preview.rhtml +3 -0
- data/app/views/analysis/save.rhtml +73 -0
- data/app/views/analysis/show_diagram.rhtml +42 -0
- data/app/views/cross/_display_map.rhtml +201 -0
- data/app/views/cross/_result.rhtml +205 -0
- data/app/views/cross/_show_result_tree.rhtml +40 -0
- data/app/views/cross/_show_results.rhtml +80 -0
- data/app/views/cross/_style.rhtml +21 -0
- data/app/views/cross/index.rhtml +271 -0
- data/app/views/draw_method/_edit_form.rhtml +110 -0
- data/app/views/draw_method/create.rhtml +8 -0
- data/app/views/draw_method/details.rhtml +113 -0
- data/app/views/draw_method/edit.rhtml +8 -0
- data/app/views/draw_method/list.rhtml +80 -0
- data/app/views/explorer/_display_map.rhtml +199 -0
- data/app/views/explorer/_show_result_tree.rhtml +40 -0
- data/app/views/explorer/_show_results.rhtml +101 -0
- data/app/views/explorer/_style.rhtml +21 -0
- data/app/views/explorer/index.rhtml +214 -0
- data/app/views/finder/_children.html.erb +84 -0
- data/app/views/finder/_children_details.html.erb +74 -0
- data/app/views/finder/_children_details_tr.html.erb +196 -0
- data/app/views/finder/create_tree.html.erb +15 -0
- data/app/views/finder/flex.html.erb +52 -0
- data/app/views/finder/index.html.erb +47 -0
- data/app/views/finder/show_details.html.erb +3 -0
- data/app/views/finder/show_images.html.erb +3 -0
- data/app/views/function/_edit_form.rhtml +106 -0
- data/app/views/function/create.rhtml +8 -0
- data/app/views/function/details.rhtml +96 -0
- data/app/views/function/edit.rhtml +8 -0
- data/app/views/function/list.rhtml +80 -0
- data/app/views/group/add_member.rhtml +13 -0
- data/app/views/group/change_owner.rhtml +15 -0
- data/app/views/group/create.rhtml +11 -0
- data/app/views/group/delete_member.rhtml +14 -0
- data/app/views/group/list.rhtml +63 -0
- data/app/views/knowledge/_backup.rhtml +135 -0
- data/app/views/knowledge/_category.rhtml +58 -0
- data/app/views/knowledge/_category_list.rhtml +34 -0
- data/app/views/knowledge/_category_table.rhtml +23 -0
- data/app/views/knowledge/_comment.rhtml +64 -0
- data/app/views/knowledge/_comment_input_form.rhtml +19 -0
- data/app/views/knowledge/_comments.rhtml +84 -0
- data/app/views/knowledge/_form.rhtml +139 -0
- data/app/views/knowledge/_group_figure_form.rhtml +187 -0
- data/app/views/knowledge/_layout_figure.rhtml +61 -0
- data/app/views/knowledge/_layout_figures_in_a_row_above_text.rhtml +42 -0
- data/app/views/knowledge/_layout_figures_under_text.rhtml +45 -0
- data/app/views/knowledge/_layout_one_figure_above_text.rhtml +28 -0
- data/app/views/knowledge/_summary.rhtml +21 -0
- data/app/views/knowledge/edit.rhtml +37 -0
- data/app/views/knowledge/list.rhtml +287 -0
- data/app/views/knowledge/new.rhtml +23 -0
- data/app/views/knowledge/new_from_analysis.rhtml +21 -0
- data/app/views/knowledge/show.rhtml +196 -0
- data/app/views/layouts/gfdnavi.rhtml +105 -0
- data/app/views/nodes/_ancestors.html.erb +89 -0
- data/app/views/nodes/_description_methods_table.html.erb +75 -0
- data/app/views/nodes/_mode.html.erb +16 -0
- data/app/views/nodes/description.html.erb +181 -0
- data/app/views/nodes/description_methods.html.erb +1 -0
- data/app/views/nodes/edit.html.erb +73 -0
- data/app/views/nodes/index.html.erb +25 -0
- data/app/views/nodes/show.html.erb +20 -0
- data/app/views/search/_children_details_mapsearch.rhtml +68 -0
- data/app/views/search/_children_details_tr.rhtml +205 -0
- data/app/views/search/_show_grouplist.rhtml +74 -0
- data/app/views/search/_show_results.rhtml +43 -0
- data/app/views/search/_show_results_global.rhtml +36 -0
- data/app/views/search/_show_results_partial.rhtml +39 -0
- data/app/views/search/_show_results_partial_groupbyfile.rhtml +50 -0
- data/app/views/search/_show_variablelist.rhtml +28 -0
- data/app/views/search/mapsearch.rhtml +176 -0
- data/app/views/search/remapsearch.rjs +18 -0
- data/app/views/search/show_details.rhtml +3 -0
- data/app/views/user/add_user.rhtml +30 -0
- data/app/views/user/change_password.rhtml +25 -0
- data/app/views/user/edit.html.erb +50 -0
- data/app/views/user/index.rhtml +162 -0
- data/app/views/user/login.rhtml +41 -0
- data/app/views/user/logout.rhtml +4 -0
- data/app/views/user/signup.rhtml +36 -0
- data/app/views/user/signup_succeeded.rhtml +36 -0
- data/app/views/user_mailer/authorization_inform.rhtml +15 -0
- data/app/views/user_mailer/signup_accepted.rhtml +12 -0
- data/app/views/user_mailer/signup_confirm.rhtml +14 -0
- data/app/views/user_mailer/signup_inform.rhtml +13 -0
- data/app/views/user_mailer/signup_rejected.rhtml +11 -0
- data/app/views/work_flow/_push_wsdls.rhtml +55 -0
- data/app/views/work_flow/index.rhtml +46 -0
- data/config/database.yml.example +35 -0
- data/config/environment.rb +68 -0
- data/config/gfdnavi.yml.example +95 -0
- data/config/load_config.rb +151 -0
- data/config/routes.rb +35 -0
- data/consistency_checker.rb +129 -0
- data/data/gfdnavi_docs/how_to_draw_multiple_images.knlge +68 -0
- data/data/gfdnavi_docs/how_to_knowledge.knlge +138 -0
- data/data/gfdnavi_docs/how_to_write_document_about_Gfdnavi.knlge +30 -0
- data/data/samples/jmadata.SIGEN +8 -0
- data/data/samples/jmadata.yml +6 -0
- data/data/samples/jmadata/MSM-P/2006.nc.yml +2 -0
- data/data/samples/jmadata/MSM-P/2006.yml +17 -0
- data/data/samples/jmadata/MSM-P/2006/0101.nc +0 -0
- data/data/samples/jmadata/MSM-P/2006/0101.nc.yml +13 -0
- data/data/samples/jmadata/MSM-P/2006/0102.nc +0 -0
- data/data/samples/jmadata/MSM-P/2006/0103.nc +0 -0
- data/data/samples/jmadata/MSM-P/2006/0104.nc +0 -0
- data/data/samples/jmadata/MSM-P/2006/0105.nc +0 -0
- data/data/samples/jmadata/MSM-P/2006/010[1-3].nc.yml +2 -0
- data/data/samples/jmadata/MSM-P/2006/skip_data.rb +96 -0
- data/data/samples/jmadata/MSM-P/2006/skip_data.sh +6 -0
- data/data/samples/reanalysis.SIGEN +8 -0
- data/data/samples/reanalysis/era40.SIGEN +8 -0
- data/data/samples/reanalysis/era40.yml +2 -0
- data/data/samples/reanalysis/era40/t.jan.nc +0 -0
- data/data/samples/reanalysis/era40/t.jan.nc.yml +1 -0
- data/data/samples/reanalysis/ncep.SIGEN +9 -0
- data/data/samples/reanalysis/ncep/T.jan.100hPa.png +0 -0
- data/data/samples/reanalysis/ncep/T.jan.100hPa.png.yml +43 -0
- data/data/samples/reanalysis/ncep/T.jan.nc +0 -0
- data/data/samples/reanalysis/ncep/T.jan.zonal_mean.nc +0 -0
- data/data/samples/reanalysis/ncep/T.jan.zonal_mean.nc.yml +8 -0
- data/data/samples/reanalysis/ncep/T.jan_only_root.nc +0 -0
- data/data/samples/reanalysis/ncep/T.jan_only_root.nc.yml +4 -0
- data/data/samples/reanalysis/ncep/UV.jan.nc +0 -0
- data/data/samples/reanalysis/ncep/UV.jan.nc.yml +10 -0
- data/data/samples/reanalysis/ncep/UV.jan.nc.yml.ja +11 -0
- data/data/samples/sonde_operational.yml +5 -0
- data/data/samples/sonde_operational/std_plev.yml +12 -0
- data/data/samples/sonde_operational/std_plev/41256.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/42410.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/43333.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/43346.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/48698.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/61641.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/63741.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/67083.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/72261.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/76805.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/82193.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/91165.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/91610.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/91948.spl.nc +0 -0
- data/data/samples/sonde_operational/std_plev/94294.spl.nc +0 -0
- data/db/NetCDFparser.rb +406 -0
- data/db/create_derived_spatial_attributes.sql +12 -0
- data/db/draw_methods/line.yml +6 -0
- data/db/draw_methods/scatter.yml +38 -0
- data/db/draw_methods/tone.yml +64 -0
- data/db/draw_methods/vector.yml +19 -0
- data/db/dump_db.rb +43 -0
- data/db/functions/additions.yml +10 -0
- data/db/functions/cut.yml +10 -0
- data/db/functions/division.yml +10 -0
- data/db/functions/mean.yml +28 -0
- data/db/functions/multiplication.yml +10 -0
- data/db/functions/stddev.yml +28 -0
- data/db/functions/subtraction.yml +10 -0
- data/db/migrate/001_initial_scheme.rb +289 -0
- data/db/migrate/002_add_open_id_authentication_tables.rb +20 -0
- data/db/register_directory_tree.rb +760 -0
- data/db/restore_db.rb +60 -0
- data/gfdnavi-install +828 -0
- data/install.rb +828 -0
- data/lib/activerecord_gfdnavi.rb +31 -0
- data/lib/basic_authorization.rb +50 -0
- data/lib/create_activeresources.rb +108 -0
- data/lib/execute_analysis.rb +472 -0
- data/lib/file_gfdnavi.rb +38 -0
- data/lib/gphys_gfdnavi.rb +81 -0
- data/lib/localdir.rb +110 -0
- data/lib/login_system.rb +110 -0
- data/lib/multibytes.rb +20 -0
- data/lib/narray_yaml.rb +58 -0
- data/lib/no_rdb_base.rb +40 -0
- data/lib/opendapdir.rb +171 -0
- data/lib/tar.rb +127 -0
- data/lib/tasks/clean.rake +65 -0
- data/lib/tasks/setup.rake +316 -0
- data/lib/tasks/update.rake +62 -0
- data/lib/vizshot_gfdnavi.rb +224 -0
- data/public/crossdomain.xml +4 -0
- data/public/flex/NodeTreeDescriptor.as +55 -0
- data/public/flex/TreeNode.as +253 -0
- data/public/flex/finder.mxml +304 -0
- data/public/flex/finder.swf +0 -0
- data/public/flex/gfdnavi.mxml +52 -0
- data/public/flex/gfdnavi.swf +0 -0
- data/public/images/Help_S-shots/dir_tree_with_add.jpg +0 -0
- data/public/images/analyze.gif +0 -0
- data/public/images/circle.gif +0 -0
- data/public/images/create_from_analysis_button.png +0 -0
- data/public/images/delete.png +0 -0
- data/public/images/down.png +0 -0
- data/public/images/drawbutton.gif +0 -0
- data/public/images/gfdnavi_home_logo.png +0 -0
- data/public/images/gfdnavi_logo_big.png +0 -0
- data/public/images/gfdnavi_logo_med.png +0 -0
- data/public/images/gfdnavi_logo_mini.png +0 -0
- data/public/images/gfdnavi_logo_nobg_big.png +0 -0
- data/public/images/gfdnavi_logo_nobg_med.png +0 -0
- data/public/images/gfdnavi_logo_nobg_small.png +0 -0
- data/public/images/gfdnavi_logo_small.png +0 -0
- data/public/images/gfdnavi_logo_xsmall.png +0 -0
- data/public/images/hbar.png +0 -0
- data/public/images/helpmark16.png +0 -0
- data/public/images/helpmark18.png +0 -0
- data/public/images/kikyu_g.gif +0 -0
- data/public/images/kikyu_r.gif +0 -0
- data/public/images/map_icon_g.gif +0 -0
- data/public/images/map_icon_r.gif +0 -0
- data/public/images/new_knowledge.png +0 -0
- data/public/images/openid.png +0 -0
- data/public/images/read_in_the_form.png +0 -0
- data/public/images/slider_f.gif +0 -0
- data/public/images/slider_f_red.gif +0 -0
- data/public/images/star1.gif +0 -0
- data/public/images/star2.gif +0 -0
- data/public/images/startanim.gif +0 -0
- data/public/images/stopanim.gif +0 -0
- data/public/images/tree/DL.png +0 -0
- data/public/images/tree/anal_viz.png +0 -0
- data/public/images/tree/analyze_visualize_checked_items.png +0 -0
- data/public/images/tree/binary.png +0 -0
- data/public/images/tree/details.png +0 -0
- data/public/images/tree/download_checked_items.png +0 -0
- data/public/images/tree/folder.png +0 -0
- data/public/images/tree/folder_close.gif +0 -0
- data/public/images/tree/image2.png +0 -0
- data/public/images/tree/knowledge.png +0 -0
- data/public/images/tree/knowledges.png +0 -0
- data/public/images/tree/last.gif +0 -0
- data/public/images/tree/last.png +0 -0
- data/public/images/tree/minus.gif +0 -0
- data/public/images/tree/minus_simple.gif +0 -0
- data/public/images/tree/none.gif +0 -0
- data/public/images/tree/none.png +0 -0
- data/public/images/tree/plus.gif +0 -0
- data/public/images/tree/plus_simple.gif +0 -0
- data/public/images/tree/show.png +0 -0
- data/public/images/tree/show_checked_items.png +0 -0
- data/public/images/tree/t.gif +0 -0
- data/public/images/tree/t.png +0 -0
- data/public/images/tree/tate.gif +0 -0
- data/public/images/tree/tate.png +0 -0
- data/public/images/up.png +0 -0
- data/public/images/vbar.png +0 -0
- data/public/images/white.bmp +0 -0
- data/public/images/x.gif +0 -0
- data/public/index.html +100 -0
- data/public/javascripts/AC_OETags.js +269 -0
- data/public/javascripts/analysis.js +751 -0
- data/public/javascripts/application.js +29 -0
- data/public/javascripts/directory_tree.js +102 -0
- data/public/javascripts/draw_method.js +83 -0
- data/public/javascripts/excanvas.js +704 -0
- data/public/javascripts/function.js +107 -0
- data/public/javascripts/gfdnavi.js +175 -0
- data/public/javascripts/knowledge.js +384 -0
- data/public/javascripts/mapsearch.js +313 -0
- data/public/javascripts/progress.js +42 -0
- data/public/javascripts/resizable_box.js +164 -0
- data/public/javascripts/slider.js +260 -0
- data/public/javascripts/tab.js +17 -0
- data/public/javascripts/work_flow.js +452 -0
- data/public/stylesheets/analysis.css +111 -0
- data/public/stylesheets/description.css +71 -0
- data/public/stylesheets/gfdnavi.css +141 -0
- data/public/stylesheets/knowledge.css +218 -0
- data/public/stylesheets/search.css +184 -0
- data/public/stylesheets/tree.css +45 -0
- data/public/stylesheets/tree_for_ie.css +3 -0
- data/public/stylesheets/work_flow.css +78 -0
- data/script/cleaner +11 -0
- data/script/server_ssl +131 -0
- data/test/fixtures/diagram_cache_data.yml +5 -0
- data/test/fixtures/diagram_cache_sessions.yml +6 -0
- data/test/fixtures/diagram_caches.yml +6 -0
- data/test/fixtures/directories.yml +57 -0
- data/test/fixtures/draw_parameters.yml +6 -0
- data/test/fixtures/function_arguments.yml +15 -0
- data/test/fixtures/function_outputs.yml +15 -0
- data/test/fixtures/functions.yml +29 -0
- data/test/fixtures/group_members.yml +33 -0
- data/test/fixtures/groups.yml +25 -0
- data/test/fixtures/images.yml +12 -0
- data/test/fixtures/keyword_attributes.yml +73 -0
- data/test/fixtures/knowledges.yml +10 -0
- data/test/fixtures/node_relations.yml +11 -0
- data/test/fixtures/nodes.yml +298 -0
- data/test/fixtures/sign_up_users.yml +8 -0
- data/test/fixtures/spatial_and_time_attributes.yml +29 -0
- data/test/fixtures/user_mailer/authorization_inform +11 -0
- data/test/fixtures/user_mailer/signup_accepted +10 -0
- data/test/fixtures/user_mailer/signup_confirm +17 -0
- data/test/fixtures/user_mailer/signup_inform +10 -0
- data/test/fixtures/user_mailer/signup_rejected +9 -0
- data/test/fixtures/users.yml +31 -0
- data/test/fixtures/value_types.yml +10 -0
- data/test/fixtures/variables.yml +17 -0
- data/test/functional/analysis_controller_test.rb +169 -0
- data/test/functional/description_controller_test.rb +18 -0
- data/test/functional/function_controller_test.rb +18 -0
- data/test/functional/group_controller_test.rb +18 -0
- data/test/functional/search_controller_test.rb +83 -0
- data/test/functional/user_controller_test.rb +77 -0
- data/test/functional/webservice_analysis_api_test.rb +12 -0
- data/test/functional/work_flow_controller_test.rb +18 -0
- data/test/test_helper.rb +28 -0
- data/test/unit/diagram_cache_datum_test.rb +10 -0
- data/test/unit/diagram_cache_session_test.rb +10 -0
- data/test/unit/diagram_cache_test.rb +10 -0
- data/test/unit/directory_test.rb +49 -0
- data/test/unit/draw_parameter_test.rb +10 -0
- data/test/unit/function_argument_test.rb +10 -0
- data/test/unit/function_output_test.rb +10 -0
- data/test/unit/function_test.rb +10 -0
- data/test/unit/group_test.rb +48 -0
- data/test/unit/image_test.rb +13 -0
- data/test/unit/keyword_attribute_test.rb +33 -0
- data/test/unit/knowledge_test.rb +13 -0
- data/test/unit/node_relation_test.rb +20 -0
- data/test/unit/node_test.rb +85 -0
- data/test/unit/sign_up_user_test.rb +20 -0
- data/test/unit/spatial_and_time_attribute_test.rb +29 -0
- data/test/unit/user_mailer_test.rb +101 -0
- data/test/unit/user_test.rb +134 -0
- data/test/unit/value_type_test.rb +10 -0
- data/test/unit/variable_test.rb +35 -0
- data/vendor/plugins/acts_as_list/README +23 -0
- data/vendor/plugins/acts_as_list/init.rb +3 -0
- data/vendor/plugins/acts_as_list/lib/active_record/acts/list.rb +256 -0
- data/vendor/plugins/acts_as_list/test/list_test.rb +332 -0
- data/vendor/plugins/acts_as_tree/README +26 -0
- data/vendor/plugins/acts_as_tree/Rakefile +22 -0
- data/vendor/plugins/acts_as_tree/init.rb +1 -0
- data/vendor/plugins/acts_as_tree/lib/active_record/acts/tree.rb +96 -0
- data/vendor/plugins/acts_as_tree/test/abstract_unit.rb +0 -0
- data/vendor/plugins/acts_as_tree/test/acts_as_tree_test.rb +219 -0
- data/vendor/plugins/acts_as_tree/test/database.yml +0 -0
- data/vendor/plugins/acts_as_tree/test/fixtures/mixin.rb +0 -0
- data/vendor/plugins/acts_as_tree/test/fixtures/mixins.yml +0 -0
- data/vendor/plugins/acts_as_tree/test/schema.rb +0 -0
- data/vendor/plugins/will_paginate/CHANGELOG +92 -0
- data/vendor/plugins/will_paginate/LICENSE +18 -0
- data/vendor/plugins/will_paginate/README.rdoc +131 -0
- data/vendor/plugins/will_paginate/Rakefile +62 -0
- data/vendor/plugins/will_paginate/examples/apple-circle.gif +0 -0
- data/vendor/plugins/will_paginate/examples/index.haml +69 -0
- data/vendor/plugins/will_paginate/examples/index.html +92 -0
- data/vendor/plugins/will_paginate/examples/pagination.css +90 -0
- data/vendor/plugins/will_paginate/examples/pagination.sass +91 -0
- data/vendor/plugins/will_paginate/init.rb +1 -0
- data/vendor/plugins/will_paginate/lib/will_paginate.rb +86 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/array.rb +16 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/collection.rb +145 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/core_ext.rb +32 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/finder.rb +247 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/named_scope.rb +132 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/named_scope_patch.rb +39 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/version.rb +9 -0
- data/vendor/plugins/will_paginate/lib/will_paginate/view_helpers.rb +373 -0
- data/vendor/plugins/will_paginate/will_paginate.gemspec +21 -0
- metadata +586 -0
data/LICENCE.txt
ADDED
@@ -0,0 +1,57 @@
|
|
1
|
+
Gfdnavi is copyrighted free software by GFD Dennou Club.
|
2
|
+
You can redistribute it and/or modify it under either the terms of the GPL
|
3
|
+
or the conditions below (same conditions as the licence of the Ruby
|
4
|
+
programming language):
|
5
|
+
|
6
|
+
1. You may make and give away verbatim copies of the source form of the
|
7
|
+
software without restriction, provided that you duplicate all of the
|
8
|
+
original copyright notices and associated disclaimers.
|
9
|
+
|
10
|
+
2. You may modify your copy of the software in any way, provided that
|
11
|
+
you do at least ONE of the following:
|
12
|
+
|
13
|
+
a) place your modifications in the Public Domain or otherwise
|
14
|
+
make them Freely Available, such as by posting said
|
15
|
+
modifications to Usenet or an equivalent medium, or by allowing
|
16
|
+
the author to include your modifications in the software.
|
17
|
+
|
18
|
+
b) use the modified software only within your corporation or
|
19
|
+
organization.
|
20
|
+
|
21
|
+
c) rename any non-standard executables so the names do not conflict
|
22
|
+
with standard executables, which must also be provided.
|
23
|
+
|
24
|
+
d) make other distribution arrangements with the author.
|
25
|
+
|
26
|
+
3. You may distribute the software in object code or executable
|
27
|
+
form, provided that you do at least ONE of the following:
|
28
|
+
|
29
|
+
a) distribute the executables and library files of the software,
|
30
|
+
together with instructions (in the manual page or equivalent)
|
31
|
+
on where to get the original distribution.
|
32
|
+
|
33
|
+
b) accompany the distribution with the machine-readable source of
|
34
|
+
the software.
|
35
|
+
|
36
|
+
c) give non-standard executables non-standard names, with
|
37
|
+
instructions on where to get the original software distribution.
|
38
|
+
|
39
|
+
d) make other distribution arrangements with the author.
|
40
|
+
|
41
|
+
4. You may modify and include the part of the software into any other
|
42
|
+
software (possibly commercial). But some files in the distribution
|
43
|
+
are not written by the author, so that they are not under this terms.
|
44
|
+
|
45
|
+
They are the files under the directory vendor.
|
46
|
+
|
47
|
+
5. The scripts and library files supplied as input to or produced as
|
48
|
+
output from the software do not automatically fall under the
|
49
|
+
copyright of the software, but belong to whomever generated them,
|
50
|
+
and may be sold commercially, and may be aggregated with this
|
51
|
+
software.
|
52
|
+
|
53
|
+
6. THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
|
54
|
+
IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
55
|
+
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
56
|
+
PURPOSE.
|
57
|
+
|
data/Makefile
ADDED
@@ -0,0 +1,18 @@
|
|
1
|
+
cl:
|
2
|
+
@cvs2cl --help > /dev/null 2>&1 || \
|
3
|
+
echo -e \
|
4
|
+
"\n" \
|
5
|
+
" cvs2cl is not found.\n" \
|
6
|
+
" Please get from http://www.red-bean.com/cvs2cl/\n"
|
7
|
+
@cvs2cl --help > /dev/null 2>&1 && \
|
8
|
+
echo -e \
|
9
|
+
"This file is generated automatically by\n" \
|
10
|
+
"\n" \
|
11
|
+
" cvs2cl -r -b -t --fsf -w --header <This header>\n" \
|
12
|
+
"\n" \
|
13
|
+
`cvs2cl --version` "\n" \
|
14
|
+
"This script is available from " \
|
15
|
+
"http://www.red-bean.com/cvs2cl/\n\n" \
|
16
|
+
| cvs2cl -r -b -t --fsf -w --header -
|
17
|
+
rm ChangeLog.bak
|
18
|
+
@echo -e "\n" "ChangeLog is Updated." "\n"
|
data/TODO
ADDED
@@ -0,0 +1,132 @@
|
|
1
|
+
---------------------------
|
2
|
+
���ӁF
|
3
|
+
* ((<�Ή��ς�(or��Ή��ɂȂ���)����>)) �͕��������Ɉړ�����.
|
4
|
+
���̍ہA�ǂ��Ή��������������� better.
|
5
|
+
---------------------------
|
6
|
+
|
7
|
+
* analysis
|
8
|
+
* ���̏c���^�㉺flip
|
9
|
+
* analysis�����̉������ł���悤��
|
10
|
+
* axes�ł܂݉E�̃e�L�X�g�����B���͕̂s��
|
11
|
+
* axes�ŁA�͈͂����łȂ��ǂ݂Ƃ��X�e�b�v���w�肵����
|
12
|
+
|
13
|
+
* 2007/03�̃Z�~�i�[���ɂł��͂Ȃ�
|
14
|
+
* windows�� tar.gz �t�@�C�����ł��Ȃ�
|
15
|
+
* ������H�v�m�F
|
16
|
+
* �f�[�^���X�N���v�g�ۑ�����ۂ̃t�@�C�����������Ŏw�肵����
|
17
|
+
* �}�̃^�C�g�����w�肵����
|
18
|
+
* rake setup ���ɁA�ŏ����� root �̃p�X���[�h�����߂�����ׂ�
|
19
|
+
* install �X�N���v�g�ł͎���
|
20
|
+
* --> install �X�N���v�g�ŐU�镑�����ς��̂͌��Ȃ̂Ō��������� (horinout)
|
21
|
+
|
22
|
+
* �f�[�^�f�B�X�N�X�L�����ɂ�鎩���o�^
|
23
|
+
* *.nc@temp in ../hoge.nc �������ꍇ�ɁA
|
24
|
+
���ۂ� ../hoge.nc ���t�@�C���Ƃ��đ��݂����ꍇ�ɗ�O������悤��
|
25
|
+
* ��O�������̃G���[���b�Z�[�W�͂킩��₷��
|
26
|
+
* ��̓I�Ȏw���������悤��
|
27
|
+
* ���̏ꍇ�́A�g���[�X�o�b�N�͕s�v �i�f�t�H���g�� abort ��
|
28
|
+
--trace �I�v�V������������ raise�j
|
29
|
+
|
30
|
+
* ���^�f�[�^�����A�����L���O�A�����C���^�t�F�[�X(�n��)
|
31
|
+
* swath�e�X�g�f�[�^���������R�~�b�g����
|
32
|
+
* ��S���i�q�̏ꍇ�� balloon �̈ʒu�͒��S�ł����̂��H
|
33
|
+
-- �Y�[��������̈�͂��Ԃ邯�ǒ��S�͊O�ɂł�ꍇ������
|
34
|
+
* ����t�������������� by �n�ӂ���
|
35
|
+
* �e�}�[�N���J�o�[����͈͂��}�b�v��ɕ\��������
|
36
|
+
* �L�[���[�h�����̌��� by key & value (incl. key ���̂��̂�
|
37
|
+
�T�[�`����L���O�j
|
38
|
+
* �ܓx�~�A�o�x�~�Ή�
|
39
|
+
* ��ԏ��ɂ��āA�K�w�I�ɍ�����������
|
40
|
+
�igoogle map �ɂ�����^�C���̂悤�ɂ����ȑ傫���Łj
|
41
|
+
* �n�ӂ���� RD ��m���Ă��炤
|
42
|
+
|
43
|
+
* �p�b�P�[�W���O�A�����̈Չ�
|
44
|
+
* rake setup / rake update
|
45
|
+
* ���ꂩ�牽�����邩����ʂ�\������ (for �S�̏���)
|
46
|
+
* rake setup
|
47
|
+
* password / passphrase �Ȃǂ��������͂�����
|
48
|
+
* install script �ł͎����ς�
|
49
|
+
* --> install �X�N���v�g�ŐU�镑�����ς��̂͌��Ȃ̂Ō��������� (horinout)
|
50
|
+
* rake update
|
51
|
+
* update �̑ΏۂƂȂ鎖����\�����A���ꂼ����s���������Ă����B
|
52
|
+
�Ⴆ��
|
53
|
+
* data directory ���X�L�������ă��^�f�[�^DB���č\��
|
54
|
+
* user�e�[�u�����X�V
|
55
|
+
* gfdnavi �̃o�[�W�����A�b�v
|
56
|
+
�ȂǁB���ꂼ��ɂ����āA�ǂ̂悤�ȑI����������A���̌���
|
57
|
+
�����N���邩�������B
|
58
|
+
|
59
|
+
|
60
|
+
* �h�L�������e�[�V���� / help
|
61
|
+
* popup����w���v�������Ə[��������B
|
62
|
+
* �����`���[�g���A���ł́Amysql �ł͂Ȃ� sqlite3 ���g�����Ƃ�
|
63
|
+
����B����ŁA�������y�ɂȂ�͂��B
|
64
|
+
|
65
|
+
---------------
|
66
|
+
== �Ή��ς�(or��Ή��ɂȂ���)����
|
67
|
+
|
68
|
+
* 2007/03�̃Z�~�i�[���ɂł��͂Ȃ�
|
69
|
+
* save�����}��\��������
|
70
|
+
�i���̓��^�f�[�^�̂݁B�Ƃ肠���� description�őΉ����j
|
71
|
+
* gzip �����łȂ� zip ���ł��Ăق���
|
72
|
+
* ���̌�Aportable �� ��������͓̂�����Ƃ����b���ł��̂ŁA�v�čl
|
73
|
+
|
74
|
+
* Draw�{�^�������� -- �������� *�ɂ�* �ق���
|
75
|
+
* �����Ƀ{�^���ړ�
|
76
|
+
* ���ƂɈʒu�̓{�^���͂Ƃ肠�����u���Ȃ�
|
77
|
+
* �^�u�̈Ӗ��I�ɁA�^�u�̑I���ɂ���āA���̕������ς��̂͂��܂�悭�Ȃ��炵��
|
78
|
+
|
79
|
+
* �f�[�^�f�B�X�N�X�L�����ɂ�鎩���o�^
|
80
|
+
* �X��h�L�������g
|
81
|
+
* contains �������Y��Ă���B�p�X�̏������ǂ����������H �v�m�F�B
|
82
|
+
* RAILS_ROOT/user �̉����X�L��������悤��
|
83
|
+
|
84
|
+
* �`��f�t�H���g�I�v�V������ yml �Ŏw��ł���悤�ɂ���
|
85
|
+
* ����̃t�@�C����ϐ��A����f�B���N�g���[�ȉ��̔C�ӂ�
|
86
|
+
�t�@�C���ȂǁAyml �Őݒ�ł���Ώۂ̃X�R�[�v�͂��Ȃ�_��
|
87
|
+
��������̂ŁA���p����B
|
88
|
+
* ��Ƃ̗���́A�ăX�L��������DB�Č����m�ۂƓ��l�ɁA
|
89
|
+
���̂��߂̘g�g�݂��V������i����͂����ς͗l�j�A
|
90
|
+
�X�삳�����X�L�����v���O������Ή�������B
|
91
|
+
* DB�č\�z���c���[�̈ꕔ�łł���悤��
|
92
|
+
* ����f�B���N�g���[�ȉ�������ΏۂɎ����o�^�X�N���v�g��
|
93
|
+
���点����悤�ɂ���B
|
94
|
+
* �ăX�L�������� DB �Č������m�ۂ���
|
95
|
+
* user / group ���́Akeyword=attributes �Ƃ͕ʃe�[�u����
|
96
|
+
�Ǘ�����Ă���B����� yml �ɏ����o���悤�ɂ�(--> ���V),
|
97
|
+
�����o�^�X�N���v�g������𐳂������߂ł���悤�ɂ���(--> �X��)�B
|
98
|
+
* �V���{���b�N�����N�Ή�
|
99
|
+
* yaml �ɂ����郏�C���h�J�[�h % �� * �̎g�������͂킩��ɂ����B
|
100
|
+
* �i���[�N�V���b�v���ɂ������܂��傤�ƌ������b�B���Ƃ�
|
101
|
+
���V���x�V�����b���āA����ς悭�Ȃ��Ƃ������ƂɂȂ����j�F
|
102
|
+
�ΏǗÖ@�Ƃ��āA���p�p�x�����قǑ����Ȃ���������Ȃ� % ��
|
103
|
+
�ɂ��Ă̋L�q�́A�h�L�������g�̉��̂ق��Ɉڂ��Ėڗ����Ȃ�
|
104
|
+
���邱�Ƃŏ����Ă��܂��B
|
105
|
+
* �i�V�āj: ���C���h�J�[�h���Ԃ͓��ꂵ�Ďg��������v��Ȃ�����B
|
106
|
+
������v�ɕ\�����߂ɁAaggregate: �Ƃ����V�L�[��p�ӂ���B
|
107
|
+
��
|
108
|
+
contains:
|
109
|
+
u% # u ����n�܂�C�ӕϐ��ɋ��ʂ��郁�^�f�[�^�lj�
|
110
|
+
*.nc # *.nc ���o�[�`�����Ɍ�������
|
111
|
+
�V
|
112
|
+
contains:
|
113
|
+
u* # u ����n�܂�C�ӕϐ��ɋ��ʂ��郁�^�f�[�^�lj�
|
114
|
+
aggregate:
|
115
|
+
*.nc # *.nc ���o�[�`�����Ɍ�������
|
116
|
+
|
117
|
+
* �p�b�P�[�W���O�A�����̈Չ�
|
118
|
+
* �z�z�Ńp�b�P�[�W���O�č\��
|
119
|
+
* ���݂� DL���ēW�J�������̂����̂܂ܕҏW���Ďg�킹�Ă邪�A
|
120
|
+
DL and (�W�J or �C���X�g�[���j��A�^�p�p�̏ꏊ�ɉ��߂�
|
121
|
+
�W�J������(�euser�̃f�B���N�g���[�Ƃ� /var �Ƃ�)�B
|
122
|
+
* �p�b�P�[�W�ɂ͉^�p�p�̏ꏊ�ɓW�J���邽�߂� setup �R�}���h
|
123
|
+
���܂߂邩�A���ꎩ�̂� setup.exe �ɂ���B
|
124
|
+
* gfdnavi �̔z�z�Ńp�b�P�[�W���O�ƁA�e���̉^�p�p�R�s�[�̕���
|
125
|
+
* gfdnavi���o�[�W�����A�b�v���Ă���蒼�����Ȃ��ōςނ悤��
|
126
|
+
* �z�z�ł���͂��߂Ă� cvs �ł��g����̂��ǂ��B
|
127
|
+
* �Ƃ肠�����@install �X�N���v�g������Ă݂�
|
128
|
+
* ���[�U�f�B���N�g�� �� /var �ɃC���X�g�[����ɁAmake setup
|
129
|
+
�ɑ�������悤�ɂ���Ƃ悢���낤�i��� setup ����I�v�V�������c���B�j
|
130
|
+
|
131
|
+
* �h�L�������e�[�V���� / help
|
132
|
+
* gfdnavi �h�L�������e�[�V������`���[�g���A���ւ̃����N���~�����B
|
@@ -0,0 +1,700 @@
|
|
1
|
+
require "vizshot_gfdnavi"
|
2
|
+
require "fileutils"
|
3
|
+
|
4
|
+
if defined?(Dependencies)
|
5
|
+
Dependencies.require_or_load "execute_analysis"
|
6
|
+
else
|
7
|
+
ActiveSupport::Dependencies.require_or_load "execute_analysis"
|
8
|
+
end
|
9
|
+
|
10
|
+
class AnalysisController < ApplicationController
|
11
|
+
include ExecuteAnalysis
|
12
|
+
|
13
|
+
layout "gfdnavi"
|
14
|
+
|
15
|
+
before_filter :login_required, :only => :save
|
16
|
+
|
17
|
+
def index
|
18
|
+
if session[:analysis]
|
19
|
+
@analysis = session[:analysis]
|
20
|
+
else
|
21
|
+
@analysis = Analysis.new
|
22
|
+
@analysis.user = session[:user]
|
23
|
+
clear_diagram_files
|
24
|
+
clear_temp_variables()
|
25
|
+
end
|
26
|
+
session[:analysis] = @analysis
|
27
|
+
@user = (login=session[:user]) && User.find_by_login(login)
|
28
|
+
@variables = all_variables(@user)
|
29
|
+
@draw_methods = draw_method_set(@analysis)
|
30
|
+
@functions = function_set(@analysis)
|
31
|
+
@history = session[:history]
|
32
|
+
@diagrams = session[:diagrams]
|
33
|
+
end
|
34
|
+
|
35
|
+
def load_history
|
36
|
+
i = params[:id].to_i
|
37
|
+
unless session[:history][i]
|
38
|
+
render :update do |page|
|
39
|
+
page.replace_html :messages, "operation failed. please reload the page."
|
40
|
+
end
|
41
|
+
end
|
42
|
+
analysis = session[:history][i][0]
|
43
|
+
session[:analysis] = analysis
|
44
|
+
redirect_to(:action => "index")
|
45
|
+
end
|
46
|
+
|
47
|
+
def clear
|
48
|
+
session[:analysis] = nil
|
49
|
+
session[:history] = nil
|
50
|
+
clear_variables
|
51
|
+
clear_diagram_files
|
52
|
+
redirect_to(:action => "index")
|
53
|
+
end
|
54
|
+
|
55
|
+
def clear_diagrams
|
56
|
+
clear_diagram_files
|
57
|
+
if request.xhr?
|
58
|
+
render(:update){|page|
|
59
|
+
page.replace_html :diagrams, ""
|
60
|
+
}
|
61
|
+
else
|
62
|
+
redirect_to(:action => "index")
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
def variables_selected
|
67
|
+
unless request.xhr?
|
68
|
+
clear
|
69
|
+
return
|
70
|
+
end
|
71
|
+
session[:analysis] = variables_set(params["variables"])
|
72
|
+
action_type_selected
|
73
|
+
end
|
74
|
+
|
75
|
+
def action_type_selected
|
76
|
+
unless request.xhr?
|
77
|
+
clear
|
78
|
+
return
|
79
|
+
end
|
80
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
81
|
+
@analysis = session[:analysis] || Analysis.new
|
82
|
+
@analysis.user = session[:user]
|
83
|
+
@analysis.action_type = params[:action_type] if params[:action_type]
|
84
|
+
if Analysis::ACTION_TYPE[@analysis.action_type] == "draw"
|
85
|
+
unless @analysis.draw_method
|
86
|
+
dm = nil
|
87
|
+
if @analysis.dimensions.length >= 2
|
88
|
+
dm = DrawMethod.find(:first,:conditions=>["name=?","tone"],:user=>user)
|
89
|
+
dm ||= DrawMethod.find(:first,:conditions=>"nvars>1",:user=>user)
|
90
|
+
end
|
91
|
+
dm ||= DrawMethod.find(:first,:conditions=>"nvars=1",:user=>user)
|
92
|
+
unless dm
|
93
|
+
raise "no draw method"
|
94
|
+
end
|
95
|
+
@analysis.draw_method = dm
|
96
|
+
end
|
97
|
+
@draw_methods = draw_method_set(@analysis)
|
98
|
+
elsif Analysis::ACTION_TYPE[@analysis.action_type] == "analysis"
|
99
|
+
@functions = function_set(@analysis)
|
100
|
+
end
|
101
|
+
|
102
|
+
session[:analysis] = @analysis
|
103
|
+
messages = ""
|
104
|
+
if @analysis.variables.length == 0
|
105
|
+
@analysis.variable_clear
|
106
|
+
elsif @analysis.dimensions.length == 0
|
107
|
+
messages = "all selected variables must have the same dimensions"
|
108
|
+
end
|
109
|
+
|
110
|
+
render :update do |page|
|
111
|
+
page.replace_html :messages, messages
|
112
|
+
page.replace_html :dimensions_setting, render(:partial => "dimension_option")
|
113
|
+
case Analysis::ACTION_TYPE[@analysis.action_type]
|
114
|
+
when "draw"
|
115
|
+
page.replace_html :draw_settings, render(:partial => "draw_settings")
|
116
|
+
page.replace_html :popular_diagrams, render(:partial => "popular_diagrams")
|
117
|
+
when "analysis"
|
118
|
+
page.replace_html :analysis_settings, render(:partial => "analysis_settings")
|
119
|
+
page.replace_html :popular_diagrams, ""
|
120
|
+
end
|
121
|
+
|
122
|
+
page.replace_html :script, <<"EOF"
|
123
|
+
<script>
|
124
|
+
action_type = #{@analysis.action_type};
|
125
|
+
executable = #{@analysis.dimensions.length > 0};
|
126
|
+
afterCallBack();
|
127
|
+
</script>
|
128
|
+
EOF
|
129
|
+
end
|
130
|
+
|
131
|
+
end
|
132
|
+
|
133
|
+
def execute
|
134
|
+
params_analysis = params[:analysis] || Hash.new
|
135
|
+
if params_analysis[:anim]=="1" && (anim = params[:anim])
|
136
|
+
val = anim["val"]
|
137
|
+
region_org = params_analysis["region"].dup
|
138
|
+
anim_dim = params_analysis["anim_dim"]
|
139
|
+
params_analysis["region"].delete(anim_dim)
|
140
|
+
params_analysis["region"][anim_dim] = {"min"=> val}
|
141
|
+
anim = true
|
142
|
+
else
|
143
|
+
anim = false
|
144
|
+
end
|
145
|
+
action_type = params[:action_type]
|
146
|
+
if request.xhr?
|
147
|
+
analysis = session[:analysis]
|
148
|
+
unless analysis
|
149
|
+
render :update do |page|
|
150
|
+
page.replace_html :messages, "operation failed. please reload the page."
|
151
|
+
end
|
152
|
+
return
|
153
|
+
end
|
154
|
+
else
|
155
|
+
analysis = variables_set(params["variables"])
|
156
|
+
analysis.draw_keep = false
|
157
|
+
analysis.draw_share = false
|
158
|
+
analysis.anim = anim
|
159
|
+
analysis.action_type = Analysis::ACTION_TYPE.index(action_type)
|
160
|
+
end
|
161
|
+
analysis.attributes = params_analysis
|
162
|
+
session[:analysis] = analysis
|
163
|
+
res = false
|
164
|
+
case action_type
|
165
|
+
when "draw"
|
166
|
+
res = execute_draw(analysis, anim)
|
167
|
+
if anim
|
168
|
+
analysis.region = region_org
|
169
|
+
session[:analysis] = analysis
|
170
|
+
end
|
171
|
+
return
|
172
|
+
when "analysis"
|
173
|
+
if request.xhr?
|
174
|
+
res = execute_analysis(analysis)
|
175
|
+
return
|
176
|
+
end
|
177
|
+
end
|
178
|
+
if res
|
179
|
+
session[:history] ||= AnalysisHistory.new
|
180
|
+
session[:history].push YAML.load(analysis.to_yaml)
|
181
|
+
else
|
182
|
+
raise "invalid action (#{action_type})"
|
183
|
+
end
|
184
|
+
end
|
185
|
+
|
186
|
+
def download_diagram_script_and_data
|
187
|
+
id = params[:id]
|
188
|
+
diagram = get_temp_diagram(id)
|
189
|
+
if diagram
|
190
|
+
viz = YAML.load(diagram.vizshot)
|
191
|
+
if NumRu::VizShot === viz
|
192
|
+
flag = true
|
193
|
+
viz.get_variables.each{|v|
|
194
|
+
unless v.downloadable?
|
195
|
+
flag = false
|
196
|
+
break
|
197
|
+
end
|
198
|
+
}
|
199
|
+
if flag
|
200
|
+
res = viz_to_script_and_data(viz, work_dir)
|
201
|
+
if res[0]
|
202
|
+
send_file res[1], :filename => "gfdnavi.tar.gz"
|
203
|
+
return
|
204
|
+
else
|
205
|
+
message = res[1]
|
206
|
+
end
|
207
|
+
else
|
208
|
+
message = "download is inhivited"
|
209
|
+
end
|
210
|
+
else
|
211
|
+
message = "cannot find data to download"
|
212
|
+
end
|
213
|
+
else
|
214
|
+
message = "cannot find diagram"
|
215
|
+
end
|
216
|
+
flash[:messages] = "failed to download<br/>" + message
|
217
|
+
redirect_to :action => "index"
|
218
|
+
end
|
219
|
+
|
220
|
+
def upload_file
|
221
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
222
|
+
if user
|
223
|
+
file = params[:file]
|
224
|
+
unless file.empty?
|
225
|
+
path = File.join(work_dir,File.basename(file.path))
|
226
|
+
FileUtils.move(file.path, path)
|
227
|
+
session[:temp_variables_list] ||= Array.new
|
228
|
+
NumRu::GPhys::IO.var_names_except_coordinates(path).each{|vname|
|
229
|
+
gphys = NumRu::GPhys::IO.open(path,vname)
|
230
|
+
var = Variable.new
|
231
|
+
var.file = "temporary:#{path.sub(/^#{GFDNAVI_WORK_PATH}/,"")}"
|
232
|
+
var.path = File.join(var.file, vname)
|
233
|
+
var.name = vname
|
234
|
+
var.mtime = Time.now
|
235
|
+
var.owner = user
|
236
|
+
var.size = gphys.length
|
237
|
+
node = var.node
|
238
|
+
gphys.att_names.each{|an|
|
239
|
+
val = gphys.get_att(an)
|
240
|
+
val = NArray[val] if Numeric === val
|
241
|
+
ka = KeywordAttribute.new
|
242
|
+
ka.name = Kconv.kconv(an,Kconv::UTF8)
|
243
|
+
ka.value = val
|
244
|
+
ka.node = node
|
245
|
+
node.keyword_attributes.push(ka)
|
246
|
+
}
|
247
|
+
session[:temp_variables_list].push var
|
248
|
+
}
|
249
|
+
end
|
250
|
+
end
|
251
|
+
redirect_to(:action => "index")
|
252
|
+
end
|
253
|
+
|
254
|
+
def download_data
|
255
|
+
path = params[:path]
|
256
|
+
var = get_temp_variable(path)
|
257
|
+
if var
|
258
|
+
if var.downloadable?
|
259
|
+
fname = var.fname
|
260
|
+
if fname
|
261
|
+
send_file fname, :filename => "gfdnavi.nc"
|
262
|
+
return
|
263
|
+
end
|
264
|
+
else
|
265
|
+
mess = "download is inhivited"
|
266
|
+
end
|
267
|
+
else
|
268
|
+
mess = "cannot download data"
|
269
|
+
end
|
270
|
+
render :update do |page|
|
271
|
+
page.replace_html :messages, mess
|
272
|
+
end
|
273
|
+
end
|
274
|
+
|
275
|
+
def save
|
276
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
277
|
+
unless user
|
278
|
+
redirect_to :action => "index"
|
279
|
+
return
|
280
|
+
end
|
281
|
+
|
282
|
+
case params[:path]
|
283
|
+
when /\.\.\//
|
284
|
+
flash[:notice] = '"../" cannot be used in path.'
|
285
|
+
redirect_to :action => "save"
|
286
|
+
return
|
287
|
+
when /^\s*$/
|
288
|
+
flash[:notice] = 'Path cannot be empty.'
|
289
|
+
redirect_to :action => "save"
|
290
|
+
return
|
291
|
+
when /^\s*\//, /\/\s*$/, /\/\s*\//
|
292
|
+
flash[:notice] = "Directory that doesn't have name is forbidden."
|
293
|
+
redirect_to :action => "save"
|
294
|
+
return
|
295
|
+
end
|
296
|
+
|
297
|
+
if request.get?
|
298
|
+
@id = params[:id]
|
299
|
+
@type = params[:type]
|
300
|
+
@groups = user.belonging_groups
|
301
|
+
@user = user
|
302
|
+
case @type
|
303
|
+
when "diagram"
|
304
|
+
@suffix = "png"
|
305
|
+
when "data"
|
306
|
+
@name = get_temp_variable(@id).name
|
307
|
+
@suffix = "nc"
|
308
|
+
end
|
309
|
+
render
|
310
|
+
return
|
311
|
+
end
|
312
|
+
id = params[:id]
|
313
|
+
type = params[:type]
|
314
|
+
# name = params[:name]
|
315
|
+
path = params[:path]
|
316
|
+
description = params[:description]
|
317
|
+
keywords = params[:keywords]
|
318
|
+
groups = params[:groups].values # Hash to Array
|
319
|
+
|
320
|
+
if groups[0] == 'everyone'
|
321
|
+
other_mode = 4
|
322
|
+
groups.shift
|
323
|
+
else
|
324
|
+
other_mode = 0
|
325
|
+
end
|
326
|
+
refs = Array.new
|
327
|
+
case type
|
328
|
+
when "diagram"
|
329
|
+
var = Image.new
|
330
|
+
diagram = get_temp_diagram(id)
|
331
|
+
viz = YAML.load(diagram.vizshot)
|
332
|
+
ids = viz.get_variables.collect{|v| # ���̃u���b�N�͂Ƃ肠�������̂܂܂ɂ��Ă��邪�A�v�Ή�
|
333
|
+
if Variable===v && ! v.id
|
334
|
+
from = v.fname
|
335
|
+
to, pa = auto_file_path("data")
|
336
|
+
FileUtils.move(from, to)
|
337
|
+
v.path = pa + '/' + v.name
|
338
|
+
v.owner = user
|
339
|
+
v.other_mode = other_mode
|
340
|
+
v.set_rgroups(groups) if groups.length > 0
|
341
|
+
v.save!
|
342
|
+
else
|
343
|
+
v = Variable===v ? v : Variable.find(:first, :conditions=>["path=?",v],:user=>user)
|
344
|
+
end
|
345
|
+
refs << v.node
|
346
|
+
v.id
|
347
|
+
}
|
348
|
+
var.vizshot = viz.to_yaml
|
349
|
+
path = "/#{path}.png"
|
350
|
+
from = diagram.path
|
351
|
+
name = var.name = File.basename(path)
|
352
|
+
var.path = File.join("/usr",Knowledge.remove_scheme(user),path)
|
353
|
+
when "data"
|
354
|
+
var = get_temp_variable(id)
|
355
|
+
from = var.fname
|
356
|
+
name = var.name
|
357
|
+
path = "/#{path}.nc/#{name}"
|
358
|
+
var.path = File.join("/usr",Knowledge.remove_scheme(user),path)
|
359
|
+
var.file = File.dirname(var.path)
|
360
|
+
end
|
361
|
+
var.owner = user
|
362
|
+
var.other_mode = other_mode
|
363
|
+
var.node.set_rgroups(groups) if groups.length > 0
|
364
|
+
|
365
|
+
var.keyword_attributes.build(:name => "description", :value => description) unless description == ""
|
366
|
+
keywords.each{|k,v|
|
367
|
+
if Hash === v && (name=v["name"])!="" && (val=v["value"])!=""
|
368
|
+
if val.to_i.to_s == val
|
369
|
+
val = NArray[val.to_i]
|
370
|
+
elsif val.to_f.to_s == val
|
371
|
+
val = NArray[val.to_f]
|
372
|
+
end
|
373
|
+
var.keyword_attributes.build(:name => name, :value => val)
|
374
|
+
end
|
375
|
+
}
|
376
|
+
|
377
|
+
to = var.fname
|
378
|
+
FileUtils.makedirs( File.dirname(to) )
|
379
|
+
full_path = ""
|
380
|
+
parent = nil
|
381
|
+
var.path.split(File::Separator)[0..-2].each{|dname|
|
382
|
+
full_path = File.join(full_path, dname)
|
383
|
+
dir = Directory.find(:first, :conditions=>["path=?",full_path], :user=>user)
|
384
|
+
unless dir
|
385
|
+
dir = Directory.new
|
386
|
+
dir.name = dname
|
387
|
+
dir.path = full_path
|
388
|
+
dir.parent = parent.node
|
389
|
+
dir.owner = user
|
390
|
+
dir.other_mode = other_mode
|
391
|
+
dir.set_rgroups(groups) if groups.length > 0
|
392
|
+
if full_path == var.file
|
393
|
+
dir.downloadable = var.downloadable?
|
394
|
+
dir.plain_file = true
|
395
|
+
end
|
396
|
+
dir.save!
|
397
|
+
end
|
398
|
+
parent = dir
|
399
|
+
}
|
400
|
+
|
401
|
+
if var.save
|
402
|
+
rtype = {"diagram"=>"draw", "data"=>"analyze"}[type]
|
403
|
+
refs.each{|ref|
|
404
|
+
NodeRelation.new(:name=>rtype, :reference=>ref, :referenced_by=>var.node).save!
|
405
|
+
}
|
406
|
+
messages = "successfully saved"
|
407
|
+
case type
|
408
|
+
when "diagram"
|
409
|
+
FileUtils.copy( from, to )
|
410
|
+
when "data"
|
411
|
+
raise("[BUG] from == to") if from==to
|
412
|
+
FileUtils.move( from, to )
|
413
|
+
session[:temp_variables_list].delete var
|
414
|
+
session[:variables_list] ||= Array.new
|
415
|
+
session[:variables_list].push var.path
|
416
|
+
end
|
417
|
+
else
|
418
|
+
messages = "failed to save<br/>"
|
419
|
+
messages += var.errors.full_messages.join("<br/>") if var.errors
|
420
|
+
end
|
421
|
+
flash[:messages] = messages
|
422
|
+
redirect_to :action => :index
|
423
|
+
end
|
424
|
+
|
425
|
+
def delete_diagram
|
426
|
+
id = params[:id].to_i
|
427
|
+
if (diagram = session[:diagrams][id])
|
428
|
+
session[:diagrams].delete_at(id)
|
429
|
+
end
|
430
|
+
render :nothing => true
|
431
|
+
end
|
432
|
+
|
433
|
+
def pile_up
|
434
|
+
unless request.xhr?
|
435
|
+
render :nothing => true
|
436
|
+
return
|
437
|
+
end
|
438
|
+
lower_id = params[:lower].to_i
|
439
|
+
upper_id = params[:upper].to_i
|
440
|
+
if (diagrams = session[:diagrams])
|
441
|
+
session_id = session.session_id
|
442
|
+
lower = DiagramCache.find_for_session(diagrams[lower_id],session_id)
|
443
|
+
upper = DiagramCache.find_for_session(diagrams[upper_id],session_id)
|
444
|
+
if lower && upper
|
445
|
+
a = YAML.load(lower.vizshot)
|
446
|
+
b = YAML.load(upper.vizshot)
|
447
|
+
viz = a.add(b)
|
448
|
+
# viz = YAML.load(lower.vizshot).add(YAML.load(upper.vizshot))
|
449
|
+
res = vizs_to_diagram([viz], true, session[:analysis].draw_share, true)
|
450
|
+
show_diagram(res, true, false, true)
|
451
|
+
return
|
452
|
+
end
|
453
|
+
end
|
454
|
+
render :nothing => true
|
455
|
+
end
|
456
|
+
|
457
|
+
def preview
|
458
|
+
unless request.xhr?
|
459
|
+
render :nothing => true
|
460
|
+
return
|
461
|
+
end
|
462
|
+
h = params[:function] || params[:draw_method]
|
463
|
+
@html = ERB.new(h[:setting_html]||"").result
|
464
|
+
@analysis = Analysis.new
|
465
|
+
render :layout => false
|
466
|
+
end
|
467
|
+
|
468
|
+
def show_image
|
469
|
+
id = params[:id]
|
470
|
+
|
471
|
+
if (dc = DiagramCache.find_for_session(id, session.session_id))
|
472
|
+
response.headers['Content-Type'] = 'image/png'
|
473
|
+
response.headers['Pragma'] = 'no-cache'
|
474
|
+
File.open(dc.path,"rb"){|file|
|
475
|
+
render :text => file.read
|
476
|
+
}
|
477
|
+
else
|
478
|
+
render :nothing => true
|
479
|
+
end
|
480
|
+
end
|
481
|
+
|
482
|
+
# end
|
483
|
+
private
|
484
|
+
def all_variables(user=nil)
|
485
|
+
vars = session[:variables_list] || []
|
486
|
+
variables = Array.new
|
487
|
+
vars.each{|path|
|
488
|
+
if v = Variable.find(:first,:conditions=>["path=?",path],:user=>user)
|
489
|
+
attrs = v.keyword_attributes.collect{|attr| [attr.name, attr.value]}
|
490
|
+
selected = @analysis.variables.include?(v)
|
491
|
+
variables.push [v.name, v.path, attrs, selected, false]
|
492
|
+
end
|
493
|
+
}
|
494
|
+
variables.sort!
|
495
|
+
temp_vars = session[:temp_variables_list] || []
|
496
|
+
for i in 0...temp_vars.length
|
497
|
+
v = temp_vars[i]
|
498
|
+
attrs = v.keyword_attributes.collect{|attr| [attr.name, attr.value]}
|
499
|
+
selected = @analysis.variables.include?(v)
|
500
|
+
variables.push [v.name, "temp_#{i}", attrs, selected, true, v.downloadable?]
|
501
|
+
end
|
502
|
+
return variables
|
503
|
+
end
|
504
|
+
|
505
|
+
def draw_method_set(analysis)
|
506
|
+
dms = Array.new
|
507
|
+
nvars = analysis.variables.length
|
508
|
+
ndims = analysis.dimensions.length
|
509
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
510
|
+
nvars.times{|i|
|
511
|
+
if nvars%(i+1) == 0
|
512
|
+
dms += DrawMethod.find(:all, :conditions => ["ndims<=? and nvars=?", ndims, i+1], :user => user)
|
513
|
+
end
|
514
|
+
}
|
515
|
+
return dms
|
516
|
+
end
|
517
|
+
|
518
|
+
def function_set(analysis)
|
519
|
+
funcs = Array.new
|
520
|
+
nvars = analysis.variables.length
|
521
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
522
|
+
nvars.times{|i|
|
523
|
+
if nvars%(i+1) == 0
|
524
|
+
funcs += Function.find(:all, :conditions => ["nvars=?", i+1], :user => user)
|
525
|
+
end
|
526
|
+
}
|
527
|
+
return funcs
|
528
|
+
end
|
529
|
+
|
530
|
+
#draw
|
531
|
+
def execute_draw(analysis, anim=false)
|
532
|
+
keep = anim || analysis.draw_keep
|
533
|
+
res = get_diagram(analysis, keep)
|
534
|
+
show_diagram(res, keep, anim)
|
535
|
+
end
|
536
|
+
|
537
|
+
def show_diagram(res, keep, anim, pile=false)
|
538
|
+
unless res[0]
|
539
|
+
if request.xhr?
|
540
|
+
render :update do |page|
|
541
|
+
page.replace_html :messages, res[1]
|
542
|
+
end
|
543
|
+
else
|
544
|
+
render :text => res[1]
|
545
|
+
end
|
546
|
+
return false
|
547
|
+
end
|
548
|
+
diagrams = res[1]
|
549
|
+
draw_or_cache = res[3]
|
550
|
+
if keep && Array === (dgs = session[:diagrams])
|
551
|
+
ndg_old = dgs.length
|
552
|
+
else
|
553
|
+
session[:diagrams] = Array.new
|
554
|
+
ndg_old = 0
|
555
|
+
end
|
556
|
+
diagrams.each{|dc|
|
557
|
+
session[:diagrams].push dc.id
|
558
|
+
}
|
559
|
+
|
560
|
+
ndg_new = diagrams.length
|
561
|
+
if request.xhr?
|
562
|
+
@analysis = session[:analysis]
|
563
|
+
render(:update){|page|
|
564
|
+
page.replace_html :messages, ""
|
565
|
+
if GFDNAVI_BENCHMARK && !anim
|
566
|
+
html = host_information_table
|
567
|
+
html +=<<-"EOS"
|
568
|
+
Total number of diagrams is #{diagrams.length}<br/>
|
569
|
+
Cached diagram: #{draw_or_cache[1]}<br/>
|
570
|
+
Drawed diagram: #{draw_or_cache[0]}
|
571
|
+
EOS
|
572
|
+
page << "benchMark.set(['#{((ndg_old...(ndg_old+ndg_new)).to_a).join('\',\'')}'], '#{escape_javascript(html)}');"
|
573
|
+
@benchmark = true
|
574
|
+
end
|
575
|
+
@anim = anim
|
576
|
+
@pile = pile
|
577
|
+
diagrams.each_with_index{|dg,i|
|
578
|
+
id = ndg_old + i
|
579
|
+
@diagram = [id,dg]
|
580
|
+
unless dg.diagram_cache_sessions.find(:first,:conditions=>["session=?",session.session_id])
|
581
|
+
page.replace_html :messages, "invalid diagram was specified"
|
582
|
+
return false
|
583
|
+
end
|
584
|
+
if keep || i>0
|
585
|
+
page.insert_html :bottom, :diagrams, render(:partial => "diagram")
|
586
|
+
else
|
587
|
+
page.replace_html :diagrams, render(:partial => "diagram")
|
588
|
+
end
|
589
|
+
if anim
|
590
|
+
id_html = "diagram_#{id}"
|
591
|
+
page << "anim.diagrams.push($('#{id_html}_table'));"
|
592
|
+
page << "anim.next();"
|
593
|
+
end
|
594
|
+
}
|
595
|
+
# "Create Knowledge from Analysis" button is disabled if login menu is disabled.
|
596
|
+
page << "drawKnowledgeFromAnalysisButton();" unless GFDNAVI_DISABLE_USER && session[:user].nil?
|
597
|
+
|
598
|
+
@history = session[:history]
|
599
|
+
page.replace_html :history, render(:partial => "history")
|
600
|
+
}
|
601
|
+
return
|
602
|
+
else
|
603
|
+
@diagrams = diagrams
|
604
|
+
render :action => :show_diagram
|
605
|
+
end
|
606
|
+
end
|
607
|
+
|
608
|
+
# analysis
|
609
|
+
def execute_analysis(analysis)
|
610
|
+
vars, messages = create_new_variable(analysis, work_dir)
|
611
|
+
if vars
|
612
|
+
session[:temp_variables_list] ||= Array.new
|
613
|
+
vars.each{|var| session[:temp_variables_list].push var}
|
614
|
+
@analysis = analysis
|
615
|
+
user = (login=session[:user]) && User.find_by_login(login)
|
616
|
+
@variables = all_variables(user)
|
617
|
+
render :update do |page|
|
618
|
+
page.replace_html :messages, messages
|
619
|
+
page.replace_html :variables_body, render(:partial => "variables")
|
620
|
+
if GFDNAVI_BENCHMARK
|
621
|
+
html = host_information_table
|
622
|
+
html +=<<-"EOS"
|
623
|
+
Number of created variable is #{vars.length}.<br/>
|
624
|
+
EOS
|
625
|
+
page << "benchMark.set(null, '#{escape_javascript(html)}');"
|
626
|
+
page << "benchMark.complete();"
|
627
|
+
end
|
628
|
+
@history = session[:history]
|
629
|
+
page.replace_html :history, render(:partial => "history")
|
630
|
+
end
|
631
|
+
return true
|
632
|
+
else
|
633
|
+
render :update do |page|
|
634
|
+
page.replace_html :messages, messages
|
635
|
+
end
|
636
|
+
return false
|
637
|
+
end
|
638
|
+
end
|
639
|
+
|
640
|
+
|
641
|
+
#common
|
642
|
+
def get_temp_variable(path)
|
643
|
+
variables = session[:temp_variables_list]
|
644
|
+
if variables
|
645
|
+
/^temp_(.*)/ =~ path
|
646
|
+
id = $1.to_i
|
647
|
+
return variables[id]
|
648
|
+
else
|
649
|
+
return nil
|
650
|
+
end
|
651
|
+
end
|
652
|
+
|
653
|
+
def get_temp_diagram(id)
|
654
|
+
diagrams = session[:diagrams]
|
655
|
+
if diagrams
|
656
|
+
id = id.to_i
|
657
|
+
return DiagramCache.find_for_session(diagrams[id],session.session_id)
|
658
|
+
else
|
659
|
+
return nil
|
660
|
+
end
|
661
|
+
end
|
662
|
+
|
663
|
+
def clear_temp_variables
|
664
|
+
temps = session[:temp_variables_list]
|
665
|
+
temps && temps.each{|v|
|
666
|
+
File.delete(v.fname) if File.exist?(v.fname)
|
667
|
+
}
|
668
|
+
session[:temp_variables_list] = nil
|
669
|
+
end
|
670
|
+
|
671
|
+
def clear_variables
|
672
|
+
clear_temp_variables()
|
673
|
+
session[:variables_list] = nil
|
674
|
+
end
|
675
|
+
|
676
|
+
def auto_file_path(type)
|
677
|
+
case type
|
678
|
+
when "data"
|
679
|
+
suffix = "nc"
|
680
|
+
when "diagram"
|
681
|
+
suffix = "png"
|
682
|
+
end
|
683
|
+
path = user_path+"/auto"
|
684
|
+
FileUtils.makedirs(path) unless File.exist?(path)
|
685
|
+
last = Dir["#{path}/gfdnavi_\d+\.#{suffix}"][0]
|
686
|
+
if last
|
687
|
+
last =~ /gfdnavi_(\d+)\./
|
688
|
+
num = $1.next
|
689
|
+
else
|
690
|
+
num = "0000"
|
691
|
+
end
|
692
|
+
fname = "gfdnavi_#{num}.#{suffix}"
|
693
|
+
full_path = "#{path}/#{fname}"
|
694
|
+
path = "/usr/#{session[:user]}/auto/#{fname}"
|
695
|
+
return [full_path, path]
|
696
|
+
end
|
697
|
+
|
698
|
+
|
699
|
+
|
700
|
+
end
|