@mapgis/mapbox-gl 16.0.1 → 16.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/mapbox-gl.js +3 -3
- package/dist/mapbox-gl.js.map +1 -1
- package/package.json +1 -1
- package/.flowconfig +0 -61
- package/LICENSE.txt +0 -84
- package/README.md +0 -34
- package/build/banner.js +0 -4
- package/build/check-bundle-size.js +0 -140
- package/build/generate-access-token-script.js +0 -11
- package/build/generate-flow-typed-style-spec.js +0 -188
- package/build/generate-release-list.js +0 -21
- package/build/generate-struct-arrays.js +0 -237
- package/build/generate-style-code.js +0 -159
- package/build/mapbox-gl.js.flow +0 -3
- package/build/print-release-url.js +0 -6
- package/build/rollup_plugin_minify_style_spec.js +0 -20
- package/build/rollup_plugins.js +0 -80
- package/build/run-node +0 -3
- package/build/run-tap +0 -8
- package/build/test/build-tape.js +0 -19
- package/flow-typed/gl.js +0 -5
- package/flow-typed/jsdom.js +0 -18
- package/flow-typed/mapbox-gl-supported.js +0 -9
- package/flow-typed/mapbox-unitbezier.js +0 -14
- package/flow-typed/offscreen-canvas.js +0 -9
- package/flow-typed/pbf.js +0 -25
- package/flow-typed/point-geometry.js +0 -44
- package/flow-typed/potpack.js +0 -12
- package/flow-typed/sinon.js +0 -28
- package/flow-typed/vector-tile.js +0 -41
- package/src/css/mapbox-gl.css +0 -798
- package/src/css/svg/mapboxgl-ctrl-attrib.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-compass.svg +0 -4
- package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-geolocate.svg +0 -5
- package/src/css/svg/mapboxgl-ctrl-logo.svg +0 -20
- package/src/css/svg/mapboxgl-ctrl-shrink.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +0 -3
- package/src/data/array_types.js +0 -1095
- package/src/data/bucket/circle_attributes.js +0 -9
- package/src/data/bucket/circle_bucket.js +0 -204
- package/src/data/bucket/fill_attributes.js +0 -9
- package/src/data/bucket/fill_bucket.js +0 -233
- package/src/data/bucket/fill_extrusion_attributes.js +0 -10
- package/src/data/bucket/fill_extrusion_bucket.js +0 -289
- package/src/data/bucket/heatmap_bucket.js +0 -17
- package/src/data/bucket/line_attributes.js +0 -10
- package/src/data/bucket/line_bucket.js +0 -556
- package/src/data/bucket/pattern_attributes.js +0 -10
- package/src/data/bucket/pattern_bucket_features.js +0 -60
- package/src/data/bucket/symbol_attributes.js +0 -117
- package/src/data/bucket/symbol_bucket.js +0 -972
- package/src/data/bucket.js +0 -123
- package/src/data/dem_data.js +0 -125
- package/src/data/extent.js +0 -18
- package/src/data/feature_index.js +0 -321
- package/src/data/feature_position_map.js +0 -125
- package/src/data/index_array_type.js +0 -16
- package/src/data/load_geometry.js +0 -48
- package/src/data/pos_attributes.js +0 -6
- package/src/data/program_configuration.js +0 -687
- package/src/data/raster_bounds_attributes.js +0 -7
- package/src/data/segment.js +0 -76
- package/src/geo/edge_insets.js +0 -102
- package/src/geo/lng_lat.js +0 -165
- package/src/geo/lng_lat_bounds.js +0 -267
- package/src/geo/mercator_coordinate.js +0 -153
- package/src/geo/transform.js +0 -864
- package/src/gl/color_mode.js +0 -34
- package/src/gl/context.js +0 -298
- package/src/gl/cull_face_mode.js +0 -26
- package/src/gl/depth_mode.js +0 -29
- package/src/gl/framebuffer.js +0 -44
- package/src/gl/index_buffer.js +0 -55
- package/src/gl/stencil_mode.js +0 -30
- package/src/gl/types.js +0 -84
- package/src/gl/value.js +0 -520
- package/src/gl/vertex_buffer.js +0 -119
- package/src/index.js +0 -201
- package/src/render/draw_background.js +0 -57
- package/src/render/draw_circle.js +0 -113
- package/src/render/draw_collision_debug.js +0 -49
- package/src/render/draw_custom.js +0 -49
- package/src/render/draw_debug.js +0 -127
- package/src/render/draw_fill.js +0 -126
- package/src/render/draw_fill_extrusion.js +0 -96
- package/src/render/draw_heatmap.js +0 -140
- package/src/render/draw_hillshade.js +0 -108
- package/src/render/draw_line.js +0 -98
- package/src/render/draw_raster.js +0 -125
- package/src/render/draw_symbol.js +0 -394
- package/src/render/glyph_atlas.js +0 -71
- package/src/render/glyph_manager.js +0 -182
- package/src/render/image_atlas.js +0 -149
- package/src/render/image_manager.js +0 -306
- package/src/render/line_atlas.js +0 -210
- package/src/render/painter.js +0 -653
- package/src/render/program/background_program.js +0 -103
- package/src/render/program/circle_program.js +0 -69
- package/src/render/program/clipping_mask_program.js +0 -20
- package/src/render/program/collision_program.js +0 -49
- package/src/render/program/debug_program.js +0 -35
- package/src/render/program/fill_extrusion_program.js +0 -122
- package/src/render/program/fill_program.js +0 -126
- package/src/render/program/heatmap_program.js +0 -83
- package/src/render/program/hillshade_program.js +0 -122
- package/src/render/program/line_program.js +0 -207
- package/src/render/program/pattern.js +0 -102
- package/src/render/program/program_uniforms.js +0 -42
- package/src/render/program/raster_program.js +0 -92
- package/src/render/program/symbol_program.js +0 -224
- package/src/render/program.js +0 -168
- package/src/render/texture.js +0 -122
- package/src/render/uniform_binding.js +0 -147
- package/src/render/vertex_array_object.js +0 -163
- package/src/shaders/README.md +0 -42
- package/src/shaders/_prelude.fragment.glsl +0 -17
- package/src/shaders/_prelude.vertex.glsl +0 -73
- package/src/shaders/background.fragment.glsl +0 -10
- package/src/shaders/background.vertex.glsl +0 -7
- package/src/shaders/background_pattern.fragment.glsl +0 -28
- package/src/shaders/background_pattern.vertex.glsl +0 -20
- package/src/shaders/circle.fragment.glsl +0 -39
- package/src/shaders/circle.vertex.glsl +0 -64
- package/src/shaders/clipping_mask.fragment.glsl +0 -3
- package/src/shaders/clipping_mask.vertex.glsl +0 -7
- package/src/shaders/collision_box.fragment.glsl +0 -21
- package/src/shaders/collision_box.vertex.glsl +0 -27
- package/src/shaders/collision_circle.fragment.glsl +0 -34
- package/src/shaders/collision_circle.vertex.glsl +0 -36
- package/src/shaders/debug.fragment.glsl +0 -9
- package/src/shaders/debug.vertex.glsl +0 -12
- package/src/shaders/encode_attribute.js +0 -17
- package/src/shaders/fill.fragment.glsl +0 -13
- package/src/shaders/fill.vertex.glsl +0 -13
- package/src/shaders/fill_extrusion.fragment.glsl +0 -9
- package/src/shaders/fill_extrusion.vertex.glsl +0 -66
- package/src/shaders/fill_extrusion_pattern.fragment.glsl +0 -45
- package/src/shaders/fill_extrusion_pattern.vertex.glsl +0 -79
- package/src/shaders/fill_outline.fragment.glsl +0 -17
- package/src/shaders/fill_outline.vertex.glsl +0 -17
- package/src/shaders/fill_outline_pattern.fragment.glsl +0 -43
- package/src/shaders/fill_outline_pattern.vertex.glsl +0 -44
- package/src/shaders/fill_pattern.fragment.glsl +0 -36
- package/src/shaders/fill_pattern.vertex.glsl +0 -39
- package/src/shaders/heatmap.fragment.glsl +0 -22
- package/src/shaders/heatmap.vertex.glsl +0 -54
- package/src/shaders/heatmap_texture.fragment.glsl +0 -14
- package/src/shaders/heatmap_texture.vertex.glsl +0 -11
- package/src/shaders/hillshade.fragment.glsl +0 -52
- package/src/shaders/hillshade.vertex.glsl +0 -11
- package/src/shaders/hillshade_prepare.fragment.glsl +0 -74
- package/src/shaders/hillshade_prepare.vertex.glsl +0 -15
- package/src/shaders/index.js +0 -20
- package/src/shaders/line.fragment.glsl +0 -30
- package/src/shaders/line.vertex.glsl +0 -85
- package/src/shaders/line_gradient.fragment.glsl +0 -34
- package/src/shaders/line_gradient.vertex.glsl +0 -87
- package/src/shaders/line_pattern.fragment.glsl +0 -74
- package/src/shaders/line_pattern.vertex.glsl +0 -99
- package/src/shaders/line_sdf.fragment.glsl +0 -45
- package/src/shaders/line_sdf.vertex.glsl +0 -98
- package/src/shaders/raster.fragment.glsl +0 -52
- package/src/shaders/raster.vertex.glsl +0 -21
- package/src/shaders/shaders.js +0 -180
- package/src/shaders/symbol_icon.fragment.glsl +0 -17
- package/src/shaders/symbol_icon.vertex.glsl +0 -94
- package/src/shaders/symbol_sdf.fragment.glsl +0 -52
- package/src/shaders/symbol_sdf.vertex.glsl +0 -115
- package/src/shaders/symbol_text_and_icon.fragment.glsl +0 -68
- package/src/shaders/symbol_text_and_icon.vertex.glsl +0 -116
- package/src/source/canvas_source.js +0 -238
- package/src/source/geojson_helper.js +0 -92
- package/src/source/geojson_source.js +0 -374
- package/src/source/geojson_worker_source.js +0 -357
- package/src/source/geojson_wrapper.js +0 -94
- package/src/source/image_source.js +0 -307
- package/src/source/load_tilejson.js +0 -39
- package/src/source/mbtiles_source.js +0 -115
- package/src/source/offline_database.js +0 -61
- package/src/source/offline_database_root.js +0 -62
- package/src/source/pixels_to_tile_units.js +0 -21
- package/src/source/query_features.js +0 -208
- package/src/source/raster_dem_tile_source.js +0 -138
- package/src/source/raster_dem_tile_worker_source.js +0 -62
- package/src/source/raster_tile_offline_source.js +0 -136
- package/src/source/raster_tile_source.js +0 -177
- package/src/source/rtl_text_plugin.js +0 -138
- package/src/source/source.js +0 -137
- package/src/source/source_cache.js +0 -957
- package/src/source/source_state.js +0 -159
- package/src/source/tile.js +0 -465
- package/src/source/tile_bounds.js +0 -38
- package/src/source/tile_cache.js +0 -212
- package/src/source/tile_id.js +0 -402
- package/src/source/vector_tile_source.js +0 -192
- package/src/source/vector_tile_worker_source.js +0 -216
- package/src/source/video_source.js +0 -203
- package/src/source/worker.js +0 -237
- package/src/source/worker_source.js +0 -106
- package/src/source/worker_tile.js +0 -224
- package/src/style/create_style_layer.js +0 -36
- package/src/style/evaluation_parameters.js +0 -62
- package/src/style/light.js +0 -130
- package/src/style/load_glyph_range.js +0 -38
- package/src/style/load_sprite.js +0 -67
- package/src/style/parse_glyph_pbf.js +0 -44
- package/src/style/pauseable_placement.js +0 -132
- package/src/style/properties.js +0 -753
- package/src/style/query_utils.js +0 -43
- package/src/style/style.js +0 -1361
- package/src/style/style_glyph.js +0 -17
- package/src/style/style_image.js +0 -137
- package/src/style/style_layer/background_style_layer.js +0 -21
- package/src/style/style_layer/background_style_layer_properties.js +0 -40
- package/src/style/style_layer/circle_style_layer.js +0 -98
- package/src/style/style_layer/circle_style_layer_properties.js +0 -63
- package/src/style/style_layer/custom_style_layer.js +0 -223
- package/src/style/style_layer/fill_extrusion_style_layer.js +0 -224
- package/src/style/style_layer/fill_extrusion_style_layer_properties.js +0 -50
- package/src/style/style_layer/fill_style_layer.js +0 -67
- package/src/style/style_layer/fill_style_layer_properties.js +0 -55
- package/src/style/style_layer/heatmap_style_layer.js +0 -69
- package/src/style/style_layer/heatmap_style_layer_properties.js +0 -44
- package/src/style/style_layer/hillshade_style_layer.js +0 -25
- package/src/style/style_layer/hillshade_style_layer_properties.js +0 -46
- package/src/style/style_layer/layer_properties.js.ejs +0 -69
- package/src/style/style_layer/line_style_layer.js +0 -151
- package/src/style/style_layer/line_style_layer_properties.js +0 -71
- package/src/style/style_layer/raster_style_layer.js +0 -21
- package/src/style/style_layer/raster_style_layer_properties.js +0 -50
- package/src/style/style_layer/symbol_style_layer.js +0 -190
- package/src/style/style_layer/symbol_style_layer_properties.js +0 -153
- package/src/style/style_layer/typed_style_layer.js +0 -17
- package/src/style/style_layer.js +0 -281
- package/src/style/style_layer_index.js +0 -80
- package/src/style/validate_style.js +0 -42
- package/src/style/zoom_history.js +0 -44
- package/src/style-spec/.eslintrc +0 -5
- package/src/style-spec/CHANGELOG.md +0 -438
- package/src/style-spec/README.md +0 -59
- package/src/style-spec/bin/gl-style-composite +0 -9
- package/src/style-spec/bin/gl-style-format +0 -22
- package/src/style-spec/bin/gl-style-migrate +0 -9
- package/src/style-spec/bin/gl-style-validate +0 -50
- package/src/style-spec/composite.js +0 -50
- package/src/style-spec/declass.js +0 -42
- package/src/style-spec/deref.js +0 -52
- package/src/style-spec/diff.js +0 -393
- package/src/style-spec/dist/.gitkeep +0 -0
- package/src/style-spec/empty.js +0 -29
- package/src/style-spec/error/parsing_error.js +0 -16
- package/src/style-spec/error/validation_error.js +0 -18
- package/src/style-spec/expression/compound_expression.js +0 -162
- package/src/style-spec/expression/definitions/assertion.js +0 -130
- package/src/style-spec/expression/definitions/at.js +0 -70
- package/src/style-spec/expression/definitions/case.js +0 -85
- package/src/style-spec/expression/definitions/coalesce.js +0 -93
- package/src/style-spec/expression/definitions/coercion.js +0 -133
- package/src/style-spec/expression/definitions/collator.js +0 -78
- package/src/style-spec/expression/definitions/comparison.js +0 -184
- package/src/style-spec/expression/definitions/format.js +0 -144
- package/src/style-spec/expression/definitions/format_section_override.js +0 -54
- package/src/style-spec/expression/definitions/image.js +0 -52
- package/src/style-spec/expression/definitions/in.js +0 -92
- package/src/style-spec/expression/definitions/index.js +0 -561
- package/src/style-spec/expression/definitions/interpolate.js +0 -267
- package/src/style-spec/expression/definitions/length.js +0 -61
- package/src/style-spec/expression/definitions/let.js +0 -72
- package/src/style-spec/expression/definitions/literal.js +0 -77
- package/src/style-spec/expression/definitions/match.js +0 -158
- package/src/style-spec/expression/definitions/number_format.js +0 -142
- package/src/style-spec/expression/definitions/step.js +0 -120
- package/src/style-spec/expression/definitions/var.js +0 -46
- package/src/style-spec/expression/definitions/within.js +0 -333
- package/src/style-spec/expression/evaluation_context.js +0 -59
- package/src/style-spec/expression/expression.js +0 -27
- package/src/style-spec/expression/index.js +0 -392
- package/src/style-spec/expression/is_constant.js +0 -59
- package/src/style-spec/expression/parsing_context.js +0 -233
- package/src/style-spec/expression/parsing_error.js +0 -13
- package/src/style-spec/expression/runtime_error.js +0 -17
- package/src/style-spec/expression/scope.js +0 -36
- package/src/style-spec/expression/stops.js +0 -39
- package/src/style-spec/expression/types/collator.js +0 -61
- package/src/style-spec/expression/types/formatted.js +0 -73
- package/src/style-spec/expression/types/resolved_image.js +0 -29
- package/src/style-spec/expression/types.js +0 -106
- package/src/style-spec/expression/values.js +0 -123
- package/src/style-spec/feature_filter/README.md +0 -55
- package/src/style-spec/feature_filter/convert.js +0 -208
- package/src/style-spec/feature_filter/index.js +0 -165
- package/src/style-spec/format.js +0 -51
- package/src/style-spec/function/convert.js +0 -254
- package/src/style-spec/function/index.js +0 -262
- package/src/style-spec/group_by_layout.js +0 -75
- package/src/style-spec/migrate/expressions.js +0 -39
- package/src/style-spec/migrate/v8.js +0 -203
- package/src/style-spec/migrate/v9.js +0 -26
- package/src/style-spec/migrate.js +0 -36
- package/src/style-spec/package.json +0 -41
- package/src/style-spec/read_style.js +0 -14
- package/src/style-spec/reference/latest.js +0 -3
- package/src/style-spec/reference/v8.json +0 -5808
- package/src/style-spec/rollup.config.js +0 -45
- package/src/style-spec/style-spec.js +0 -122
- package/src/style-spec/types.js +0 -438
- package/src/style-spec/util/color.js +0 -95
- package/src/style-spec/util/color_spaces.js +0 -139
- package/src/style-spec/util/deep_equal.js +0 -28
- package/src/style-spec/util/extend.js +0 -10
- package/src/style-spec/util/get_type.js +0 -17
- package/src/style-spec/util/interpolate.js +0 -22
- package/src/style-spec/util/properties.js +0 -15
- package/src/style-spec/util/ref_properties.js +0 -2
- package/src/style-spec/util/result.js +0 -19
- package/src/style-spec/util/unbundle_jsonlint.js +0 -24
- package/src/style-spec/validate/latest.js +0 -11
- package/src/style-spec/validate/validate.js +0 -75
- package/src/style-spec/validate/validate_array.js +0 -52
- package/src/style-spec/validate/validate_boolean.js +0 -15
- package/src/style-spec/validate/validate_color.js +0 -20
- package/src/style-spec/validate/validate_constants.js +0 -13
- package/src/style-spec/validate/validate_enum.js +0 -21
- package/src/style-spec/validate/validate_expression.js +0 -43
- package/src/style-spec/validate/validate_filter.js +0 -111
- package/src/style-spec/validate/validate_formatted.js +0 -11
- package/src/style-spec/validate/validate_function.js +0 -207
- package/src/style-spec/validate/validate_glyphs_url.js +0 -21
- package/src/style-spec/validate/validate_image.js +0 -11
- package/src/style-spec/validate/validate_layer.js +0 -134
- package/src/style-spec/validate/validate_layout_property.js +0 -6
- package/src/style-spec/validate/validate_light.js +0 -47
- package/src/style-spec/validate/validate_number.js +0 -29
- package/src/style-spec/validate/validate_object.js +0 -61
- package/src/style-spec/validate/validate_paint_property.js +0 -6
- package/src/style-spec/validate/validate_property.js +0 -64
- package/src/style-spec/validate/validate_source.js +0 -111
- package/src/style-spec/validate/validate_string.js +0 -15
- package/src/style-spec/validate_mapbox_api_supported.js +0 -171
- package/src/style-spec/validate_style.js +0 -39
- package/src/style-spec/validate_style.min.js +0 -78
- package/src/style-spec/visit.js +0 -77
- package/src/symbol/anchor.js +0 -26
- package/src/symbol/check_max_angle.js +0 -81
- package/src/symbol/clip_line.js +0 -71
- package/src/symbol/collision_feature.js +0 -217
- package/src/symbol/collision_index.js +0 -372
- package/src/symbol/cross_tile_symbol_index.js +0 -301
- package/src/symbol/get_anchors.js +0 -167
- package/src/symbol/grid_index.js +0 -335
- package/src/symbol/mergelines.js +0 -82
- package/src/symbol/one_em.js +0 -4
- package/src/symbol/opacity_state.js +0 -27
- package/src/symbol/placement.js +0 -1062
- package/src/symbol/projection.js +0 -450
- package/src/symbol/quads.js +0 -334
- package/src/symbol/shaping.js +0 -816
- package/src/symbol/symbol_layout.js +0 -772
- package/src/symbol/symbol_size.js +0 -113
- package/src/symbol/transform_text.js +0 -29
- package/src/types/callback.js +0 -17
- package/src/types/cancelable.js +0 -3
- package/src/types/tilejson.js +0 -17
- package/src/types/transferable.js +0 -3
- package/src/types/window.js +0 -172
- package/src/ui/anchor.js +0 -32
- package/src/ui/bind_handlers.js +0 -202
- package/src/ui/camera.js +0 -1152
- package/src/ui/control/attribution_control.js +0 -189
- package/src/ui/control/fps_control.js +0 -185
- package/src/ui/control/fullscreen_control.js +0 -147
- package/src/ui/control/geolocate_control.js +0 -594
- package/src/ui/control/logo_control.js +0 -92
- package/src/ui/control/navigation_control.js +0 -148
- package/src/ui/control/scale_control.js +0 -142
- package/src/ui/crs.js +0 -64
- package/src/ui/default_locale.js +0 -20
- package/src/ui/events.js +0 -806
- package/src/ui/handler/box_zoom.js +0 -175
- package/src/ui/handler/dblclick_zoom.js +0 -139
- package/src/ui/handler/drag_pan.js +0 -416
- package/src/ui/handler/drag_rotate.js +0 -378
- package/src/ui/handler/keyboard.js +0 -161
- package/src/ui/handler/scroll_zoom.js +0 -333
- package/src/ui/handler/touch_zoom_rotate.js +0 -293
- package/src/ui/hash.js +0 -147
- package/src/ui/map.js +0 -2883
- package/src/ui/marker.js +0 -607
- package/src/ui/offline_map.js +0 -91
- package/src/ui/popup.js +0 -530
- package/src/util/actor.js +0 -212
- package/src/util/ajax.js +0 -371
- package/src/util/browser/web_worker.js +0 -10
- package/src/util/browser/window.js +0 -5
- package/src/util/browser.js +0 -70
- package/src/util/classify_rings.js +0 -52
- package/src/util/color_ramp.js +0 -28
- package/src/util/config.js +0 -30
- package/src/util/debug.js +0 -12
- package/src/util/dictionary_coder.js +0 -30
- package/src/util/dispatcher.js +0 -70
- package/src/util/dom.js +0 -144
- package/src/util/evented.js +0 -174
- package/src/util/find_pole_of_inaccessibility.js +0 -129
- package/src/util/global_worker_pool.js +0 -17
- package/src/util/image.js +0 -142
- package/src/util/intersection_tests.js +0 -208
- package/src/util/is_char_in_unicode_block.js +0 -311
- package/src/util/mapbox.js +0 -486
- package/src/util/offscreen_canvas_supported.js +0 -14
- package/src/util/performance.js +0 -112
- package/src/util/primitives.js +0 -145
- package/src/util/resolve_tokens.js +0 -16
- package/src/util/script_detection.js +0 -328
- package/src/util/sku_token.js +0 -42
- package/src/util/smart_wrap.js +0 -55
- package/src/util/struct_array.js +0 -243
- package/src/util/struct_array.js.ejs +0 -112
- package/src/util/struct_array_layout.js.ejs +0 -98
- package/src/util/task_queue.js +0 -68
- package/src/util/throttle.js +0 -28
- package/src/util/throttled_invoker.js +0 -46
- package/src/util/tile_cover.js +0 -101
- package/src/util/tile_request_cache.js +0 -172
- package/src/util/util.js +0 -504
- package/src/util/vectortile_to_geojson.js +0 -54
- package/src/util/verticalize_punctuation.js +0 -114
- package/src/util/web_worker.js +0 -91
- package/src/util/web_worker_transfer.js +0 -266
- package/src/util/webp_supported.js +0 -69
- package/src/util/window.js +0 -102
- package/src/util/worker_pool.js +0 -47
|
@@ -1,162 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {toString} from './types';
|
|
4
|
-
|
|
5
|
-
import ParsingContext from './parsing_context';
|
|
6
|
-
import EvaluationContext from './evaluation_context';
|
|
7
|
-
import assert from 'assert';
|
|
8
|
-
|
|
9
|
-
import type {Expression, ExpressionRegistry} from './expression';
|
|
10
|
-
import type {Type} from './types';
|
|
11
|
-
import type {Value} from './values';
|
|
12
|
-
|
|
13
|
-
export type Varargs = {| type: Type |};
|
|
14
|
-
type Signature = Array<Type> | Varargs;
|
|
15
|
-
type Evaluate = (EvaluationContext, Array<Expression>) => Value;
|
|
16
|
-
type Definition = [Type, Signature, Evaluate] |
|
|
17
|
-
{|type: Type, overloads: Array<[Signature, Evaluate]>|};
|
|
18
|
-
|
|
19
|
-
class CompoundExpression implements Expression {
|
|
20
|
-
name: string;
|
|
21
|
-
type: Type;
|
|
22
|
-
_evaluate: Evaluate;
|
|
23
|
-
args: Array<Expression>;
|
|
24
|
-
|
|
25
|
-
static definitions: {[_: string]: Definition };
|
|
26
|
-
|
|
27
|
-
constructor(name: string, type: Type, evaluate: Evaluate, args: Array<Expression>) {
|
|
28
|
-
this.name = name;
|
|
29
|
-
this.type = type;
|
|
30
|
-
this._evaluate = evaluate;
|
|
31
|
-
this.args = args;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
evaluate(ctx: EvaluationContext) {
|
|
35
|
-
return this._evaluate(ctx, this.args);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
eachChild(fn: (_: Expression) => void) {
|
|
39
|
-
this.args.forEach(fn);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
outputDefined() {
|
|
43
|
-
return false;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
serialize(): Array<mixed> {
|
|
47
|
-
return [this.name].concat(this.args.map(arg => arg.serialize()));
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext): ?Expression {
|
|
51
|
-
const op: string = (args[0]: any);
|
|
52
|
-
const definition = CompoundExpression.definitions[op];
|
|
53
|
-
if (!definition) {
|
|
54
|
-
return context.error(`Unknown expression "${op}". If you wanted a literal array, use ["literal", [...]].`, 0);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// Now check argument types against each signature
|
|
58
|
-
const type = Array.isArray(definition) ?
|
|
59
|
-
definition[0] : definition.type;
|
|
60
|
-
|
|
61
|
-
const availableOverloads = Array.isArray(definition) ?
|
|
62
|
-
[[definition[1], definition[2]]] :
|
|
63
|
-
definition.overloads;
|
|
64
|
-
|
|
65
|
-
const overloads = availableOverloads.filter(([signature]) => (
|
|
66
|
-
!Array.isArray(signature) || // varags
|
|
67
|
-
signature.length === args.length - 1 // correct param count
|
|
68
|
-
));
|
|
69
|
-
|
|
70
|
-
let signatureContext: ParsingContext = (null: any);
|
|
71
|
-
|
|
72
|
-
for (const [params, evaluate] of overloads) {
|
|
73
|
-
// Use a fresh context for each attempted signature so that, if
|
|
74
|
-
// we eventually succeed, we haven't polluted `context.errors`.
|
|
75
|
-
signatureContext = new ParsingContext(context.registry, context.path, null, context.scope);
|
|
76
|
-
|
|
77
|
-
// First parse all the args, potentially coercing to the
|
|
78
|
-
// types expected by this overload.
|
|
79
|
-
const parsedArgs: Array<Expression> = [];
|
|
80
|
-
let argParseFailed = false;
|
|
81
|
-
for (let i = 1; i < args.length; i++) {
|
|
82
|
-
const arg = args[i];
|
|
83
|
-
const expectedType = Array.isArray(params) ?
|
|
84
|
-
params[i - 1] :
|
|
85
|
-
params.type;
|
|
86
|
-
|
|
87
|
-
const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);
|
|
88
|
-
if (!parsed) {
|
|
89
|
-
argParseFailed = true;
|
|
90
|
-
break;
|
|
91
|
-
}
|
|
92
|
-
parsedArgs.push(parsed);
|
|
93
|
-
}
|
|
94
|
-
if (argParseFailed) {
|
|
95
|
-
// Couldn't coerce args of this overload to expected type, move
|
|
96
|
-
// on to next one.
|
|
97
|
-
continue;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
if (Array.isArray(params)) {
|
|
101
|
-
if (params.length !== parsedArgs.length) {
|
|
102
|
-
signatureContext.error(`Expected ${params.length} arguments, but found ${parsedArgs.length} instead.`);
|
|
103
|
-
continue;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
for (let i = 0; i < parsedArgs.length; i++) {
|
|
108
|
-
const expected = Array.isArray(params) ? params[i] : params.type;
|
|
109
|
-
const arg = parsedArgs[i];
|
|
110
|
-
signatureContext.concat(i + 1).checkSubtype(expected, arg.type);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
if (signatureContext.errors.length === 0) {
|
|
114
|
-
return new CompoundExpression(op, type, evaluate, parsedArgs);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
assert(!signatureContext || signatureContext.errors.length > 0);
|
|
119
|
-
|
|
120
|
-
if (overloads.length === 1) {
|
|
121
|
-
context.errors.push(...signatureContext.errors);
|
|
122
|
-
} else {
|
|
123
|
-
const expected = overloads.length ? overloads : availableOverloads;
|
|
124
|
-
const signatures = expected
|
|
125
|
-
.map(([params]) => stringifySignature(params))
|
|
126
|
-
.join(' | ');
|
|
127
|
-
|
|
128
|
-
const actualTypes = [];
|
|
129
|
-
// For error message, re-parse arguments without trying to
|
|
130
|
-
// apply any coercions
|
|
131
|
-
for (let i = 1; i < args.length; i++) {
|
|
132
|
-
const parsed = context.parse(args[i], 1 + actualTypes.length);
|
|
133
|
-
if (!parsed) return null;
|
|
134
|
-
actualTypes.push(toString(parsed.type));
|
|
135
|
-
}
|
|
136
|
-
context.error(`Expected arguments of type ${signatures}, but found (${actualTypes.join(', ')}) instead.`);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
return null;
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
static register(
|
|
143
|
-
registry: ExpressionRegistry,
|
|
144
|
-
definitions: {[_: string]: Definition }
|
|
145
|
-
) {
|
|
146
|
-
assert(!CompoundExpression.definitions);
|
|
147
|
-
CompoundExpression.definitions = definitions;
|
|
148
|
-
for (const name in definitions) {
|
|
149
|
-
registry[name] = CompoundExpression;
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
function stringifySignature(signature: Signature): string {
|
|
155
|
-
if (Array.isArray(signature)) {
|
|
156
|
-
return `(${signature.map(toString).join(', ')})`;
|
|
157
|
-
} else {
|
|
158
|
-
return `(${toString(signature.type)}...)`;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export default CompoundExpression;
|
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import assert from 'assert';
|
|
4
|
-
|
|
5
|
-
import {
|
|
6
|
-
ObjectType,
|
|
7
|
-
ValueType,
|
|
8
|
-
StringType,
|
|
9
|
-
NumberType,
|
|
10
|
-
BooleanType,
|
|
11
|
-
checkSubtype,
|
|
12
|
-
toString,
|
|
13
|
-
array
|
|
14
|
-
} from '../types';
|
|
15
|
-
import RuntimeError from '../runtime_error';
|
|
16
|
-
import {typeOf} from '../values';
|
|
17
|
-
|
|
18
|
-
import type {Expression} from '../expression';
|
|
19
|
-
import type ParsingContext from '../parsing_context';
|
|
20
|
-
import type EvaluationContext from '../evaluation_context';
|
|
21
|
-
import type {Type} from '../types';
|
|
22
|
-
|
|
23
|
-
const types = {
|
|
24
|
-
string: StringType,
|
|
25
|
-
number: NumberType,
|
|
26
|
-
boolean: BooleanType,
|
|
27
|
-
object: ObjectType
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
class Assertion implements Expression {
|
|
31
|
-
type: Type;
|
|
32
|
-
args: Array<Expression>;
|
|
33
|
-
|
|
34
|
-
constructor(type: Type, args: Array<Expression>) {
|
|
35
|
-
this.type = type;
|
|
36
|
-
this.args = args;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext): ?Expression {
|
|
40
|
-
if (args.length < 2)
|
|
41
|
-
return context.error(`Expected at least one argument.`);
|
|
42
|
-
|
|
43
|
-
let i = 1;
|
|
44
|
-
let type;
|
|
45
|
-
|
|
46
|
-
const name: string = (args[0]: any);
|
|
47
|
-
if (name === 'array') {
|
|
48
|
-
let itemType;
|
|
49
|
-
if (args.length > 2) {
|
|
50
|
-
const type = args[1];
|
|
51
|
-
if (typeof type !== 'string' || !(type in types) || type === 'object')
|
|
52
|
-
return context.error('The item type argument of "array" must be one of string, number, boolean', 1);
|
|
53
|
-
itemType = types[type];
|
|
54
|
-
i++;
|
|
55
|
-
} else {
|
|
56
|
-
itemType = ValueType;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
let N;
|
|
60
|
-
if (args.length > 3) {
|
|
61
|
-
if (args[2] !== null &&
|
|
62
|
-
(typeof args[2] !== 'number' ||
|
|
63
|
-
args[2] < 0 ||
|
|
64
|
-
args[2] !== Math.floor(args[2]))
|
|
65
|
-
) {
|
|
66
|
-
return context.error('The length argument to "array" must be a positive integer literal', 2);
|
|
67
|
-
}
|
|
68
|
-
N = args[2];
|
|
69
|
-
i++;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
type = array(itemType, N);
|
|
73
|
-
} else {
|
|
74
|
-
assert(types[name], name);
|
|
75
|
-
type = types[name];
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
const parsed = [];
|
|
79
|
-
for (; i < args.length; i++) {
|
|
80
|
-
const input = context.parse(args[i], i, ValueType);
|
|
81
|
-
if (!input) return null;
|
|
82
|
-
parsed.push(input);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
return new Assertion(type, parsed);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
evaluate(ctx: EvaluationContext) {
|
|
89
|
-
for (let i = 0; i < this.args.length; i++) {
|
|
90
|
-
const value = this.args[i].evaluate(ctx);
|
|
91
|
-
const error = checkSubtype(this.type, typeOf(value));
|
|
92
|
-
if (!error) {
|
|
93
|
-
return value;
|
|
94
|
-
} else if (i === this.args.length - 1) {
|
|
95
|
-
throw new RuntimeError(`Expected value to be of type ${toString(this.type)}, but found ${toString(typeOf(value))} instead.`);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
assert(false);
|
|
100
|
-
return null;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
eachChild(fn: (_: Expression) => void) {
|
|
104
|
-
this.args.forEach(fn);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
outputDefined(): boolean {
|
|
108
|
-
return this.args.every(arg => arg.outputDefined());
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
serialize(): Array<mixed> {
|
|
112
|
-
const type = this.type;
|
|
113
|
-
const serialized = [type.kind];
|
|
114
|
-
if (type.kind === 'array') {
|
|
115
|
-
const itemType = type.itemType;
|
|
116
|
-
if (itemType.kind === 'string' ||
|
|
117
|
-
itemType.kind === 'number' ||
|
|
118
|
-
itemType.kind === 'boolean') {
|
|
119
|
-
serialized.push(itemType.kind);
|
|
120
|
-
const N = type.N;
|
|
121
|
-
if (typeof N === 'number' || this.args.length > 1) {
|
|
122
|
-
serialized.push(N);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
return serialized.concat(this.args.map(arg => arg.serialize()));
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
export default Assertion;
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {array, ValueType, NumberType} from '../types';
|
|
4
|
-
|
|
5
|
-
import RuntimeError from '../runtime_error';
|
|
6
|
-
|
|
7
|
-
import type {Expression} from '../expression';
|
|
8
|
-
import type ParsingContext from '../parsing_context';
|
|
9
|
-
import type EvaluationContext from '../evaluation_context';
|
|
10
|
-
import type {Type, ArrayType} from '../types';
|
|
11
|
-
import type {Value} from '../values';
|
|
12
|
-
|
|
13
|
-
class At implements Expression {
|
|
14
|
-
type: Type;
|
|
15
|
-
index: Expression;
|
|
16
|
-
input: Expression;
|
|
17
|
-
|
|
18
|
-
constructor(type: Type, index: Expression, input: Expression) {
|
|
19
|
-
this.type = type;
|
|
20
|
-
this.index = index;
|
|
21
|
-
this.input = input;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext) {
|
|
25
|
-
if (args.length !== 3)
|
|
26
|
-
return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);
|
|
27
|
-
|
|
28
|
-
const index = context.parse(args[1], 1, NumberType);
|
|
29
|
-
const input = context.parse(args[2], 2, array(context.expectedType || ValueType));
|
|
30
|
-
|
|
31
|
-
if (!index || !input) return null;
|
|
32
|
-
|
|
33
|
-
const t: ArrayType = (input.type: any);
|
|
34
|
-
return new At(t.itemType, index, input);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
evaluate(ctx: EvaluationContext) {
|
|
38
|
-
const index = ((this.index.evaluate(ctx): any): number);
|
|
39
|
-
const array = ((this.input.evaluate(ctx): any): Array<Value>);
|
|
40
|
-
|
|
41
|
-
if (index < 0) {
|
|
42
|
-
throw new RuntimeError(`Array index out of bounds: ${index} < 0.`);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (index >= array.length) {
|
|
46
|
-
throw new RuntimeError(`Array index out of bounds: ${index} > ${array.length - 1}.`);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
if (index !== Math.floor(index)) {
|
|
50
|
-
throw new RuntimeError(`Array index must be an integer, but found ${index} instead.`);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
return array[index];
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
eachChild(fn: (_: Expression) => void) {
|
|
57
|
-
fn(this.index);
|
|
58
|
-
fn(this.input);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
outputDefined() {
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
serialize() {
|
|
66
|
-
return ["at", this.index.serialize(), this.input.serialize()];
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export default At;
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import assert from 'assert';
|
|
4
|
-
|
|
5
|
-
import {BooleanType} from '../types';
|
|
6
|
-
|
|
7
|
-
import type {Expression} from '../expression';
|
|
8
|
-
import type ParsingContext from '../parsing_context';
|
|
9
|
-
import type EvaluationContext from '../evaluation_context';
|
|
10
|
-
import type {Type} from '../types';
|
|
11
|
-
|
|
12
|
-
type Branches = Array<[Expression, Expression]>;
|
|
13
|
-
|
|
14
|
-
class Case implements Expression {
|
|
15
|
-
type: Type;
|
|
16
|
-
|
|
17
|
-
branches: Branches;
|
|
18
|
-
otherwise: Expression;
|
|
19
|
-
|
|
20
|
-
constructor(type: Type, branches: Branches, otherwise: Expression) {
|
|
21
|
-
this.type = type;
|
|
22
|
-
this.branches = branches;
|
|
23
|
-
this.otherwise = otherwise;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext) {
|
|
27
|
-
if (args.length < 4)
|
|
28
|
-
return context.error(`Expected at least 3 arguments, but found only ${args.length - 1}.`);
|
|
29
|
-
if (args.length % 2 !== 0)
|
|
30
|
-
return context.error(`Expected an odd number of arguments.`);
|
|
31
|
-
|
|
32
|
-
let outputType: ?Type;
|
|
33
|
-
if (context.expectedType && context.expectedType.kind !== 'value') {
|
|
34
|
-
outputType = context.expectedType;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
const branches = [];
|
|
38
|
-
for (let i = 1; i < args.length - 1; i += 2) {
|
|
39
|
-
const test = context.parse(args[i], i, BooleanType);
|
|
40
|
-
if (!test) return null;
|
|
41
|
-
|
|
42
|
-
const result = context.parse(args[i + 1], i + 1, outputType);
|
|
43
|
-
if (!result) return null;
|
|
44
|
-
|
|
45
|
-
branches.push([test, result]);
|
|
46
|
-
|
|
47
|
-
outputType = outputType || result.type;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);
|
|
51
|
-
if (!otherwise) return null;
|
|
52
|
-
|
|
53
|
-
assert(outputType);
|
|
54
|
-
return new Case((outputType: any), branches, otherwise);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
evaluate(ctx: EvaluationContext) {
|
|
58
|
-
for (const [test, expression] of this.branches) {
|
|
59
|
-
if (test.evaluate(ctx)) {
|
|
60
|
-
return expression.evaluate(ctx);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return this.otherwise.evaluate(ctx);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
eachChild(fn: (_: Expression) => void) {
|
|
67
|
-
for (const [test, expression] of this.branches) {
|
|
68
|
-
fn(test);
|
|
69
|
-
fn(expression);
|
|
70
|
-
}
|
|
71
|
-
fn(this.otherwise);
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
outputDefined(): boolean {
|
|
75
|
-
return this.branches.every(([_, out]) => out.outputDefined()) && this.otherwise.outputDefined();
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
serialize() {
|
|
79
|
-
const serialized = ["case"];
|
|
80
|
-
this.eachChild(child => { serialized.push(child.serialize()); });
|
|
81
|
-
return serialized;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export default Case;
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import assert from 'assert';
|
|
4
|
-
|
|
5
|
-
import {checkSubtype, ValueType} from '../types';
|
|
6
|
-
import ResolvedImage from '../types/resolved_image';
|
|
7
|
-
|
|
8
|
-
import type {Expression} from '../expression';
|
|
9
|
-
import type ParsingContext from '../parsing_context';
|
|
10
|
-
import type EvaluationContext from '../evaluation_context';
|
|
11
|
-
import type {Type} from '../types';
|
|
12
|
-
|
|
13
|
-
class Coalesce implements Expression {
|
|
14
|
-
type: Type;
|
|
15
|
-
args: Array<Expression>;
|
|
16
|
-
|
|
17
|
-
constructor(type: Type, args: Array<Expression>) {
|
|
18
|
-
this.type = type;
|
|
19
|
-
this.args = args;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext) {
|
|
23
|
-
if (args.length < 2) {
|
|
24
|
-
return context.error("Expectected at least one argument.");
|
|
25
|
-
}
|
|
26
|
-
let outputType: Type = (null: any);
|
|
27
|
-
const expectedType = context.expectedType;
|
|
28
|
-
if (expectedType && expectedType.kind !== 'value') {
|
|
29
|
-
outputType = expectedType;
|
|
30
|
-
}
|
|
31
|
-
const parsedArgs = [];
|
|
32
|
-
|
|
33
|
-
for (const arg of args.slice(1)) {
|
|
34
|
-
const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, {typeAnnotation: 'omit'});
|
|
35
|
-
if (!parsed) return null;
|
|
36
|
-
outputType = outputType || parsed.type;
|
|
37
|
-
parsedArgs.push(parsed);
|
|
38
|
-
}
|
|
39
|
-
assert(outputType);
|
|
40
|
-
|
|
41
|
-
// Above, we parse arguments without inferred type annotation so that
|
|
42
|
-
// they don't produce a runtime error for `null` input, which would
|
|
43
|
-
// preempt the desired null-coalescing behavior.
|
|
44
|
-
// Thus, if any of our arguments would have needed an annotation, we
|
|
45
|
-
// need to wrap the enclosing coalesce expression with it instead.
|
|
46
|
-
const needsAnnotation = expectedType &&
|
|
47
|
-
parsedArgs.some(arg => checkSubtype(expectedType, arg.type));
|
|
48
|
-
|
|
49
|
-
return needsAnnotation ?
|
|
50
|
-
new Coalesce(ValueType, parsedArgs) :
|
|
51
|
-
new Coalesce((outputType: any), parsedArgs);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
evaluate(ctx: EvaluationContext) {
|
|
55
|
-
let result = null;
|
|
56
|
-
let argCount = 0;
|
|
57
|
-
let requestedImageName;
|
|
58
|
-
for (const arg of this.args) {
|
|
59
|
-
argCount++;
|
|
60
|
-
result = arg.evaluate(ctx);
|
|
61
|
-
// we need to keep track of the first requested image in a coalesce statement
|
|
62
|
-
// if coalesce can't find a valid image, we return the first image name so styleimagemissing can fire
|
|
63
|
-
if (result && result instanceof ResolvedImage && !result.available) {
|
|
64
|
-
if (!requestedImageName) {
|
|
65
|
-
requestedImageName = result.name;
|
|
66
|
-
}
|
|
67
|
-
result = null;
|
|
68
|
-
if (argCount === this.args.length) {
|
|
69
|
-
result = requestedImageName;
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
if (result !== null) break;
|
|
74
|
-
}
|
|
75
|
-
return result;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
eachChild(fn: (_: Expression) => void) {
|
|
79
|
-
this.args.forEach(fn);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
outputDefined(): boolean {
|
|
83
|
-
return this.args.every(arg => arg.outputDefined());
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
serialize() {
|
|
87
|
-
const serialized = ["coalesce"];
|
|
88
|
-
this.eachChild(child => { serialized.push(child.serialize()); });
|
|
89
|
-
return serialized;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
export default Coalesce;
|
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import assert from 'assert';
|
|
4
|
-
|
|
5
|
-
import {BooleanType, ColorType, NumberType, StringType, ValueType} from '../types';
|
|
6
|
-
import {Color, toString as valueToString, validateRGBA} from '../values';
|
|
7
|
-
import RuntimeError from '../runtime_error';
|
|
8
|
-
import Formatted from '../types/formatted';
|
|
9
|
-
import FormatExpression from '../definitions/format';
|
|
10
|
-
import ImageExpression from '../definitions/image';
|
|
11
|
-
import ResolvedImage from '../types/resolved_image';
|
|
12
|
-
|
|
13
|
-
import type {Expression} from '../expression';
|
|
14
|
-
import type ParsingContext from '../parsing_context';
|
|
15
|
-
import type EvaluationContext from '../evaluation_context';
|
|
16
|
-
import type {Type} from '../types';
|
|
17
|
-
|
|
18
|
-
const types = {
|
|
19
|
-
'to-boolean': BooleanType,
|
|
20
|
-
'to-color': ColorType,
|
|
21
|
-
'to-number': NumberType,
|
|
22
|
-
'to-string': StringType
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Special form for error-coalescing coercion expressions "to-number",
|
|
27
|
-
* "to-color". Since these coercions can fail at runtime, they accept multiple
|
|
28
|
-
* arguments, only evaluating one at a time until one succeeds.
|
|
29
|
-
*
|
|
30
|
-
* @private
|
|
31
|
-
*/
|
|
32
|
-
class Coercion implements Expression {
|
|
33
|
-
type: Type;
|
|
34
|
-
args: Array<Expression>;
|
|
35
|
-
|
|
36
|
-
constructor(type: Type, args: Array<Expression>) {
|
|
37
|
-
this.type = type;
|
|
38
|
-
this.args = args;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
static parse(args: $ReadOnlyArray<mixed>, context: ParsingContext): ?Expression {
|
|
42
|
-
if (args.length < 2)
|
|
43
|
-
return context.error(`Expected at least one argument.`);
|
|
44
|
-
|
|
45
|
-
const name: string = (args[0]: any);
|
|
46
|
-
assert(types[name], name);
|
|
47
|
-
|
|
48
|
-
if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2)
|
|
49
|
-
return context.error(`Expected one argument.`);
|
|
50
|
-
|
|
51
|
-
const type = types[name];
|
|
52
|
-
|
|
53
|
-
const parsed = [];
|
|
54
|
-
for (let i = 1; i < args.length; i++) {
|
|
55
|
-
const input = context.parse(args[i], i, ValueType);
|
|
56
|
-
if (!input) return null;
|
|
57
|
-
parsed.push(input);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
return new Coercion(type, parsed);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
evaluate(ctx: EvaluationContext) {
|
|
64
|
-
if (this.type.kind === 'boolean') {
|
|
65
|
-
return Boolean(this.args[0].evaluate(ctx));
|
|
66
|
-
} else if (this.type.kind === 'color') {
|
|
67
|
-
let input;
|
|
68
|
-
let error;
|
|
69
|
-
for (const arg of this.args) {
|
|
70
|
-
input = arg.evaluate(ctx);
|
|
71
|
-
error = null;
|
|
72
|
-
if (input instanceof Color) {
|
|
73
|
-
return input;
|
|
74
|
-
} else if (typeof input === 'string') {
|
|
75
|
-
const c = ctx.parseColor(input);
|
|
76
|
-
if (c) return c;
|
|
77
|
-
} else if (Array.isArray(input)) {
|
|
78
|
-
if (input.length < 3 || input.length > 4) {
|
|
79
|
-
error = `Invalid rbga value ${JSON.stringify(input)}: expected an array containing either three or four numeric values.`;
|
|
80
|
-
} else {
|
|
81
|
-
error = validateRGBA(input[0], input[1], input[2], input[3]);
|
|
82
|
-
}
|
|
83
|
-
if (!error) {
|
|
84
|
-
return new Color((input[0]: any) / 255, (input[1]: any) / 255, (input[2]: any) / 255, (input[3]: any));
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
throw new RuntimeError(error || `Could not parse color from value '${typeof input === 'string' ? input : String(JSON.stringify(input))}'`);
|
|
89
|
-
} else if (this.type.kind === 'number') {
|
|
90
|
-
let value = null;
|
|
91
|
-
for (const arg of this.args) {
|
|
92
|
-
value = arg.evaluate(ctx);
|
|
93
|
-
if (value === null) return 0;
|
|
94
|
-
const num = Number(value);
|
|
95
|
-
if (isNaN(num)) continue;
|
|
96
|
-
return num;
|
|
97
|
-
}
|
|
98
|
-
throw new RuntimeError(`Could not convert ${JSON.stringify(value)} to number.`);
|
|
99
|
-
} else if (this.type.kind === 'formatted') {
|
|
100
|
-
// There is no explicit 'to-formatted' but this coercion can be implicitly
|
|
101
|
-
// created by properties that expect the 'formatted' type.
|
|
102
|
-
return Formatted.fromString(valueToString(this.args[0].evaluate(ctx)));
|
|
103
|
-
} else if (this.type.kind === 'resolvedImage') {
|
|
104
|
-
return ResolvedImage.fromString(valueToString(this.args[0].evaluate(ctx)));
|
|
105
|
-
} else {
|
|
106
|
-
return valueToString(this.args[0].evaluate(ctx));
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
eachChild(fn: (_: Expression) => void) {
|
|
111
|
-
this.args.forEach(fn);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
outputDefined(): boolean {
|
|
115
|
-
return this.args.every(arg => arg.outputDefined());
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
serialize() {
|
|
119
|
-
if (this.type.kind === 'formatted') {
|
|
120
|
-
return new FormatExpression([{content: this.args[0], scale: null, font: null, textColor: null}]).serialize();
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
if (this.type.kind === 'resolvedImage') {
|
|
124
|
-
return new ImageExpression(this.args[0]).serialize();
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
const serialized = [`to-${this.type.kind}`];
|
|
128
|
-
this.eachChild(child => { serialized.push(child.serialize()); });
|
|
129
|
-
return serialized;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
export default Coercion;
|