Skip to content

Latest commit

 

History

History
928 lines (705 loc) · 40.9 KB

CHANGELOG.md

File metadata and controls

928 lines (705 loc) · 40.9 KB

v0.4.152

  • Rename json-subtree option json-path.

v0.4.151

  • Added -i json-subtree= option, for importing a nested array of JSON data records.
  • Added -dissolve group-points option, to convert groups of point/multipoint features to multipoint features, instead of converting groups to centroids.

v0.4.150

  • Fixed a bug affecting the calc=[expression] option when performing polygon-to-polygon spatial joins.

v0.4.149

  • Improve OGC Simple Features compliance of cleaned polygons.

v0.4.148

  • Added sliver-control=[0-1] option to -clean -dissolve2 and -filter-slivers commands, for variable sliver control.
  • Made sliver-control=1 the default value for these commands.
  • Tweaked the default area threshold for gap/sliver removal to use a larger threshold for more detailed datasets (detail is estimated using average segments per ring).
  • Changed name of min-gap-area option to gap-fill-area (original name also works).
  • Added tests of -clean command polygon output to verify OGC Simple Features compatibility.

v0.4.147

  • Improved robustness of path intersection (used by many commands, including -clean -dissolve2 -clip -erase -union).

v0.4.146

  • Added support for line and point type features to the -clean command.
  • Added (undocumented) -snap command, for snapping vertices post-import.

v0.4.145

  • Added -grid command for creating grids of square or hexagonal polygons. Assumes target layer is projected. Creates a grid layer that entirely contains the bounding box of the target layer.
  • Added polygon-to-polygon spatial joins to the -join command.
  • Added "interpolate=" option to the -join command, for reassigning attribute values of the listed fields using simple areal interpolation (assumes even distribution of data within polygon areas) (polygon-polygon spatial joins only).
  • Added "point-method" option to the -join command, for performing polygon-polygon spatial joins using an alternate method.
  • Added "-lines segments" option, to explode a polygon or polyline layer into individual segments.

v0.4.144

  • Change -union command syntax to use two or more target layers as input
  • Added -union fields= option for selecting which fields from the input layers to retain.

v0.4.143

  • Fix for web UI bug that caused command line options to be ignored.

v0.4.142

  • Added -union command for creating a mosaic from two polygon layers, preserving data from both layers.
  • Added -mosaic calc= option, which provides options for transferring data from source polygons to mosaic polygons.
  • Allow -merge-layers to combine a shape layer with a layer that has null geometry.

v0.4.141

  • Added "history" command to browser console, for displaying browser session as a command line shell command.
  • Added -mosaic as a documented command (flattens overlapping polygons by converting overlaps to separate features).

v0.4.140

  • Fix error in web UI.

v0.4.139

  • Send output of -version, -help and some other informational commands to stdout, not stderr.

v0.4.138

  • Added runCommandsXL() function to Mapshaper's Node API, for running commands with more memory.

v0.4.137

  • Further improvements to -data-fill and -fuzzy-join. Added 'contiguous' flag to ensure that only the most important one of multiple same-value areas is retained.

v0.4.136

  • Improvements to -data-fill and -fuzzy-join

v0.4.135

  • [shapefile] If a projection has no known WKT definition, generate a fallback .prj file with an embedded Proj.4 string (readable by QGIS and gdal but not ArcGIS).

v0.4.134

  • Fixed "npm run build" on Windows

v0.4.133

  • Performance improvements for CSV importing

v0.4.132

  • Added -i csv-lines=[integer] option, for importing the first n records from a CSV file
  • Added -i csv-skip-lines=[integer] option, for skipping lines at the top of a CSV file
  • Added -i csv-field-names=[list] option, for assigning field names to the columns of a CSV file.

v0.4.131

  • Added optional size parameter to mapshaper-xl (e.g. mapshaper-xl 16gb)
  • Improve performance of -i csv-fields= option.

v0.4.130

  • Input of GeoJSON and TopoJSON is more fault-tolerant.

v0.4.129

  • Work around layer menu issue caused by Chrome update.

v0.4.128

  • Fix Travis build.

v0.4.127

  • Updates to albersusa hybrid projection: new Alaska projection (lon_0 is at 148W) and support for customization. Customization examples: "albersusa +PR" "albersusa +AK.lon_0=-141 +AK.scale=0.4 +AK.dx=10000".
  • "-proj" command no longer throws an error if one or more coordinates fail to project. Instead, the points or arcs containing projection errors are removed.
  • Added an npm "prepare" script for users who are installing mapshaper from source code.
  • Added an "npm run build" script

v0.4.126

  • The -simplify command now ignores datasets containing no paths instead of stopping with an error. This is useful in scripts, when clipping creates an empty layer.

v0.4.125

  • API functions applyCommands() and runCommands() return a Promise if called without a callback argument.

v0.4.124

  • Added -lines groupby=[field] option, for converting points into multiple lines.
  • Added -clip bbox2=[bbox] option, which uses a higher-performance (but experimental) bounding box clip function.

