cyberweb 0.4.174
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.
Potentially problematic release.
This version of cyberweb might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/README.md +3259 -0
- data/bin/cyberweb +27 -0
- data/cyberweb.gemspec +119 -0
- data/doc/AUTHORS.md +12 -0
- data/doc/CONVENTIONS.md +7 -0
- data/doc/CYBERWEB_TUTORIAL.cgi +43 -0
- data/doc/DOCUMENTATION_FOR_CYBERSPRAWL.md +50 -0
- data/doc/FUTURE_DESIGN_GOAL_CONSIDERATIONS.md +13 -0
- data/doc/JQUERY.md +122 -0
- data/doc/MOUSE.md +80 -0
- data/doc/README.gen +3231 -0
- data/doc/RENDER_WEB_BASE.md +46 -0
- data/doc/USAGE.md +246 -0
- data/doc/configuration/configuration.md +23 -0
- data/doc/deprecations.md +32 -0
- data/doc/html_characters.md +15 -0
- data/doc/todo/TODO_FOR_THE_CYBERWEB_PROJECT.md +1089 -0
- data/examples/README.md +4 -0
- data/examples/advanced/delayed_update_of_the_body_via_javascript.cgi +38 -0
- data/examples/advanced/hybrid_experiment.cgi +108 -0
- data/examples/advanced/larger_image_on_mouse_over_example.cgi +35 -0
- data/examples/advanced/no_right_click.cgi +26 -0
- data/examples/advanced/objectified_html_tags.cgi +35 -0
- data/examples/advanced/simple_calculator.cgi +42 -0
- data/examples/advanced/simple_form_example.cgi +38 -0
- data/examples/css/blue_border.html +28 -0
- data/examples/css/caret_colour_example.html +22 -0
- data/examples/css/css_border_spacing_example.html +69 -0
- data/examples/css/css_bubbles.html +43 -0
- data/examples/css/css_clock.html +344 -0
- data/examples/css/css_drag_and_drop.html +89 -0
- data/examples/css/css_neon_glow_effects.html +317 -0
- data/examples/css/css_text_decoration_example.html +70 -0
- data/examples/css/css_tooltip.html +44 -0
- data/examples/css/fade_in_and_fade_out_effect.html +66 -0
- data/examples/css/font_size_examples.html +40 -0
- data/examples/css/letter_spacing_example.cgi +36 -0
- data/examples/css/meter_example.html +31 -0
- data/examples/css/on_mouse_button_pressed.html +41 -0
- data/examples/css/planets.html +187 -0
- data/examples/css/scale_example.html +25 -0
- data/examples/css/shadow_example_in_CSS.cgi +30 -0
- data/examples/css/sticky_div_example.html +56 -0
- data/examples/css/stitched_div.html +36 -0
- data/examples/csv/README.md +1 -0
- data/examples/csv/sample.csv +10 -0
- data/examples/example1.rb +7 -0
- data/examples/flip_card_example/flip_card_example.html +72 -0
- data/examples/frames/frame_left.html +1 -0
- data/examples/frames/frame_right.html +1 -0
- data/examples/html/README.md +1 -0
- data/examples/html/abbr_example.html +25 -0
- data/examples/html/base64_image_example.html +26 -0
- data/examples/html/colour_wheel.html +1389 -0
- data/examples/html/column_width_example.html +34 -0
- data/examples/html/custom_cursor.html +103 -0
- data/examples/html/draggable_paragraph.html +12 -0
- data/examples/html/fieldset_example.html +25 -0
- data/examples/html/frames_example.html +7 -0
- data/examples/html/glyph_example.html +43 -0
- data/examples/html/hbox_and_vbox_example.html +65 -0
- data/examples/html/href_examples.html +27 -0
- data/examples/html/input_autofocus_example.html +16 -0
- data/examples/html/larger_image_on_mouse_over_example.html +30 -0
- data/examples/html/ordered_and_unordered_bulletsin.html +33 -0
- data/examples/html/play_video_example.html +13 -0
- data/examples/html/readonly_textarea_example.html +23 -0
- data/examples/html/remote_image_example.html +10 -0
- data/examples/html/simple_unordered_list.html +16 -0
- data/examples/html/table_with_header_example.html +27 -0
- data/examples/html/two_columns_flex_example.html +39 -0
- data/examples/javascript/README.md +2 -0
- data/examples/javascript/arrays/arrays_example_in_javascript.html +16 -0
- data/examples/javascript/delay_example/delay_example.html +46 -0
- data/examples/javascript/drag_support/drag_support.html +37 -0
- data/examples/javascript/jquery_drag_and_drop/drag_and_drop_image_example.html +33 -0
- data/examples/javascript/on_click_event_hello_world/on_click_event_hello_world.html +21 -0
- data/examples/javascript/rgb_to_hex/rgb_to_hex.html +15 -0
- data/examples/javascript/screen_resolution/screen_resolution.html +20 -0
- data/examples/javascript/select_everything/select_everything.html +14 -0
- data/examples/javascript/write_into_a_file/write_into_a_file.html +39 -0
- data/examples/rack/README.md +4 -0
- data/examples/rack/example_with_html_template.rb +123 -0
- data/examples/rack/example_with_rack_and_cyberweb_showing_how_to_use_images.rb +56 -0
- data/examples/rack/hello_world_example_with_rack.rb +45 -0
- data/examples/rack/lobster.rb +79 -0
- data/examples/rack/rack_env.rb +10 -0
- data/examples/rack/standalone_example.rb +26 -0
- data/examples/show_greek_letters.rb +3 -0
- data/examples/simple/on_click_event_hello_world.cgi +34 -0
- data/examples/sinatra/001_your_ip_address_is.rb +8 -0
- data/examples/sinatra/002_the_request_object.rb +16 -0
- data/examples/sinatra/003_hello_world_example.rb +82 -0
- data/examples/sinatra/004_splat_example.rb +10 -0
- data/examples/sinatra/005_attachment_example.rb +11 -0
- data/examples/sinatra/006_outer_self_example.rb +8 -0
- data/examples/sinatra/007_mime_type_example.rb +17 -0
- data/examples/sinatra/008_post_example.rb +55 -0
- data/examples/table_example.rb +37 -0
- data/images/cyberweb_favicon.png +0 -0
- data/images/cyberweb_logo.png +0 -0
- data/images/cyberweb_theme.png +0 -0
- data/lib/cyberweb/and_sinatra_base.rb +9 -0
- data/lib/cyberweb/autoinclude.rb +20 -0
- data/lib/cyberweb/autoinclude_webobject.rb +14 -0
- data/lib/cyberweb/base/base.rb +41 -0
- data/lib/cyberweb/base/colours.rb +69 -0
- data/lib/cyberweb/base/constants.rb +18 -0
- data/lib/cyberweb/base/encoding.rb +19 -0
- data/lib/cyberweb/base/misc.rb +239 -0
- data/lib/cyberweb/base/reset.rb +23 -0
- data/lib/cyberweb/base/save_file.rb +22 -0
- data/lib/cyberweb/cascading_style_sheets/README.md +4 -0
- data/lib/cyberweb/cascading_style_sheets/admonition.css +33 -0
- data/lib/cyberweb/cascading_style_sheets/balloon.css +344 -0
- data/lib/cyberweb/cascading_style_sheets/border.css +202 -0
- data/lib/cyberweb/cascading_style_sheets/code.css +58 -0
- data/lib/cyberweb/cascading_style_sheets/colours.css +476 -0
- data/lib/cyberweb/cascading_style_sheets/default.css +1836 -0
- data/lib/cyberweb/cascading_style_sheets/div.css +26 -0
- data/lib/cyberweb/cascading_style_sheets/fonts.css +365 -0
- data/lib/cyberweb/cascading_style_sheets/links.css +207 -0
- data/lib/cyberweb/cascading_style_sheets/margin.css +677 -0
- data/lib/cyberweb/cascading_style_sheets/menu.css +37 -0
- data/lib/cyberweb/cascading_style_sheets/message_boxes.css +48 -0
- data/lib/cyberweb/cascading_style_sheets/misc.css +162 -0
- data/lib/cyberweb/cascading_style_sheets/popup.css +63 -0
- data/lib/cyberweb/cascading_style_sheets/rpg.css +51 -0
- data/lib/cyberweb/cascading_style_sheets/ruby_regexes.css +33 -0
- data/lib/cyberweb/cascading_style_sheets/template2.css +18 -0
- data/lib/cyberweb/cascading_style_sheets/text_shadow.css +19 -0
- data/lib/cyberweb/cascading_style_sheets/tooltip.css +36 -0
- data/lib/cyberweb/cgi/README.md +6 -0
- data/lib/cyberweb/cgi/cgi.rb +340 -0
- data/lib/cyberweb/cgi/constants.rb +121 -0
- data/lib/cyberweb/cgi/cookie.rb +218 -0
- data/lib/cyberweb/cgi/core.rb +638 -0
- data/lib/cyberweb/cgi/exceptions.rb +223 -0
- data/lib/cyberweb/cgi/html.rb +1025 -0
- data/lib/cyberweb/cgi/mod_ruby_exception_printer.rb +40 -0
- data/lib/cyberweb/cgi/query_extension.rb +431 -0
- data/lib/cyberweb/cgi/session/file_store.rb +131 -0
- data/lib/cyberweb/cgi/session/memory_store.rb +90 -0
- data/lib/cyberweb/cgi/session/pstore.rb +127 -0
- data/lib/cyberweb/cgi/session.rb +444 -0
- data/lib/cyberweb/cgi/tag_maker.rb +94 -0
- data/lib/cyberweb/cgi/util.rb +239 -0
- data/lib/cyberweb/charts/README.md +2 -0
- data/lib/cyberweb/charts/google_charts.rb +51 -0
- data/lib/cyberweb/classes/simple_form.rb +55 -0
- data/lib/cyberweb/classes/tooltips.rb +169 -0
- data/lib/cyberweb/coloured_tags/coloured_tags.rb +3099 -0
- data/lib/cyberweb/colours/colour_chart.rb +117 -0
- data/lib/cyberweb/colours/colours.rb +50 -0
- data/lib/cyberweb/colours/random_colour.rb +28 -0
- data/lib/cyberweb/colours/sanitize_for_colours.rb +95 -0
- data/lib/cyberweb/commandline/commandline_interface.rb +49 -0
- data/lib/cyberweb/configuration/configuration.rb +66 -0
- data/lib/cyberweb/configuration/load_the_configuration_file.rb +73 -0
- data/lib/cyberweb/constants/array_images.rb +21 -0
- data/lib/cyberweb/constants/array_local_css_files.rb +35 -0
- data/lib/cyberweb/constants/array_predefined_constants.rb +23 -0
- data/lib/cyberweb/constants/configuration_file.rb +33 -0
- data/lib/cyberweb/constants/constants.rb +9 -0
- data/lib/cyberweb/constants/file_constants.rb +16 -0
- data/lib/cyberweb/constants/http_status_codes.rb +42 -0
- data/lib/cyberweb/constants/nl.rb +22 -0
- data/lib/cyberweb/constants/project_constants.rb +99 -0
- data/lib/cyberweb/constants/roebe.rb +28 -0
- data/lib/cyberweb/constants/standalone_constants.rb +309 -0
- data/lib/cyberweb/controller/README.md +4 -0
- data/lib/cyberweb/controller/webobject_controller.rb +50 -0
- data/lib/cyberweb/csv/README.md +2 -0
- data/lib/cyberweb/csv/csv.rb +58 -0
- data/lib/cyberweb/cybersprawl +1 -0
- data/lib/cyberweb/debug/debug.rb +69 -0
- data/lib/cyberweb/encoding/encoding.rb +84 -0
- data/lib/cyberweb/erb/test.rhtml +81 -0
- data/lib/cyberweb/erb/test_template.erb +9 -0
- data/lib/cyberweb/evaluate_from_the_same_named_file_then_serve.rb +9 -0
- data/lib/cyberweb/favicon/favicon.rb +196 -0
- data/lib/cyberweb/generator/README.md +2 -0
- data/lib/cyberweb/generator/cgi.rb +201 -0
- data/lib/cyberweb/generator/class.rb +25 -0
- data/lib/cyberweb/generator/static_webpage.rb +162 -0
- data/lib/cyberweb/generator/webpage_for_images.rb +553 -0
- data/lib/cyberweb/help/help.rb +29 -0
- data/lib/cyberweb/html_codes/README.md +15 -0
- data/lib/cyberweb/html_codes/greek_letters.rb +204 -0
- data/lib/cyberweb/html_tags/README.md +3 -0
- data/lib/cyberweb/html_tags/a.rb +65 -0
- data/lib/cyberweb/html_tags/accesskey.rb +25 -0
- data/lib/cyberweb/html_tags/blockquote.rb +56 -0
- data/lib/cyberweb/html_tags/body.rb +14 -0
- data/lib/cyberweb/html_tags/br.rb +19 -0
- data/lib/cyberweb/html_tags/button.rb +110 -0
- data/lib/cyberweb/html_tags/canvas.rb +59 -0
- data/lib/cyberweb/html_tags/chtml.rb +14 -0
- data/lib/cyberweb/html_tags/div.rb +163 -0
- data/lib/cyberweb/html_tags/fieldset.rb +67 -0
- data/lib/cyberweb/html_tags/figure.rb +72 -0
- data/lib/cyberweb/html_tags/form.rb +203 -0
- data/lib/cyberweb/html_tags/h1.rb +75 -0
- data/lib/cyberweb/html_tags/h2.rb +73 -0
- data/lib/cyberweb/html_tags/h3.rb +58 -0
- data/lib/cyberweb/html_tags/h4.rb +60 -0
- data/lib/cyberweb/html_tags/h5.rb +54 -0
- data/lib/cyberweb/html_tags/h6.rb +54 -0
- data/lib/cyberweb/html_tags/hr.rb +22 -0
- data/lib/cyberweb/html_tags/html_tags.rb +240 -0
- data/lib/cyberweb/html_tags/i.rb +50 -0
- data/lib/cyberweb/html_tags/img.rb +294 -0
- data/lib/cyberweb/html_tags/input.rb +345 -0
- data/lib/cyberweb/html_tags/label.rb +63 -0
- data/lib/cyberweb/html_tags/legend.rb +56 -0
- data/lib/cyberweb/html_tags/li.rb +67 -0
- data/lib/cyberweb/html_tags/map.rb +31 -0
- data/lib/cyberweb/html_tags/nav.rb +63 -0
- data/lib/cyberweb/html_tags/object.rb +56 -0
- data/lib/cyberweb/html_tags/ol.rb +56 -0
- data/lib/cyberweb/html_tags/option.rb +61 -0
- data/lib/cyberweb/html_tags/p.rb +90 -0
- data/lib/cyberweb/html_tags/pre.rb +164 -0
- data/lib/cyberweb/html_tags/section.rb +33 -0
- data/lib/cyberweb/html_tags/select.rb +100 -0
- data/lib/cyberweb/html_tags/span.rb +338 -0
- data/lib/cyberweb/html_tags/strong.rb +39 -0
- data/lib/cyberweb/html_tags/table.rb +273 -0
- data/lib/cyberweb/html_tags/tbody.rb +24 -0
- data/lib/cyberweb/html_tags/td.rb +214 -0
- data/lib/cyberweb/html_tags/textarea.rb +138 -0
- data/lib/cyberweb/html_tags/th.rb +68 -0
- data/lib/cyberweb/html_tags/thead.rb +36 -0
- data/lib/cyberweb/html_tags/tr.rb +97 -0
- data/lib/cyberweb/html_tags/ul.rb +51 -0
- data/lib/cyberweb/html_template/html_template.rb +352 -0
- data/lib/cyberweb/images/embed_this_image.rb +37 -0
- data/lib/cyberweb/images/images.rb +58 -0
- data/lib/cyberweb/images/is_image.rb +22 -0
- data/lib/cyberweb/images/path_to_images.rb +60 -0
- data/lib/cyberweb/images/real/README.md +6 -0
- data/lib/cyberweb/images/remove_this_substring_from_all_images.rb +44 -0
- data/lib/cyberweb/images/standalone_drag_and_drop_this_image.rb +64 -0
- data/lib/cyberweb/images/string_image.rb +399 -0
- data/lib/cyberweb/images_base64_encoded/AUSRUFUNGSZEICHEN.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/BLUEARROW.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/BUBBLE.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/CAT.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/CAUTION.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/CHEERING_PERSON.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/CURSOR.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/DOT_01.png.md +5 -0
- data/lib/cyberweb/images_base64_encoded/DUCKY.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/ELEPHANT.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/HALLOWEEN.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/HANGING_MONKEY.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/LENS.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/README.md +2 -0
- data/lib/cyberweb/images_base64_encoded/TU_WIEN_LOGO.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/VOGEL.png.md +1 -0
- data/lib/cyberweb/io/README.md +1 -0
- data/lib/cyberweb/io/io.rb +19 -0
- data/lib/cyberweb/javascript/drag_and_drop.rb +105 -0
- data/lib/cyberweb/javascript/dragula_collection.rb +54 -0
- data/lib/cyberweb/javascript/javascript.rb +211 -0
- data/lib/cyberweb/javascript/javascript_bundle.rb +223 -0
- data/lib/cyberweb/javascript/javascript_clock.rb +69 -0
- data/lib/cyberweb/javascript/javascript_last_modified.rb +27 -0
- data/lib/cyberweb/javascript/javascript_magic.rb +150 -0
- data/lib/cyberweb/javascript/javascript_selectable.rb +24 -0
- data/lib/cyberweb/javascript/jquery.rb +30 -0
- data/lib/cyberweb/javascript/on_click_change_opacity.rb +97 -0
- data/lib/cyberweb/javascript/on_click_hide.rb +63 -0
- data/lib/cyberweb/javascript/popup.rb +80 -0
- data/lib/cyberweb/javascript/print_javascript.rb +33 -0
- data/lib/cyberweb/javascript/registered_javascript_methods.rb +30 -0
- data/lib/cyberweb/javascript/resize.rb +28 -0
- data/lib/cyberweb/javascript/return_javascript.rb +48 -0
- data/lib/cyberweb/javascript/scroll.rb +17 -0
- data/lib/cyberweb/javascript/snoweffect.rb +122 -0
- data/lib/cyberweb/javascript_code/README.md +6 -0
- data/lib/cyberweb/javascript_code/chmod_displayer.js +74 -0
- data/lib/cyberweb/javascript_code/custom_functions.js +267 -0
- data/lib/cyberweb/javascript_code/jquery/jquery-3.6.0.js +10881 -0
- data/lib/cyberweb/javascript_code/jquery/jquery-ui-1.12.1.js +18706 -0
- data/lib/cyberweb/javascript_code/rgb_to_hex.js +14 -0
- data/lib/cyberweb/javascript_code/select_even_numbers.js +7 -0
- data/lib/cyberweb/javascript_code/select_everything.js +22 -0
- data/lib/cyberweb/javascript_code/simple_calculator.js +15 -0
- data/lib/cyberweb/javascript_code/sleep.js +3 -0
- data/lib/cyberweb/javascript_code/to_celsius.js +8 -0
- data/lib/cyberweb/mouse/README.md +3 -0
- data/lib/cyberweb/mouse/libxdo.rb +321 -0
- data/lib/cyberweb/mouse/mouse.rb +264 -0
- data/lib/cyberweb/objectified_html_tags/README.md +8 -0
- data/lib/cyberweb/objectified_html_tags/a.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/abbr.rb +84 -0
- data/lib/cyberweb/objectified_html_tags/base.rb +376 -0
- data/lib/cyberweb/objectified_html_tags/button.rb +135 -0
- data/lib/cyberweb/objectified_html_tags/combobox.rb +165 -0
- data/lib/cyberweb/objectified_html_tags/div.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/embed.rb +161 -0
- data/lib/cyberweb/objectified_html_tags/form.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h1.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h2.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h3.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h4.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h5.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/h6.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/hbox.rb +71 -0
- data/lib/cyberweb/objectified_html_tags/img.rb +202 -0
- data/lib/cyberweb/objectified_html_tags/input.rb +185 -0
- data/lib/cyberweb/objectified_html_tags/p.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/pre.rb +129 -0
- data/lib/cyberweb/objectified_html_tags/span.rb +92 -0
- data/lib/cyberweb/objectified_html_tags/table.rb +174 -0
- data/lib/cyberweb/objectified_html_tags/textarea.rb +173 -0
- data/lib/cyberweb/objectified_html_tags/title.rb +82 -0
- data/lib/cyberweb/objectified_html_tags/window.rb +79 -0
- data/lib/cyberweb/predefined_and_freeform_methods/README.md +1 -0
- data/lib/cyberweb/predefined_and_freeform_methods/frage.rb +45 -0
- data/lib/cyberweb/predefined_and_freeform_methods/freeform_methods.rb +93 -0
- data/lib/cyberweb/predefined_and_freeform_methods/hash_css_class_to_use.rb +55 -0
- data/lib/cyberweb/predefined_and_freeform_methods/hash_registered_extra_tags.rb +29 -0
- data/lib/cyberweb/predefined_and_freeform_methods/header.rb +81 -0
- data/lib/cyberweb/predefined_and_freeform_methods/predefined_methods.rb +413 -0
- data/lib/cyberweb/project/project.rb +85 -0
- data/lib/cyberweb/rack/README.md +1 -0
- data/lib/cyberweb/rack/request.rb +31 -0
- data/lib/cyberweb/requires/README.md +4 -0
- data/lib/cyberweb/requires/do_require_web_object_files.rb +9 -0
- data/lib/cyberweb/requires/remove_html.rb +9 -0
- data/lib/cyberweb/requires/require_cgi.rb +16 -0
- data/lib/cyberweb/requires/require_charts.rb +20 -0
- data/lib/cyberweb/requires/require_generators.rb +23 -0
- data/lib/cyberweb/requires/require_html_tags_files.rb +23 -0
- data/lib/cyberweb/requires/require_javascript_files.rb +23 -0
- data/lib/cyberweb/requires/require_kimurai.rb +13 -0
- data/lib/cyberweb/requires/require_objectified_html_tags_files.rb +23 -0
- data/lib/cyberweb/requires/require_sinatra.rb +7 -0
- data/lib/cyberweb/requires/require_the_constants.rb +26 -0
- data/lib/cyberweb/requires/require_the_cyberweb_project.rb +172 -0
- data/lib/cyberweb/requires/require_the_html_template.rb +7 -0
- data/lib/cyberweb/requires/require_the_toplevel_methods_files.rb +24 -0
- data/lib/cyberweb/requires/require_web_images.rb +7 -0
- data/lib/cyberweb/requires/require_web_object_files.rb +25 -0
- data/lib/cyberweb/requires/require_yaml.rb +11 -0
- data/lib/cyberweb/sinatra/README.md +11 -0
- data/lib/cyberweb/sinatra/base.rb +145 -0
- data/lib/cyberweb/sinatra/custom_extensions.rb +131 -0
- data/lib/cyberweb/standalone_classes/all_css_classes.rb +255 -0
- data/lib/cyberweb/standalone_classes/calculator.rb +127 -0
- data/lib/cyberweb/standalone_classes/correct_image_entries_in_html_file.rb +207 -0
- data/lib/cyberweb/standalone_classes/input_focus.rb +97 -0
- data/lib/cyberweb/standalone_classes/tag_prototype.rb +43 -0
- data/lib/cyberweb/standalone_classes/turn_html_into_cyberweb.rb +174 -0
- data/lib/cyberweb/svg/blue_rect.svg +12 -0
- data/lib/cyberweb/svg/butterfly.svg +15 -0
- data/lib/cyberweb/svg/chemical_molecule.svg +192 -0
- data/lib/cyberweb/svg/circles_on_background.svg +29 -0
- data/lib/cyberweb/svg/ellipse.svg +12 -0
- data/lib/cyberweb/svg/five_circles.svg +26 -0
- data/lib/cyberweb/svg/flag_germany.svg +10 -0
- data/lib/cyberweb/svg/gaussian_blur.svg +20 -0
- data/lib/cyberweb/svg/gradient_circle.svg +18 -0
- data/lib/cyberweb/svg/green_butterfly.svg +18 -0
- data/lib/cyberweb/svg/green_tilted_lines.svg +25 -0
- data/lib/cyberweb/svg/lion.svg +161 -0
- data/lib/cyberweb/svg/one_circle.svg +12 -0
- data/lib/cyberweb/svg/pie_chart.svg +130 -0
- data/lib/cyberweb/svg/svg.cgi +61 -0
- data/lib/cyberweb/svg/tetris.svg +487 -0
- data/lib/cyberweb/svg/three_circles.svg +18 -0
- data/lib/cyberweb/svg/tiger.svg +732 -0
- data/lib/cyberweb/svg/tilted_arcs.svg +74 -0
- data/lib/cyberweb/svg/transparent_rect.svg +12 -0
- data/lib/cyberweb/svg/yellow_fe_blending.svg +42 -0
- data/lib/cyberweb/toplevel_methods/a.rb +131 -0
- data/lib/cyberweb/toplevel_methods/anmerkung.rb +67 -0
- data/lib/cyberweb/toplevel_methods/audio.rb +59 -0
- data/lib/cyberweb/toplevel_methods/bold.rb +65 -0
- data/lib/cyberweb/toplevel_methods/cgi.rb +65 -0
- data/lib/cyberweb/toplevel_methods/charsets.rb +52 -0
- data/lib/cyberweb/toplevel_methods/clear.rb +30 -0
- data/lib/cyberweb/toplevel_methods/close.rb +62 -0
- data/lib/cyberweb/toplevel_methods/consider_serving_the_web_object.rb +41 -0
- data/lib/cyberweb/toplevel_methods/css.rb +732 -0
- data/lib/cyberweb/toplevel_methods/date.rb +71 -0
- data/lib/cyberweb/toplevel_methods/dictionary.rb +48 -0
- data/lib/cyberweb/toplevel_methods/disable.rb +49 -0
- data/lib/cyberweb/toplevel_methods/document.rb +56 -0
- data/lib/cyberweb/toplevel_methods/dot.rb +182 -0
- data/lib/cyberweb/toplevel_methods/download_webpage.rb +18 -0
- data/lib/cyberweb/toplevel_methods/edit_configuration_file.rb +26 -0
- data/lib/cyberweb/toplevel_methods/ee.rb +44 -0
- data/lib/cyberweb/toplevel_methods/env.rb +44 -0
- data/lib/cyberweb/toplevel_methods/escape_html.rb +54 -0
- data/lib/cyberweb/toplevel_methods/fields.rb +46 -0
- data/lib/cyberweb/toplevel_methods/filename.rb +33 -0
- data/lib/cyberweb/toplevel_methods/frames.rb +131 -0
- data/lib/cyberweb/toplevel_methods/glob.rb +30 -0
- data/lib/cyberweb/toplevel_methods/google.rb +35 -0
- data/lib/cyberweb/toplevel_methods/hardware_information.rb +90 -0
- data/lib/cyberweb/toplevel_methods/hfin.rb +56 -0
- data/lib/cyberweb/toplevel_methods/html_comment.rb +48 -0
- data/lib/cyberweb/toplevel_methods/html_mode.rb +39 -0
- data/lib/cyberweb/toplevel_methods/html_tables.rb +818 -0
- data/lib/cyberweb/toplevel_methods/input.rb +54 -0
- data/lib/cyberweb/toplevel_methods/jquery.rb +82 -0
- data/lib/cyberweb/toplevel_methods/last_modified.rb +39 -0
- data/lib/cyberweb/toplevel_methods/links.rb +426 -0
- data/lib/cyberweb/toplevel_methods/listing.rb +96 -0
- data/lib/cyberweb/toplevel_methods/localhost.rb +18 -0
- data/lib/cyberweb/toplevel_methods/log_directory.rb +84 -0
- data/lib/cyberweb/toplevel_methods/logging.rb +42 -0
- data/lib/cyberweb/toplevel_methods/logo.rb +30 -0
- data/lib/cyberweb/toplevel_methods/markdown.rb +112 -0
- data/lib/cyberweb/toplevel_methods/mathml.rb +130 -0
- data/lib/cyberweb/toplevel_methods/message_boxes.rb +140 -0
- data/lib/cyberweb/toplevel_methods/misc.rb +1398 -0
- data/lib/cyberweb/toplevel_methods/name_of_img_dir.rb +51 -0
- data/lib/cyberweb/toplevel_methods/padlem_and_marlem.rb +107 -0
- data/lib/cyberweb/toplevel_methods/params.rb +57 -0
- data/lib/cyberweb/toplevel_methods/path.rb +69 -0
- data/lib/cyberweb/toplevel_methods/pdf.rb +103 -0
- data/lib/cyberweb/toplevel_methods/process_content.rb +102 -0
- data/lib/cyberweb/toplevel_methods/progress.rb +42 -0
- data/lib/cyberweb/toplevel_methods/quote.rb +44 -0
- data/lib/cyberweb/toplevel_methods/random.rb +70 -0
- data/lib/cyberweb/toplevel_methods/rds.rb +35 -0
- data/lib/cyberweb/toplevel_methods/read_and_display.rb +284 -0
- data/lib/cyberweb/toplevel_methods/readlines.rb +31 -0
- data/lib/cyberweb/toplevel_methods/redirect.rb +29 -0
- data/lib/cyberweb/toplevel_methods/registered_ids.rb +178 -0
- data/lib/cyberweb/toplevel_methods/remove_html.rb +32 -0
- data/lib/cyberweb/toplevel_methods/remove_newlines.rb +28 -0
- data/lib/cyberweb/toplevel_methods/return_head_start.rb +33 -0
- data/lib/cyberweb/toplevel_methods/return_html_fin.rb +34 -0
- data/lib/cyberweb/toplevel_methods/return_html_header.rb +35 -0
- data/lib/cyberweb/toplevel_methods/return_html_start.rb +24 -0
- data/lib/cyberweb/toplevel_methods/return_html_to_head_start.rb +42 -0
- data/lib/cyberweb/toplevel_methods/return_meta_collection.rb +54 -0
- data/lib/cyberweb/toplevel_methods/return_pwd.rb +23 -0
- data/lib/cyberweb/toplevel_methods/return_strict_doctype.rb +51 -0
- data/lib/cyberweb/toplevel_methods/roebe.rb +43 -0
- data/lib/cyberweb/toplevel_methods/s2.rb +30 -0
- data/lib/cyberweb/toplevel_methods/sanitize_url.rb +57 -0
- data/lib/cyberweb/toplevel_methods/sbr.rb +170 -0
- data/lib/cyberweb/toplevel_methods/server_base_directory.rb +148 -0
- data/lib/cyberweb/toplevel_methods/show_and_display.rb +215 -0
- data/lib/cyberweb/toplevel_methods/show_configuration.rb +83 -0
- data/lib/cyberweb/toplevel_methods/sitemap.rb +111 -0
- data/lib/cyberweb/toplevel_methods/spacer.rb +119 -0
- data/lib/cyberweb/toplevel_methods/string_body_start.rb +65 -0
- data/lib/cyberweb/toplevel_methods/string_content.rb +35 -0
- data/lib/cyberweb/toplevel_methods/svg.rb +66 -0
- data/lib/cyberweb/toplevel_methods/tag.rb +237 -0
- data/lib/cyberweb/toplevel_methods/temp_directory.rb +73 -0
- data/lib/cyberweb/toplevel_methods/test_css.rb +24 -0
- data/lib/cyberweb/toplevel_methods/textile.rb +45 -0
- data/lib/cyberweb/toplevel_methods/title.rb +125 -0
- data/lib/cyberweb/toplevel_methods/umlaute.rb +90 -0
- data/lib/cyberweb/toplevel_methods/video.rb +352 -0
- data/lib/cyberweb/toplevel_methods/view_source.rb +50 -0
- data/lib/cyberweb/toplevel_methods/web_object.rb +42 -0
- data/lib/cyberweb/toplevel_methods/write_what_into.rb +27 -0
- data/lib/cyberweb/utility_scripts/README.md +4 -0
- data/lib/cyberweb/utility_scripts/create_coloured_tags.rb +172 -0
- data/lib/cyberweb/utility_scripts/download_balloon_css.rb +160 -0
- data/lib/cyberweb/utility_scripts/hyperlink_all_images_from.rb +148 -0
- data/lib/cyberweb/version/version.rb +25 -0
- data/lib/cyberweb/web_base/web_base.rb +28 -0
- data/lib/cyberweb/web_images/array_listing_all_project_images.rb +52 -0
- data/lib/cyberweb/web_images/map_symbol_to_image_location.rb +1661 -0
- data/lib/cyberweb/web_images/web_images.rb +270 -0
- data/lib/cyberweb/web_object/css.rb +627 -0
- data/lib/cyberweb/web_object/evaluate.rb +126 -0
- data/lib/cyberweb/web_object/favicon.rb +160 -0
- data/lib/cyberweb/web_object/html_related_tags.rb +320 -0
- data/lib/cyberweb/web_object/images.rb +693 -0
- data/lib/cyberweb/web_object/initialize.rb +51 -0
- data/lib/cyberweb/web_object/input_related_functionality.rb +414 -0
- data/lib/cyberweb/web_object/javascript.rb +427 -0
- data/lib/cyberweb/web_object/languages.rb +172 -0
- data/lib/cyberweb/web_object/links.rb +228 -0
- data/lib/cyberweb/web_object/misc.rb +5159 -0
- data/lib/cyberweb/web_object/params.rb +289 -0
- data/lib/cyberweb/web_object/reset.rb +192 -0
- data/lib/cyberweb/web_object/run.rb +44 -0
- data/lib/cyberweb/web_object/sinatra_related_functionality.rb +30 -0
- data/lib/cyberweb/web_object/sitemap.rb +176 -0
- data/lib/cyberweb/web_object/table.rb +378 -0
- data/lib/cyberweb/web_object/web_object.rb +126 -0
- data/lib/cyberweb/web_scraper/README.md +8 -0
- data/lib/cyberweb/web_scraper/scrape_this_url.rb +183 -0
- data/lib/cyberweb/webmin/biology_server.cgi +256 -0
- data/lib/cyberweb/webmin/calculator.cgi +52 -0
- data/lib/cyberweb/webmin/colour_chart.cgi +33 -0
- data/lib/cyberweb/webmin/comments.cgi +137 -0
- data/lib/cyberweb/webmin/comments_data +18 -0
- data/lib/cyberweb/webmin/constants.rb +46 -0
- data/lib/cyberweb/webmin/dictionary.cgi +39 -0
- data/lib/cyberweb/webmin/sys_info.cgi +26 -0
- data/lib/cyberweb/webmin/webforum.cgi +58 -0
- data/lib/cyberweb/webmin/webmin.cgi +679 -0
- data/lib/cyberweb/yaml/autogenerated_system_settings.yml +14 -0
- data/lib/cyberweb/yaml/custom_tags.yml +7 -0
- data/lib/cyberweb/yaml/debug.yml +1 -0
- data/lib/cyberweb/yaml/html5_global_attributes.yml +12 -0
- data/lib/cyberweb/yaml/html5_new_elements.yml +108 -0
- data/lib/cyberweb/yaml/html_tag_legend.yml +12 -0
- data/lib/cyberweb/yaml/http_status_codes.yml +38 -0
- data/lib/cyberweb/yaml/js_files_to_load.yml +28 -0
- data/lib/cyberweb/yaml/project_configuration.yml +229 -0
- data/lib/cyberweb/yaml/video_attributes.yml +35 -0
- data/lib/cyberweb/yaml/web_images.yml +306 -0
- data/lib/cyberweb.rb +5 -0
- data/test/README.md +5 -0
- data/test/complex_tests/all_tests_in_one_page.cgi +666 -0
- data/test/complex_tests/simple_sinatra_example_using_cyberweb/simple.rb +60 -0
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.cgi +7 -0
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.rb +23 -0
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.sinatra +65 -0
- data/test/complex_tests/testing_frames.cgi +42 -0
- data/test/complex_tests/testing_objectified_html_tags.rb +82 -0
- data/test/complex_tests/testing_style_variants/README.md +2 -0
- data/test/complex_tests/testing_style_variants/show_coloured_boxes.cgi +58 -0
- data/test/complex_tests/testing_tables.cgi +67 -0
- data/test/complex_tests/testing_the_cyberweb_shell.rb +188 -0
- data/test/complex_tests/testing_web_object.rb +94 -0
- data/test/css/README.md +5 -0
- data/test/css/return_the_content_of_these_css_classes.rb +7 -0
- data/test/css/testing_css_effects.cgi +159 -0
- data/test/css/testing_css_masking.cgi +36 -0
- data/test/dummy.pdf +0 -0
- data/test/hello_world/hello_world.cgi +25 -0
- data/test/javascript/README.md +2 -0
- data/test/javascript/testing_cheerleader_javascript.cgi +0 -0
- data/test/javascript/testing_drag_and_drop_support.cgi +33 -0
- data/test/javascript/testing_on_click_change_opacity.cgi +26 -0
- data/test/javascript/testing_snowflakes.cgi +20 -0
- data/test/simple_tests/README.md +3 -0
- data/test/simple_tests/ad-hoc-test.cgi +55 -0
- data/test/simple_tests/commandline_tests.rb +70 -0
- data/test/simple_tests/display_this_file.cgi +11 -0
- data/test/simple_tests/simple_html_example.cgi +29 -0
- data/test/simple_tests/simple_status_page.cgi +52 -0
- data/test/simple_tests/string_s2_test.rb +11 -0
- data/test/simple_tests/test_simple_string_as_input.rb +12 -0
- data/test/simple_tests/testing_base64_images.cgi +26 -0
- data/test/simple_tests/testing_dragging_an_image.cgi +23 -0
- data/test/simple_tests/testing_editable_text.cgi +16 -0
- data/test/simple_tests/testing_email.cgi +31 -0
- data/test/simple_tests/testing_embedding_a_pdf_file.cgi +32 -0
- data/test/simple_tests/testing_google_charts.cgi +24 -0
- data/test/simple_tests/testing_html_forms.cgi +31 -0
- data/test/simple_tests/testing_html_template.rb +13 -0
- data/test/simple_tests/testing_popup_div.cgi +22 -0
- data/test/simple_tests/testing_return_dataset_without_any_comments.rb +11 -0
- data/test/simple_tests/testing_the_cap_box.cgi +20 -0
- data/test/simple_tests/testing_the_div_tag.cgi +21 -0
- data/test/simple_tests/testing_the_headers_tag.cgi +36 -0
- data/test/simple_tests/testing_the_html_colours.cgi +19 -0
- data/test/simple_tests/testing_the_info_box.cgi +19 -0
- data/test/simple_tests/testing_the_li_tag.cgi +24 -0
- data/test/simple_tests/testing_the_s2_method.rb +7 -0
- data/test/simple_tests/testing_the_select_tag.cgi +23 -0
- data/test/simple_tests/testing_the_span_tag.cgi +36 -0
- data/test/simple_tests/testing_web_images.rb +12 -0
- data/test/testing_html_tags/README.md +7 -0
- data/test/testing_html_tags/button_example.cgi +42 -0
- metadata +759 -0
@@ -0,0 +1,487 @@
|
|
1
|
+
<?xml version="1.0"?>
|
2
|
+
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
|
3
|
+
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
4
|
+
|
5
|
+
<!-- SVG Tetris for SVG-enabled Mozilla -->
|
6
|
+
<!-- (c)2004 alex fritze <alex@croczilla.com> -->
|
7
|
+
<!-- ugly score and time hack by Tuna-Fish -->
|
8
|
+
<!-- -->
|
9
|
+
<!-- For info about Mozilla/SVG see -->
|
10
|
+
<!-- http://www.mozilla.org/projects/svg/ -->
|
11
|
+
|
12
|
+
<svg xmlns="http://www.w3.org/2000/svg"
|
13
|
+
xmlns:xlink="http://www.w3.org/1999/xlink"
|
14
|
+
onload="init();">
|
15
|
+
|
16
|
+
<script>
|
17
|
+
<![CDATA[
|
18
|
+
|
19
|
+
//----------------------------------------------------------------------
|
20
|
+
// static data
|
21
|
+
|
22
|
+
var SVG_NS ="http://www.w3.org/2000/svg";
|
23
|
+
var tickTimeReducer = 0.98;
|
24
|
+
var ROWS = 20;
|
25
|
+
var COLS = 10;
|
26
|
+
|
27
|
+
var HPAD = 2; // horizontal padding used in laying out grids
|
28
|
+
var VPAD = 2; // ditto for vertical
|
29
|
+
|
30
|
+
var SHAPE_DESCRIPTORS = [
|
31
|
+
{ color: "grey", orientations: [ [[0,0],[1,0],[0,1],[1,1]] ] },
|
32
|
+
{ color: "blue", orientations: [ [[0,0],[1,0],[2,0],[2,1]],
|
33
|
+
[[1,0],[1,1],[1,2],[0,2]],
|
34
|
+
[[0,0],[0,1],[1,1],[2,1]],
|
35
|
+
[[0,0],[1,0],[0,1],[0,2]] ] },
|
36
|
+
{ color: "purple", orientations: [ [[0,0],[0,1],[1,0],[2,0]],
|
37
|
+
[[0,0],[1,0],[1,1],[1,2]],
|
38
|
+
[[0,1],[1,1],[2,1],[2,0]],
|
39
|
+
[[0,0],[0,1],[0,2],[1,2]] ] },
|
40
|
+
{ color: "cyan", orientations: [ [[0,0],[1,0],[2,0],[3,0]],
|
41
|
+
[[0,0],[0,1],[0,2],[0,3]] ] },
|
42
|
+
{ color: "green", orientations: [ [[1,0],[2,0],[0,1],[1,1]],
|
43
|
+
[[0,0],[0,1],[1,1],[1,2]] ] },
|
44
|
+
{ color: "red", orientations: [ [[1,0],[1,1],[0,1],[0,2]],
|
45
|
+
[[0,0],[1,0],[1,1],[2,1]] ] },
|
46
|
+
{ color: "yellow", orientations: [ [[0,1],[1,1],[2,1],[1,0]],
|
47
|
+
[[0,0],[0,1],[0,2],[1,1]],
|
48
|
+
[[0,0],[1,0],[2,0],[1,1]],
|
49
|
+
[[1,0],[1,1],[1,2],[0,1]] ] }
|
50
|
+
];
|
51
|
+
|
52
|
+
//----------------------------------------------------------------------
|
53
|
+
// Helper functions
|
54
|
+
|
55
|
+
// map a function over an array; accumulate output in new array:
|
56
|
+
function mapcar(f, a) {
|
57
|
+
var res = new Array(a.length);
|
58
|
+
for (var i=0;i<a.length;++i) {
|
59
|
+
res[i] = f(a[i]);
|
60
|
+
}
|
61
|
+
return res;
|
62
|
+
}
|
63
|
+
|
64
|
+
// map a function over an array; don't accumulate output:
|
65
|
+
function mapc(f, a) {
|
66
|
+
for (var i=0;i<a.length;++i) {
|
67
|
+
f(a[i]);
|
68
|
+
}
|
69
|
+
}
|
70
|
+
|
71
|
+
// return true if predicate p is true for every element of the array:
|
72
|
+
function every(p, a) {
|
73
|
+
for (var i=0;i<a.length;++i) {
|
74
|
+
if (!p(a[i])) return false;
|
75
|
+
}
|
76
|
+
return true;
|
77
|
+
}
|
78
|
+
|
79
|
+
function suspendRedraw()
|
80
|
+
{
|
81
|
+
// asv doesn't implement suspendRedraw, so we wrap this in a try-block:
|
82
|
+
try {
|
83
|
+
document.documentElement.suspendRedraw(0);
|
84
|
+
}
|
85
|
+
catch(e) {}
|
86
|
+
}
|
87
|
+
|
88
|
+
function unsuspendRedraw()
|
89
|
+
{
|
90
|
+
// asv doesn't implement unsuspendRedraw, so we wrap this in a try-block:
|
91
|
+
try {
|
92
|
+
document.documentElement.unsuspendRedraw(0);
|
93
|
+
}
|
94
|
+
catch(e) {}
|
95
|
+
}
|
96
|
+
|
97
|
+
//----------------------------------------------------------------------
|
98
|
+
// Shape class
|
99
|
+
|
100
|
+
function Shape(position) {
|
101
|
+
// create a new shape, randomly picking a descriptor & orientation:
|
102
|
+
this._descriptor = SHAPE_DESCRIPTORS[Math.round(Math.random()*(SHAPE_DESCRIPTORS.length-1))];
|
103
|
+
this._orientation = Math.round(Math.random()*(this._descriptor.orientations.length-1));
|
104
|
+
this._pos = position;
|
105
|
+
}
|
106
|
+
|
107
|
+
Shape.prototype = {
|
108
|
+
getCellArray : function() {
|
109
|
+
var s = this;
|
110
|
+
return mapcar(function(coord) { return [coord[0]+s._pos[0],coord[1]+s._pos[1]]; },
|
111
|
+
this._descriptor.orientations[this._orientation]);
|
112
|
+
},
|
113
|
+
getColor : function() {
|
114
|
+
return this._descriptor.color;
|
115
|
+
},
|
116
|
+
move : function(dx,dy) {
|
117
|
+
this._pos[0] += dx; this._pos[1] += dy;
|
118
|
+
},
|
119
|
+
rotate : function(dOrient) {
|
120
|
+
this._orientation = (this._orientation+dOrient) % this._descriptor.orientations.length;
|
121
|
+
if (this._orientation<0) this._orientation += this._descriptor.orientations.length;
|
122
|
+
}
|
123
|
+
};
|
124
|
+
|
125
|
+
//----------------------------------------------------------------------
|
126
|
+
// Grid class
|
127
|
+
|
128
|
+
function Grid(cols, rows, color, bordercolor, x, y, width, height, node) {
|
129
|
+
// Create a cols*rows grid with a 1/2-cell border.
|
130
|
+
// Scale to fit width*height user pixels (including border).
|
131
|
+
// Place at x,y user pixel coords.
|
132
|
+
|
133
|
+
this._cols = cols;
|
134
|
+
this._rows = rows;
|
135
|
+
this._color = color;
|
136
|
+
|
137
|
+
node.setAttribute("transform", "translate("+x+","+y+") scale("+
|
138
|
+
(width/(cols+1))+","+(height/(rows+1))+") translate(0.5,0.5)");
|
139
|
+
|
140
|
+
this._border = document.createElementNS(SVG_NS, "rect");
|
141
|
+
this._border.setAttribute("fill", bordercolor);
|
142
|
+
this._border.setAttribute("width", cols+1);
|
143
|
+
this._border.setAttribute("height", rows+1);
|
144
|
+
this._border.setAttribute("x", "-0.5");
|
145
|
+
this._border.setAttribute("y", "-0.5");
|
146
|
+
|
147
|
+
this._background = document.createElementNS(SVG_NS, "rect");
|
148
|
+
this._background.setAttribute("fill", color);
|
149
|
+
this._background.setAttribute("width", cols);
|
150
|
+
this._background.setAttribute("height", rows);
|
151
|
+
|
152
|
+
this._rowArray = document.createElementNS(SVG_NS, "g");
|
153
|
+
for (var r=0;r<rows;++r) {
|
154
|
+
var row_group = document.createElementNS(SVG_NS, "g");
|
155
|
+
row_group.setAttribute("transform", "translate(0,"+r+")");
|
156
|
+
|
157
|
+
for (var c=0;c<cols;++c) {
|
158
|
+
var cell = document.createElementNS(SVG_NS, "rect");
|
159
|
+
cell.setAttribute("x", c);
|
160
|
+
cell.setAttribute("width", "1");
|
161
|
+
cell.setAttribute("height", "1");
|
162
|
+
cell.setAttribute("stroke", "grey");
|
163
|
+
cell.setAttribute("fill", "none");
|
164
|
+
cell.occupied = false;
|
165
|
+
row_group.appendChild(cell);
|
166
|
+
}
|
167
|
+
this._rowArray.appendChild(row_group);
|
168
|
+
}
|
169
|
+
|
170
|
+
node.appendChild(this._border);
|
171
|
+
node.appendChild(this._background);
|
172
|
+
node.appendChild(this._rowArray);
|
173
|
+
}
|
174
|
+
|
175
|
+
Grid.prototype = {
|
176
|
+
colorCell : function(coord, color) { try {
|
177
|
+
this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).setAttribute("fill", color);
|
178
|
+
}catch(e) {
|
179
|
+
alert("error: coord="+coord);
|
180
|
+
}
|
181
|
+
},
|
182
|
+
clearCell : function(coord) {
|
183
|
+
this.colorCell(coord, this._color);
|
184
|
+
},
|
185
|
+
occupyCell : function(coord) {
|
186
|
+
// XXX ASV has a problem with expando properties, so we use attribs instead:
|
187
|
+
// this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).occupied = true;
|
188
|
+
this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).setAttribute("occupied", "true");
|
189
|
+
},
|
190
|
+
unoccupyCell : function(coord) {
|
191
|
+
// this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).occupied = false;
|
192
|
+
this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).setAttribute("occupied", "false");
|
193
|
+
},
|
194
|
+
cellInBounds : function(coord) {
|
195
|
+
return (coord[0]>=0 && coord[1]>=0 && coord[0]<this._cols && coord[1]<this._rows);
|
196
|
+
},
|
197
|
+
cellOccupied : function(coord) {
|
198
|
+
// return this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).occupied;
|
199
|
+
return this._rowArray.childNodes.item(coord[1]).childNodes.item(coord[0]).getAttribute("occupied")=="true";
|
200
|
+
},
|
201
|
+
eliminateFullRows : function() {
|
202
|
+
var g = this;
|
203
|
+
var bo = false;
|
204
|
+
function rowFull(r) {
|
205
|
+
for (var c=0;c<g._cols;++c) {
|
206
|
+
if (!g.cellOccupied([c,r])) return false;
|
207
|
+
}
|
208
|
+
return true;
|
209
|
+
}
|
210
|
+
|
211
|
+
function moveCellDown(c,r) {
|
212
|
+
var src = g._rowArray.childNodes.item(r).childNodes.item(c);
|
213
|
+
var dest = g._rowArray.childNodes.item(r+1).childNodes.item(c);
|
214
|
+
dest.setAttribute("fill", src.getAttribute("fill"));
|
215
|
+
//dest.occupied = src.occupied;
|
216
|
+
//src.occupied = false;
|
217
|
+
dest.setAttribute("occupied", src.getAttribute("occupied"));
|
218
|
+
src.setAttribute("occupied", "false");
|
219
|
+
src.setAttribute("fill", g._color);
|
220
|
+
}
|
221
|
+
|
222
|
+
function eliminateRow(row) {
|
223
|
+
suspendRedraw();
|
224
|
+
for (var c=0;c<g._cols;++c) {
|
225
|
+
g.clearCell([c,row]);
|
226
|
+
g.unoccupyCell([c,row]);
|
227
|
+
}
|
228
|
+
for (var r=row-1;r>=0;--r) {
|
229
|
+
for (c=0;c<g._cols;++c) {
|
230
|
+
if (g.cellOccupied([c,r]))
|
231
|
+
moveCellDown(c,r);
|
232
|
+
}
|
233
|
+
}
|
234
|
+
unsuspendRedraw();
|
235
|
+
}
|
236
|
+
|
237
|
+
for (var r=0;r<this._rows;++r) {
|
238
|
+
if (rowFull(r)) {
|
239
|
+
bo = true;
|
240
|
+
eliminateRow(r);
|
241
|
+
++lines;
|
242
|
+
}
|
243
|
+
}
|
244
|
+
if (bo) {
|
245
|
+
tickTime=time(tickTime);
|
246
|
+
}
|
247
|
+
}
|
248
|
+
};
|
249
|
+
|
250
|
+
//----------------------------------------------------------------------
|
251
|
+
// message class
|
252
|
+
|
253
|
+
function Message(txt, position, style) {
|
254
|
+
this._node = document.createElementNS(SVG_NS, "text");
|
255
|
+
this._node.setAttribute("style", style);
|
256
|
+
this._node.setAttribute("x", position[0]);
|
257
|
+
this._node.setAttribute("y", position[1]);
|
258
|
+
this._node.appendChild(document.createTextNode(txt));
|
259
|
+
}
|
260
|
+
|
261
|
+
Message.prototype = {
|
262
|
+
show : function() {
|
263
|
+
suspendRedraw();
|
264
|
+
document.documentElement.appendChild(this._node);
|
265
|
+
unsuspendRedraw();
|
266
|
+
},
|
267
|
+
hide : function() {
|
268
|
+
document.documentElement.removeChild(this._node);
|
269
|
+
}
|
270
|
+
};
|
271
|
+
|
272
|
+
//----------------------------------------------------------------------
|
273
|
+
// grid <---> shape operations
|
274
|
+
|
275
|
+
function canPlace(shape, grid) {
|
276
|
+
// can only place if all cells in shape are in bounds and not occupied:
|
277
|
+
return every(function(coord){ return grid.cellInBounds(coord) &&
|
278
|
+
!grid.cellOccupied(coord); },
|
279
|
+
shape.getCellArray());
|
280
|
+
}
|
281
|
+
|
282
|
+
function show(shape, grid) {
|
283
|
+
suspendRedraw();
|
284
|
+
mapc(function(coord){ grid.colorCell(coord, shape.getColor()); },
|
285
|
+
shape.getCellArray());
|
286
|
+
unsuspendRedraw();
|
287
|
+
}
|
288
|
+
|
289
|
+
function hide(shape, grid) {
|
290
|
+
suspendRedraw();
|
291
|
+
mapc(function(coord){ grid.clearCell(coord); },
|
292
|
+
shape.getCellArray());
|
293
|
+
unsuspendRedraw();
|
294
|
+
}
|
295
|
+
|
296
|
+
function occupy(shape, grid) {
|
297
|
+
mapc(function(coord){ grid.occupyCell(coord); },
|
298
|
+
shape.getCellArray());
|
299
|
+
}
|
300
|
+
|
301
|
+
function move(shape, grid, dx, dy) {
|
302
|
+
shape.move(dx,dy);
|
303
|
+
if (!canPlace(shape, grid)) {
|
304
|
+
shape.move(-dx,-dy);
|
305
|
+
return false;
|
306
|
+
}
|
307
|
+
suspendRedraw();
|
308
|
+
shape.move(-dx, -dy);
|
309
|
+
hide(shape, grid);
|
310
|
+
shape.move(dx,dy);
|
311
|
+
show(shape, grid);
|
312
|
+
unsuspendRedraw();
|
313
|
+
return true;
|
314
|
+
}
|
315
|
+
|
316
|
+
function rotate(shape, grid, dOrient) {
|
317
|
+
shape.rotate(dOrient);
|
318
|
+
if (!canPlace(shape, grid)) {
|
319
|
+
shape.rotate(-dOrient);
|
320
|
+
return false;
|
321
|
+
}
|
322
|
+
suspendRedraw();
|
323
|
+
shape.rotate(-dOrient);
|
324
|
+
hide(shape, grid);
|
325
|
+
shape.rotate(dOrient);
|
326
|
+
show(shape, grid);
|
327
|
+
unsuspendRedraw();
|
328
|
+
return true;
|
329
|
+
}
|
330
|
+
|
331
|
+
function drop(shape, grid) {
|
332
|
+
suspendRedraw();
|
333
|
+
while (move(shape, grid, 0, 1))
|
334
|
+
/**/;
|
335
|
+
unsuspendRedraw();
|
336
|
+
}
|
337
|
+
|
338
|
+
//----------------------------------------------------------------------
|
339
|
+
// the game:
|
340
|
+
|
341
|
+
var board; // grid where the action is
|
342
|
+
var preview; // grid where the next shape will be previewed
|
343
|
+
var currentShape;
|
344
|
+
var lines;
|
345
|
+
var score;
|
346
|
+
var nextShape;
|
347
|
+
var gameState; // "stopped", "running", "finished"
|
348
|
+
var tickTime;
|
349
|
+
function startNewGame() {
|
350
|
+
// XXX clear grids
|
351
|
+
score = 0;
|
352
|
+
suspendRedraw();
|
353
|
+
currentShape = new Shape([3,0]);
|
354
|
+
lines = 0;
|
355
|
+
show(currentShape, board);
|
356
|
+
nextShape = new Shape([0,0]);
|
357
|
+
show(nextShape, preview);
|
358
|
+
unsuspendRedraw();
|
359
|
+
gameState = "running";
|
360
|
+
tickTime = 300;
|
361
|
+
tick();
|
362
|
+
}
|
363
|
+
|
364
|
+
function runNextShape() {
|
365
|
+
occupy(currentShape, board);
|
366
|
+
board.eliminateFullRows();
|
367
|
+
score = score+1;
|
368
|
+
suspendRedraw();
|
369
|
+
currentShape = nextShape;
|
370
|
+
hide(nextShape, preview);
|
371
|
+
currentShape.move(3,0);
|
372
|
+
if (!canPlace(currentShape, board)) {
|
373
|
+
unsuspendRedraw();
|
374
|
+
return false; // game over!
|
375
|
+
}
|
376
|
+
show(currentShape, board);
|
377
|
+
nextShape = new Shape([0,0]);
|
378
|
+
show(nextShape, preview);
|
379
|
+
unsuspendRedraw();
|
380
|
+
return true;
|
381
|
+
}
|
382
|
+
|
383
|
+
function tick() {
|
384
|
+
if (gameState != "running") return;
|
385
|
+
|
386
|
+
if (!move(currentShape, board, 0, 1)) {
|
387
|
+
if(!runNextShape()) {
|
388
|
+
var m = new Message("Game Over! Score:"+score, [1,10], "stroke:none;font-size:2px;fill:red;stroke:black;stroke-width:0.04px;fill-opacity:0.8;");
|
389
|
+
m.show();
|
390
|
+
gameState = "finished";
|
391
|
+
return; // Game over
|
392
|
+
}
|
393
|
+
}
|
394
|
+
setTimeout("tick()", tickTime);
|
395
|
+
}
|
396
|
+
|
397
|
+
function time(tickTime) {
|
398
|
+
tickTime = tickTime*tickTimeReducer;
|
399
|
+
return tickTime;
|
400
|
+
}
|
401
|
+
|
402
|
+
function pause() {
|
403
|
+
if (gameState == "running")
|
404
|
+
gameState = "stopped";
|
405
|
+
}
|
406
|
+
|
407
|
+
function resume() {
|
408
|
+
if (gameState == "stopped") {
|
409
|
+
gameState = "running";
|
410
|
+
tick();
|
411
|
+
}
|
412
|
+
}
|
413
|
+
|
414
|
+
//----------------------------------------------------------------------
|
415
|
+
// user input handler
|
416
|
+
|
417
|
+
function keyHandler(event) {
|
418
|
+
event.preventDefault();
|
419
|
+
switch (event.keyCode) {
|
420
|
+
case 32: /* space */
|
421
|
+
if (gameState == "running")
|
422
|
+
drop(currentShape, board);
|
423
|
+
break;
|
424
|
+
case 72: /* h */
|
425
|
+
pause();
|
426
|
+
alert("Help:\n"+
|
427
|
+
"-------------------------------------\n\n"+
|
428
|
+
"Score : "+score+"\n"+
|
429
|
+
"Lines : "+lines+"\n"+
|
430
|
+
"h : Display this help\n"+
|
431
|
+
"p : Toggle pause game\n"+
|
432
|
+
"up : Rotate piece counterclockwise\n"+
|
433
|
+
"down : Rotate piece clocwise\n"+
|
434
|
+
"left : Move piece left\n"+
|
435
|
+
"right : Move piece right\n"+
|
436
|
+
"space : Drop piece\n");
|
437
|
+
resume();
|
438
|
+
break;
|
439
|
+
case 80: /* p */
|
440
|
+
if (gameState == "running")
|
441
|
+
pause();
|
442
|
+
else
|
443
|
+
resume();
|
444
|
+
break;
|
445
|
+
case 38: /* up */
|
446
|
+
if (gameState == "running")
|
447
|
+
rotate(currentShape, board, -1);
|
448
|
+
break;
|
449
|
+
case 40: /* down */
|
450
|
+
if (gameState == "running")
|
451
|
+
rotate(currentShape, board, 1);
|
452
|
+
break;
|
453
|
+
case 37: /* left */
|
454
|
+
if (gameState == "running")
|
455
|
+
move(currentShape, board, -1, 0);
|
456
|
+
break;
|
457
|
+
case 39: /* right */
|
458
|
+
if (gameState == "running")
|
459
|
+
move(currentShape, board, 1, 0);
|
460
|
+
break;
|
461
|
+
}
|
462
|
+
}
|
463
|
+
|
464
|
+
//----------------------------------------------------------------------
|
465
|
+
|
466
|
+
function init() {
|
467
|
+
// page layout:
|
468
|
+
document.documentElement.setAttribute("viewBox", "0 0 "+(3*HPAD+(COLS+1)+5)+" "+(2*VPAD+(ROWS+1)));
|
469
|
+
|
470
|
+
board = new Grid(COLS, ROWS, "black", "grey", HPAD, VPAD, COLS+1, ROWS+1, document.getElementById("board"));
|
471
|
+
preview = new Grid(4,4, "black", "grey", 2*HPAD+COLS+1, VPAD, 5, 5, document.getElementById("preview"));
|
472
|
+
|
473
|
+
startNewGame();
|
474
|
+
|
475
|
+
// initialize event processing:
|
476
|
+
document.documentElement.addEventListener("keydown", keyHandler, false);
|
477
|
+
}
|
478
|
+
|
479
|
+
|
480
|
+
]]>
|
481
|
+
</script>
|
482
|
+
|
483
|
+
<text x="1" y="1" font-size="1px">Mozilla SVG Tetris - Press 'h' for help.</text>
|
484
|
+
<g id="preview" stroke-width="0.02"/>
|
485
|
+
<g id="board" stroke-width="0.02"/>
|
486
|
+
|
487
|
+
</svg>
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
2
|
+
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN"
|
3
|
+
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-basic.dtd">
|
4
|
+
<svg xmlns="http://www.w3.org/2000/svg"
|
5
|
+
xmlns:xlink="http://www.w3.org/1999/xlink">
|
6
|
+
|
7
|
+
<g fill-opacity="0.6" stroke="#fff" stroke-width="1px">
|
8
|
+
<circle cx="100px" cy="50px" r="50" fill="#00f"
|
9
|
+
transform="translate(0,0)" />
|
10
|
+
|
11
|
+
<circle cx="100px" cy="50px" r="50" fill="#ff0"
|
12
|
+
transform="translate(30,50)" />
|
13
|
+
|
14
|
+
<circle cx="100px" cy="50px" r="50" fill="#f0f"
|
15
|
+
transform="translate(-30,50)"/>
|
16
|
+
|
17
|
+
</g>
|
18
|
+
</svg>
|