v0.4.123

  • Now, -lines command converts a layer of points to a single polyline.

v0.4.122

  • Added -drop holes option, for removing holes from polygons.

v0.4.120

  • Fix for several GUI glitches

v0.4.119

  • Fix Travis build error

v0.4.118

  • Added string interpolation to source layer name in -clip/-erase, using template literal syntax (e.g. -clip source='${target}-clip')

v0.4.117

  • Added -o svg-data= option for exporting data fields as SVG data-* attributes.

v0.4.116

  • Bug fixes

v0.4.115

  • Improved -dissolve2 to handle polygons that overlap each other in complex ways.

v0.4.114

  • Fix: using -join with the "unjoined" and "unmatched" flags no longer adds debugging layers to the next command's default target layer(s).
  • Added layer names to tab completion in the web UI console.

v0.4.113

  • Fix for issue #339 (no .prj output after projecting to +proj=stere)

v0.4.112

  • Fix for issue #337 (error when clipping or erasing polygon rings inside holes)

v0.4.111

  • Added $.length accessor to -each expressions with polyline features

v0.4.110

  • Added +proj=patterson projection

v0.4.109

  • Updated format of -info command output, for better legibility.
  • Fixed layer duplication bug when running -clip/-erase with the "+" option.

v0.4.108

  • Now you can import all CSV fields as string data using '-i string-fields=*' option.
  • Now the -points command auto-detects commonly used names for x and y coordinates (e.g. longitude,latitude,lon,lng,lat,x,y) when converting tabular data to points. It is no longer necessary to add x= and y= parameters to the -points command.

v0.4.107

  • Preliminary work on new -symbols command.

v0.4.106

  • Automatic DMS parsing in -points x= y=.
  • Added a reference to the target record to -join where= expressions, named "target".

v0.4.105

  • [gui] Added separate interface modes for inspecting attributes, editing attributes, dragging labels to change offset from anchor, and dragging point symbols to change coordinates.
  • [cli] Improved error message when trying to read unsupported file types.

v0.4.104

  • Added "-uniq invert" option, for retaining non-unique records (useful e.g. for troubleshooting many-to-one joins).
  • Improved some error messages.

v0.4.103

  • Added "weighted" option to the "-filter-slivers" command. When used with the "min-area=" option, the "weighted" flag multiplies the area of each polygon ring by the "Polsby-Popper" compactness metric, so sliver-shaped rings have a lower effective area.
  • Added "this.perimeter" to the JS expression context. Perimeter values are in meters for unprojected data or in projected units (usually meters) for projected data.
  • Added "this.compactness" to the JS expression context. Compactness is the "Polsby-Popper" score of each polygon feature.
  • Added "-points vertices2" option, which is like "-points vertices", but retains every vertex of the original polygon or polyline instead of removing duplicate vertices within each feature.
  • Fix for issue #310.

v0.4.102

  • Close issues #308 and #309.

v0.4.101

  • Re-publish to npm

v0.4.100

  • Enable support for variable simplification amounts at the feature level using JS expressions. Adding the "variable" keyword to the -simplify command turns on variable simplification.

v0.4.99

  • Support reading CSV files larger than 2GB.
  • Added -i command option csv-filter=, for filtering CSV records on import using a JS expression.
  • Added -i command option csv-fields=, for importing a subset of fields from a CSV file.
  • Faster rendering of many unstyled point symbols (which are drawn as little squares).

v0.4.98

  • Fixed a performance regression.

v0.4.97

  • Updated mproj version to include bertin1953 projection.

v0.4.96

  • Fix for issue #304 (inaccurate centroids for some tiny polygons, caused by floating point rounding).

v0.4.95

  • Fixed some clipping and dissolving errors caused by floating point inaccuracy.

v0.4.94

  • Fix for problem importing GeoJSON with non-standard properties

v0.4.93

  • Improve CRS detection when merging datasets

v0.4.92

  • Added '-o pixels=' and '-frame pixels=' options for scaling SVG output based on the number of pixels in the output image.

v0.4.91

  • Upgraded to 0.0.18 of mapshaper-proj.

v0.4.90

  • Upgraded to v0.0.17 of mapshaper-proj, which includes the "Equal Earth" projection (+proj=eqearth).

v0.4.89

  • Convert undefined and null values to empty strings when outputting a DBF string field.

v0.4.88

  • Fix: convert non-alphameric characters in DBF field names to underscores.
  • Web UI updates to support putting more than one mapshaper instance on a single page.

v0.4.87

  • Added experimental -run command, for creating commands on-the-fly and running them.
  • Added experimental -require command, for importing Node modules for use in -each expressions.
  • Added "d" as an alias for "this.properties" in expressions, with a nod to D3.
  • -join command prints a warning instead of erroring if no records are joined.

v0.4.86

  • [gui] Now you can drag layers in the layer menu to change their stacking order.
  • Added mapshaper-gui -a option, to display all layers initially.
  • The -target command can now target multiple layers.
  • Added undocumented aspect-ratio= option to -rectangle and -rectangles commands.

v0.4.85

  • [style] Added -style stroke-dasharray= option.
  • Added -o max-height= option, for limiting the height of SVG output files.
  • Added undocumented -rectangles option, for creating a box around every feature in a layer.
  • Bug fixes

v0.4.84

  • [rectangle] offset= option accepts a list of four values (minx,miny,maxx,maxy) in addition to a single value. Value can be a percentage or an interval.
  • [rectangle] If no source= or bbox= option is given, -rectangle uses the bounding box of the current target layer(s).
  • [points] Added a polyline-to-point conversion that reduces each polyline feature to a single vertex, suitable for point-in-polygon testing.
  • Bug fixes

v0.4.83

  • Now you can turn on multiple reference layers from the layers menu in the web UI. Reference layers are styled on the map if they have style attributes.
  • If a feature is pinned via the [i] inspector tool, the delete key will delete it.
  • The text-anchor property of single-line SVG labels is automatically updated on drag, based on its horizontal position in relation to its anchor point. Labels towards the left of the anchor are given text-anchor=end, labels to the right are given text-anchor=start and centered labels are given text-anchor=middle.
  • The text-anchor property of multi-line SVG labels can be toggled by clicking the label after it has been selected.
  • Added -uniq max-count= option to retain multiple features with the same id.

v0.4.82

  • Added -lines each= option, for applying a JS expression to each output line feature. The expression can access data about the original polygon features, just like the where= option.

v0.4.81

  • Added -lines where= and -innerlines where= options, for filtering lines using properties of adjacent polygons. Polygons are represented as A and B objects in the expression. B is null for "outer" lines.

v0.4.80

  • Results of assigments in -calc expressions are available to subsequent -each expressions as variables.
  • Updated dependencies.

v0.4.79

  • Added new -include command for loading JS data and functions from an external file. The file should contain a single JS object. The keys and values of this object are converted to variables in the JS expression used by -each.

v0.4.78

  • Bug fix

v0.4.77

  • Added -s/--direct-save option to mapshaper-gui, for saving output files to a path relative to the user's current working directory, instead of into the browser's download folder.
  • Added -f/--force-save option to mapshaper-gui, to allow overwriting input files.

v0.4.76

  • Increased the maximum size of CSV output to 2GB (the maximum Buffer size in Node).
  • Print a warning instead of throwing an error if a CSV file contains no data records.

v0.4.75

  • -join copies source fields by default even if calc= option is present.
  • -join prints a warning when inconsistent values are found in copied fields during many-to-one joins.

v0.4.74

  • -join fields=* now copies all of the fields from the source layer, including the key field.

v0.4.73

  • The -merge-layers command is now able to merge layers from different datasets (including layers in the GUI and layers loaded via separate -i commands).
  • Added -merge-layers "force" option for merging layers with inconsistent data fields.

v0.4.72

  • -dissolve and -dissolve2 now accept a comma-separated list of field names to dissolve on.

v0.4.71

  • Added -o field-order=ascending option, for sorting the column names (A-Z) of DBF and CSV files.

v0.4.70

  • Order of data fields is preserved in DBF output (previously fields were sorted in case-sensitive ascending order).

v0.4.69

  • Added support for using .shx file when present. (Very occasionally, records in the .shp file are packed in an unusual way, and the .shx index file is needed for reading the .shp file).

v0.4.68

  • Added ability to dismiss the intersection display on the GUI.
  • Updated web interface colors.

v0.4.67

  • Renamed -svg-style command to -style (-svg-style still works as an alias).
  • Minor web interface improvements

v0.4.66

  • SVG labels are displayed in the web interface.
  • Update label position relative to its anchor point by clicking and dragging the label.

v0.4.65

  • Add -o height option, for setting the pixel height of SVG and TopoJSON output.

v0.4.64

  • Bug fixes

v0.4.63

  • Added mapshaper-xl script, for running mapshaper with about 8GB of heap memory instead of the default amount.
  • Output type 1 Shapefiles if features are all single points (more compact than type 8/multipoint).

v0.4.62

  • Added -o singles option for saving each output layer to a separate file (TopoJSON only).
  • Allow -proj command to set the projection of an empty dataset.

v0.4.61

  • Improvements to command line help.
  • Add support for specifying most distance parameters using a variety of units. For example: -affine shift=1km,2km
  • Add support for specifying areal parameters with units. For example: -filter-islands min-area=5sqkm. Recognizes sqmi/mi2, sqkm/km2, sqm/m2, sqft/ft2.

v0.4.60

  • Added -o id-prefix= option for namespacing svg layer and symbol ids.
  • Fix: SVG layer ids are based on layer names instead of output file name.

v0.4.59

  • Bug fixes and performance improvements.
  • Added undocumented -i geometry-type= option, to allow importing GeoJSON features containing GeometryCollections with mixed types (which would otherwise cause an error).

v0.4.58

  • Fix for issue #236 - error reading some GeoJSON files.
  • Added undocumented -filter-geom command with bbox= option, for removing non-intersecting geometry.

v0.4.57

  • Bug fix for issue #228 "keep_shapes option doesn't always keep shapes".

v0.4.56

  • -clean now removes empty geometries by default.
  • Added -clean allow-empty option to retain empty geometries.
  • Added -clean snap-interval= option to override the default snapping threshold.
  • Updated mapshaper-proj to v0.0.15 (improved .prj file support).

v0.4.55

  • Fix for issue #221 (-simplify resolution= option error).

v0.4.54

  • Improvements to -clean command

v0.4.53

  • Update -dissolve2 command to flatten polygons (remove overlaps) and optionally fill gaps.
  • Added -clean command to flatten polygons and fill gaps.
  • Added min-gap-area= option to -clean and -dissolve2 comands to specify the threshold for filling enclosed gaps between adjacent polygons.
  • Show contents of zip files in web UI file import popup.

v0.4.52

  • Redesigned initial view of the web UI.
  • Temporary fix for issue #219 -- stop trying to fix polygon geometry after applying coordinate precision.

v0.4.51

  • Fix for issue #216 (GeoJSON export fails in browser).

v0.4.50

  • Added support for reading CSV files larger than 250MB.
  • Added support for reading and writing CSV files using other encodings than UTF-8 or ascii.
  • Added -drop command for dropping loaded data layers and for deleting geometry and/or attribute data fields from targeted layers.
  • The [-info] command now shows an asterisk next to currently targetted layers.
  • Bug fixes

v0.4.49

  • Added -polygons gap-tolerance= option, for closing "undershoots" (tiny gaps between two polylines).

v0.4.48

  • Added -shape command, for creating polygons and polylines from lists of coordinates.
  • Added -rectangle command, for creating rectangular polygons.
  • Added experimental -polygons command, for convering a polyline layer containing rings to a polygon layer.
  • Made -dissolve2 more robust (less likely to drop rings when input contains overlapping shapes).
  • In JS expressions, this.x and this.y can now be used to set x,y coordinates of point features (previously they were read-only).
  • -svg-style layer-text= recognizes
    , \n and '\n' (newline char) as line delimiters.
  • -o margin= option now accepts a comma-separated list of margin widths, as an alternative to a single value. List order is xmin,ymin,xmax,ymax (same as bbox= option).

v0.4.47

  • Added -svg-style where= option, for applying svg attributes to a subset of features

v0.4.46

  • Added -o geometry-type= option, which overrides the default GeoJSON output type with one of: Feature, FeatureCollection, GeometryCollection.

v0.4.45

  • Added -o svg-scale= option, for scaling SVG output using geographical units per pixel.

v0.4.44

  • -dissolve2 now removes polygon rings that are improperly nested inside other rings.

v0.4.43

  • Restore prohibition against overwriting input files unless the "-o force" option is present.

v0.4.42

  • Added support for exporting TopoJSON in pixel coordinates using the -o width= and -o margin= options.

v0.4.41

  • Added -o rfc7946 option, for generating RFC 7946-compliant GeoJSON: default 6-decimal precision, CCW outer-ring winding order, antimeridian-spanning bbox, warns if CRS is not WGS84.

v0.4.40

  • Added sprintf() and round(num, digits) utility functions to -each command context.
  • Fixed bug that prevented using applyCommands() with -clip or -erase commands.

v0.4.39

  • [web] Added support for EPSG codes using the -proj command in the browser console (using Proj.4 syntax, like: -proj +init=epsg:2784). Supported init files: epsg, esri, nad83, nad27.

v0.4.38

  • Added -svg-style letter-spacing= option.
  • Started attaching SVG symbol classes to top-level symbol element (this only affects multipoint symbols).

v0.4.37

  • Added support for multiline labels. Lines are separated by newline characters ('\n') in the label text.
  • Added -svg-style line-height= option to control the line height of multiline labels.

v0.4.36

  • Setting both r= and label-text= options of -svg-style creates labels with anchor points.
  • Added font-weight= and font-style= options to -svg-style command.

v0.4.35

  • Added SVG label output, with new options to -svg-style command.
  • Added string-fields= option as an more convenient alternative to field-types= in the -i and -join commands.

v0.4.34

  • Fixed an incompatibility with Node versions < 3.0.

v0.4.33

  • [web] Added support for importing and exporting large GeoJSON files (>1GB) to the web interface.

v0.4.32

  • [web] The inspector tool now shows multiple hits when hovering over/clicking on overlapping polygons and points with identical coordinates.
  • Added -target type=polygon|polyline|point option, for targeting layers of a given type.

v0.4.31

  • Added support for exporting large (>1GB) GeoJSON files.

v0.4.30

  • Added support for importing large (>1GB) GeoJSON files using the command line script.
  • Changed -line command to generate two fields: "RANK", containing an integer and "TYPE", containing a human-friendly name.

v0.4.29

  • Fixed error exporting Shapefiles with unparsable .prj files (content of original file is copied to output file).
  • Updated mapshaper-proj to v0.0.11.

v0.4.28

  • Fixed error when clipping polyline layers containing empty geometries.
  • [web] Support backslash continuation lines in web console.

v0.4.27

  • Added -points interpolated interval= options, for interpolating points along polylines at a fixed interval.
  • Updated parsing of list options to accept quoted items, like this: fields="County FIPS",State .
  • Renamed -proj source= option to -proj match=.
  • Now, -proj from= option accepts a .prj file name or layer id as an alternative to a projection string.
  • Now, -proj from= sets the target CRS if no destination projection is given.

v0.4.26

  • [web] Updated console interface to display alongside the map.

v0.4.25

  • Added -proj target= option, with support for target=*.
  • Added -target name= option for renaming the target layer.
  • Updated mapshaper-proj to v0.0.10.

v0.4.24

  • Fixed: error dissolving polyline features containing rings.

v0.4.23

  • Added polyline support to -dissolve command.

v0.4.22

  • Added -proj source= option to match projection from a .prj file or another layer.
  • Added support for simple point-to-point spatial joins.
  • Added -points vertices option to convert polygon and polyline features to multipoint features.
  • [web] Save console history between sessions using browser localStorage.
  • [web] Always display mouse coordinates.
  • [web] Display coordinates of mouse bbox after first click.

v0.4.21

  • Updated mapshaper-proj to v0.0.9, with better WKT parsing and more projections.
  • Added (undocumented) -shape command.
  • Bug fixes

v0.4.20

  • Added support for generating .prj files.
  • Bug fixes

v0.4.19

  • Improved display of styled layers.
  • Bug fixes

v0.4.18

  • Stacking order of layers in SVG output follows order of target= list.
  • [-colorizer] colors= can take a space- or a comma-delimited list.
  • [-o] Added point-symbol=square option for SVG output.

v0.4.17

  • Added section for experimental commands to command line help.
  • Added experimental -affine command for scaling, shifting and rotating coordinates.
  • Added experimental -colorizer command with support for sequential and categorical color schemes (intended for SVG output).
  • Fixed bug that caused .zip file export to fail in IE11.

v0.4.16

  • Bug fixes

v0.4.15

  • [web] Improve layer pinning interface.

v0.4.14

  • [web] Add button to pin a layer, so it can be compared to the selected layer.
  • Allow calc= expressions to include assignments to same-named variables, ex: calc="POPULATION = sum(POPULATION)".

v0.4.13

  • Add calc= option to -dissolve and -dissolve2 commands.

v0.4.12

  • [csv] Improve detection of numeric fields by testing all non-empty values, not just the first value.
  • [csv] Print the names of auto-detected numeric fields to the console.

v0.4.11

  • Fix a bug in undocumented -data-fill command.

v0.4.10

  • [GeoJSON] Added -o combine-layers option, which modifies GeoJSON output by combining all output layers into a single GeoJSON file.
  • [SVG] Convert all parts of a multipart polygon or polyline as a single <path> element, instead of creating a <g> group with multiple child elements.
  • Fix for issue 174 (bug in -merge-layers command).

v0.4.9

  • Fix for invalid GeoJSON output when an attribute data string contained a certain character sequence (Issue #171).

v0.4.8

  • Fix some glitches in the web attribute inspector.

v0.4.7

  • Added -join calc= option, for many-to-one joins. Provides functions for combining values from multiple source records and assigning the result to a field in the target table.
  • Fixed bug that broke the -i name= option when multiple -i commands were given.
  • Added more functions for -calc and -join calc= expressions: mode(), first(), last() and collect().
  • Added undocumented -data-fill command, for interpolating missing data values by copying from neighbor polygons.

v0.4.6

  • [cli] Fix wildcard expansion of input filenames in Windows command shell.

v0.4.5

  • [cli] Retain .prj file when combining multiple Shapefiles that have the same projection.

v0.4.4

  • [cli] Fix bug writing binary Shapefile files to disk.

v0.4.2

  • [cli] Fix bug importing .shp file contents via applyCommands() api function.

v0.4.1

  • [cli] Display user errors normally when using -quiet command.

v0.4.0

  • Added support for loading several datasets via multiple -i commands.
  • Default target of a command is the output of the previous command (previously the default target was all layers).
  • Added -target command to set the default target.
  • target= option and -target command accept numerical layer ids; first layer of first dataset is 1.
  • Added -quiet command to inhibit console messages.
  • -info command shows information about all layers in all datasets.
  • Updated applyCommands() to accept an object containing contents of multiple input files and return an object containing contents of multiple output files (via callback).
  • Added -uniq verbose option, to show which features are removed.
  • Added -o extension= option, to set the file extension of exported GeoJSON and TopoJSON files.

v0.3.43

  • Fixed bug that caused SVG to be generated without simplification applied (issue #161).

v0.3.42

  • Fixed bug that could prevent SVG output after simplification (issue #160).

v0.3.41

  • More informative error messages for -merge-layers command.

v0.3.40

  • Fix regression: topology not being built when -i combine-files is used.
  • Add experimental -cluster command for aggregating polygons into compact groups.
  • Add support for importing TopoJSON files with nested GeometryCollections.

v0.3.39

  • Add support for importing GeoJSON and TopoJSON collections that contain mixed geometry types. Polygon/MultiPolygon, LineString/MultiLineString and Point/MultiPoint features are imported to separate layers.
  • Address problems caused by imported JSON records containing inconsistent data properties.

v0.3.38

  • [gui] Support loading file(s) from a URL. Use query string ?files= followed by a comma-separated list of file URLs.
  • [dissolve2] Print a warning instead of halting when messy topology causes an uncommon pathfinding error.
  • Apply quantization to TopoJSON point layers (previously point layers were not quantized).

v0.3.37

  • [join] Add isMax() isMin() isMode() functions to -join where= expressions.
  • [proj] Fix webmercator projection alias.
  • [gui] Fix layer menu scrolling.

v0.3.36

  • Add -point-grid command.

v0.3.35

  • [cli] Remove the restriction on importing files of different datatypes using -i combine-files.

v0.3.34

  • Bug fixes
  • Add -simplification lock-box option (undocumented) to retain vertices at the corners and edges of a rectangular dataset (for simplifying vector tiles).

v0.3.33

  • Fixes a global variable leak.

v0.3.32

  • Fixes a bug that caused incorrect TopoJSON output of datasets containing partially overlapping line features.

v0.3.31

  • -info command shows a Proj.4 CS definition, if CS is known or can be inferred.

v0.3.30

  • New -graticule command adds a graticule layer appropriate for a world dataset centered on longitude 0.
  • Add -proj from= option, for defining the original coordinate system of a dataset if unknown.
  • Fix: escape characters in SVG attributes.

v0.3.29

  • Added the -uniq command, which applies an expression to each feature and removes features that produce duplicate values.
  • Commands are displayed in alphabetical order by the -help command.
  • Fixed a bug that prevented reprojecting point layers.

v0.3.28

  • Improved handling of projection errors.

v0.3.27

  • Added reprojection support via mapshaper-proj, a JS port of the Proj.4 projection library.
  • The -proj command takes a proj4 string or an alias.
  • The -proj densify option interpolates vertices so long, straight segments can transform into curved lines.
  • The -projections command lists all supported proj4 projections and aliases.
  • Mapshaper now parses the .prj files of Shapefiles to identify their coordinate system.

v0.3.26

  • -info command displays Object and Array data properties using JSON.
  • The web UI inspector displays objects and arrays as JSON, and accepts JSON input.
  • Object/Array data properties are serialized as JSON in CSV output.

v0.3.25

  • Add geometry info to the console output of -inspect
  • Typing mapshaper <command> shows help for that command (shortcut for mapshaper -h <command>)
  • Rename cleanup option of -clip and -erase to remove-slivers. Also, delete unused arcs by default after clip/erase.
  • Skip over empty Shapefile geometry parts when importing, instead of throwing an error.

v0.3.24

  • Fix regression affecting point Shapefile importing.

v0.3.23

  • The new -inspect <expression> command displays attribute information about a single feature.
  • In the web UI console, -inspect displays selected features as if they had been inspected interactively using the "i" tool.
  • Updated web UI color scheme.

v0.3.22

  • The mapshaper-gui script now accepts one or more files to load (e.g. $ mapshaper-gui states.shp cities.json)
  • mapshaper-gui probes for an open port on localhost if the default port is in use
  • mapshaper-gui exits when mapshaper's browser page is closed

v0.3.21

  • The -filter-slivers command is now documented in mapshaper -h.
  • Open polygon rings are automatically closed on import (Shapefile and GeoJSON only).
  • Reading DBF files is faster.
  • When exporting SVG or TopoJSON from the Web UI, all selected layers are exported in a single file.

v0.3.20

  • Add "Settings" button next to the simplification slider. Now, users can see the current simplification settings and change them on-the-fly.
  • Display a menu for selecting export layers when there are multiple exportable layers.
  • [split] When the target layer is unnamed, "split-" is no longer added as a prefix to output layer names when splitting on a data field.
  • Bug fixes

v0.3.19

  • Support for exporting CSS style attributes with the new -svg-style command.
  • Display mouse coordinates in the Web UI when the "i" tool is selected. Clicking the screen selects the coordinates so they can be copied to the clipboard.
  • Bug fixes

v0.3.18

  • Basic support for exporting to SVG.
  • Added command line option -o format=svg. Saving to a file with ".svg" extension also works.
  • Added SVG-specific options width= and margin= to the output command to override the default values.
  • Added support for importing and exporting NULL type Shapefiles
  • Bug fixes

v0.3.17

  • Added unjoined and unmatched options to the -join command, for inspecting unjoined records from the source and destination tables.
  • Added a constraint to Visvalingam simplification to remove an ambiguity in the order of vertex removal when several vertices have the same effective area.
  • Added cleanup option to -clip and -erase commands, which removes slivers created by clipping (before, slivers were removed by default).
  • Rename cartesian option of -simplify to planar.

v0.3.16

  • -dissolve now supports point layers. Dissolve reduces a group of point features to a single point at the centroid of the group.
  • -dissolve weight= option takes a data field or JS expression and uses this value to weight each point when calculating the centroid of a group of points.
  • -filter-fields no longer supports field renaming. Use -rename-fields instead.
  • -info and -filter-fields commands can be applied to much larger DBF files without triggering out-of-memory errors.

v0.3.15

  • For the web, separate geoprocessing library and Web UI into two files (mapshaper.js and mapshaper-gui.js)
  • Improve detection of invalid DBF files.
  • Bug fixes.

v0.3.14

  • -innerlines command creates fewer line features.
  • Bug fixes.

v0.3.13

  • Adds support for -o format=json, which exports an array of JSON records containing attribute data for each feature. Arrays of JSON records can also be imported.
  • Adds support for the output command (-o) to the Web UI console.
  • Bug fixes.

v0.3.12

  • Adds -simplify stats option, which displays summary statistics relating to the geometry of simplified paths.
  • Adds -simplification weighting= option, for setting the weight parameter in weighted Visvalingam simplification.
  • Adds densify option to the (still undocumented) -proj command.
  • Automatically filter slivers after a clip or erase operation.
  • Adds (undocumented) -filter-slivers command.

v0.3.11

  • Adds -simplify resolution= option, to apply an appropriate amount of simplification for a given display resolution. Example: -simplify resolution=8000x6000.
  • Adds $.x and $.y getters for retrieving x- and y-coordinates of point features from within an -each or -filter expression.

v0.3.10

  • Adds planar option to simplification menu, if dataset contains lat-long coordinates.
  • Bug fixes

v0.3.9

  • Changed web ui layout so popup attribute inspector appears more stable when resizing.
  • Much faster screen rendering of layers containing many small paths.

v0.3.8

  • The -join command now can do point-to-polygon and polygon-to-point spatial joins.
  • Added sum-fields= option to the -join command, for summing the contents of one or more fields when joining multiple source records to a single target record.
  • Added where= option to the -each command, for targetting a subset of features using a boolean JS expression.
  • Added name= option to the import command, for renaming the input layer or layers.
  • Bug fixes

v0.3.7

  • Added a button for exporting to CSV
  • Added delimiter= export option for overriding the default delimiter when outputting CSV.
  • More consistent layer naming -- layers created with the "+" option are unnamed by default.
  • Interface refinements.

v0.3.6

  • Web UI now can import CSV files and standalone DBF files, which enables joining via the browser console.
  • Bug fixes

v0.3.5

  • The attribute data inspector now supports editing data values.
  • The -split command can be applied to layers with no geometry.
  • Bug fixes

v0.3.4

  • Turn on attribute data inspection on rollover by clicking the "i" button.

v0.3.3

  • Correctly import numeric DBF fields that use commas as the decimal separator.
  • Use retina-quality rendering on retina displays.
  • New UI color scheme.
  • L/R arrow keys toggle between layers.
  • Added experimental weight-scale option to weighted Visvalingam simplification method.

v0.3.2

  • Add delete buttons for each layer in the layers menu.
  • Stop displaying ghosted clipping shapes after clip or erase commands.
  • Many other interface improvements.

v0.3.1

  • Adds freeform export options to export menu.
  • Fixes several bugs.

v0.3.0

  • An updated web interface has a built-in console with support for command line editing.
  • Support for text encodings in the web UI.
  • Many bug fixes.

v0.2.28

  • [cli] Fixed regression reading .shp files larger than 1GB.
  • [web] Added buttons for zooming in/out.

v0.2.27

  • Add popup error messages to the web UI.
  • Add a "No simplification" option to the import options.

v0.2.gi26

  • Web UI can now load more than one file. Only the last-loaded file can be edited and exported. The previous file is visible as a faded image. Older files are dropped.
  • Try to handle some irregularities found in in-the-wild .shp files.

v0.2.25

  • Web UI shows a progress bar while importing large datasets.

v0.2.24

  • The web interface can now import Zip archives containing supported file types.

v0.2.23

  • Add + and name= options to -filter command, for creating a new filtered layer alongside the original layer.
  • Add force flag to the -join command. This allows values in the target data table to be overwritten by values in the source table when both tables contain identically named fields.
  • Bug fixes

v0.2.22

  • Fixed a bug preventing files from importing in the GUI.

V0.2.21

  • Feature ids from GeoJSON and TopoJSON files are automatically preserved.
  • Fixed several bugs affecting csv files.
  • When importing and exporting from/to GeoJSON or TopoJSON, top-level "crs" properties are preserved.
  • -dissolve command now works on layers without any geometry (in addition to polygon layers).
  • Improvements to text encoding detection.

v0.2.20

  • Added bbox= option to -clip and -erase commands for clipping/erasing using a bounding box.
  • Added -rename-fields command.
  • Use .cpg file (if present) to set dbf text encoding.
  • Use dbf "language driver id" (if present and valid) to set dbf text encoding.
  • Try to auto-detect dbf text encoding if other methods fail (limited to utf-8 and latin1)
  • Support reading delimited text files with non-utf-8 encodings (using -i encoding= option).
  • Remove byte order mark (BOM) when importing text files in utf-8 and utf-16.
  • Fix a bug affecting -calc command.

v0.2.19

  • Fixed an error importing Shapefiles with the encoding= option.
  • Added experimental (undocumented) -proj command for projecting lat-lng datasets.
  • Added -projections command for listing names of supported projections.

v0.2.18

  • Supports importing, editing and exporting delimited text files and .dbf files.
  • Added field-types= option to -i and -join commands.
  • API function applyCommands() function now accepts delimited text files.
  • Removed optional dataset argument from API function runCommands().
  • Stop supplying default -o command when missing from command line.

v0.2.17

  • Fix an incompatibility with Node 0.12.

v0.2.16

  • Support importing GeoJSON Features that contain GeometryCollections.
  • Fix for issue #68: error clipping some shapes that abut a clip polygon.
  • Skip fields with unsupported types when importing .dbf files (instead of throwing exception).
  • Support for Node 0.12.x

v0.2.15

  • Fixed bug affecting -join command.
  • Rename data fields to avoid name collisions.

v0.2.14

  • Add wildcard expansion for input filenames (to support filename expansion in the Windows command line).
  • Speed up identification of interior points (-points inner command).
  • Improve command line help.

v0.2.13

  • Add -calc command for calculating simple statistics about a data layer using a JS expression. Functions include sum() median() average() min() max() count().
  • Add function for finding interior points of polygon features, for anchoring symbols and labels.
  • Add inner and centroid options to the -points command -- for creating a layer of centroids or interior points from a polygon layer
  • Add -sort command for sorting the features in a layer
  • -o id-field= supports a comma-sep. list of field names -- useful for assigning ids to multiple TopoJSON objects with different data properties.

v0.2.12

  • Add -filter-islands command with min-area, min-vertices and remove-empty options.
  • Add -points command with x and y options, for creating a point layer from x, y coordinates in an attribute table.
  • Add -o prettify option to generate human-readable GeoJSON and TopoJSON.
  • mapshaper.applyCommands() now returns an array only if output includes more than one JSON object.
  • Bug fixes

v0.2.11

  • Halt when -merge-layers fails
  • Print a warning if -innerlines output is null
  • Apply snapping after multiple import files are merged/combined
  • Let users apply arbitrarily large snap intervals instead of capping at avg. segment length
  • Use APIError type for invalid API function call parameters
  • Switch from async csv parsing using node-csv to synchronous parsing using d3.dsv
  • Merge mapshaper.runCommandString() into mapshaper.runCommands()
  • Add mapshaper.applyCommands() to tranform Geo/TopoJSON programmatically.

v0.2.9

  • Accept point and polyline type layers as targets of -clip and -erase commands
  • -o presimplify option adds simplification thresholds to TopoJSON arc vertices.
  • Bug fixes

v0.2.8

  • Add -rename-layers <name(s)> for renaming one or more target layers

v0.2.7

  • Bug fixes (issues #56 and #58)
  • Improved output file type inference

v0.2.6

  • Add -o drop-table option
  • Infer output file type from file name
  • Bug fixes

v0.2.5

  • Add -o force option to overwrite existing files instead of renaming output files
  • Bug fix

v0.2.4

  • Add -o precision option for rounding output coordinates
  • Add -i /dev/stdin and alias -i - to receive data via stdin (single-file Topo/GeoJSON input only)
  • Add -o /dev/stdout and alias -o - to send output to stdout (single-file JSON output only)
  • Add support for Travis CI

v0.2.3

  • Add -i id-field= option: import Topo/GeoJSON 'id' property to the specified data field
  • Extend -o id-field= option to GeoJSON Features (previously TopoJSON only)

v0.2.2

  • Update weighting function for weighted Visvalingam simplification
  • Add support for loading mapshaper.js with RequireJS
  • Improve display of information with -info command
  • Add undocumented -dissolve2 command, which can dissolve overlapping polygons

v0.2.1

  • Improve performance of -erase when erase layer contains many small polygons

v0.2.0

  • New command line syntax
  • New -clip and -erase commands
  • Many bug fixes