.TH "OSMIUM-APPLY-CHANGES" "1" "1.10.0" "" "" .SH NAME .PP osmium\-apply\-changes \- apply OSM change file(s) to OSM data file .SH SYNOPSIS .PP \f[B]osmium apply\-changes\f[] [\f[I]OPTIONS\f[]] \f[I]OSM\-DATA\-FILE\f[] \f[I]OSM\-CHANGE\-FILE\f[]... \f[B]osmium apply\-changes\f[] [\f[I]OPTIONS\f[]] \f[I]OSM\-HISTORY\-FILE\f[] \f[I]OSM\-CHANGE\-FILE\f[]... .SH DESCRIPTION .PP Merges the content of all OSM change files and applies those changes to the OSM data or history file. .PP Objects in the data or history file must be sorted by type, ID, and version. Objects in change files need not be sorted, so it doesn\[aq]t matter in what order the change files are given or in what order they contain the data. .PP Changes can be applied to normal OSM data files or OSM history files with this command. File formats will be autodetected from the file name suffixes, see the \f[B]\-\-with\-history\f[] option if that doesn\[aq]t work. .PP This commands reads its input file(s) only once and writes its output file in one go so it can be streamed, ie. it can read from STDIN and write to STDOUT. .SH OPTIONS .TP .B \-H, \-\-with\-history Update an OSM history file (instead of a normal OSM data file). Both input and output must be history files. This option is usually not necessary, because history files will be detected from their file name suffixes, but if this detection doesn\[aq]t work, you can force this mode with this option. Can not be used together with the \f[B]\-\-locations\-on\-ways\f[] option. .RS .RE .TP .B \-\-locations\-on\-ways Input has and output should have node locations on ways. Can be used to update files created by the \f[B]osmium\-add\-locations\-to\-ways\f[]. See there for details on the format. Can not be used together with the \f[B]\-\-with\-history\f[],\f[B]\-H\f[] option. .RS .RE .TP .B \-\-redact Redact (patch) history files. Change files can contain any version of any object which will replace that version of that object from the input. This allows changing the history! This mode is for special use only, for instance to remove copyrighted or private data. .RS .RE .TP .B \-r, \-\-remove\-deleted Deprecated. Remove deleted objects from the output. This is now the default if your input file is a normal OSM data file (\[aq].osm\[aq]). .RS .RE .TP .B \-s, \-\-simplify Deprecated. Only write the last version of any object to the output. This is now the default if your input file is a normal OSM data file (\[aq].osm\[aq]). .RS .RE .SH COMMON OPTIONS .TP .B \-h, \-\-help Show usage help. .RS .RE .TP .B \-v, \-\-verbose Set verbose mode. The program will output information about what it is doing to STDERR. .RS .RE .TP .B \-\-progress Show progress bar. Usually a progress bar is only displayed if STDOUT and STDERR are detected to be TTY. With this option a progress bar is always shown. Note that a progress bar will never be shown when reading from STDIN or a pipe. .RS .RE .TP .B \-\-no\-progress Do not show progress bar. Usually a progress bar is displayed if STDOUT and STDERR are detected to be a TTY. With this option the progress bar is suppressed. Note that a progress bar will never be shown when reading from STDIN or a pipe. .RS .RE .SH INPUT OPTIONS .TP .B \-F, \-\-input\-format=FORMAT The format of the OSM\-DATA\-FILE or OSM\-HISTORY\-FILE. Can be used to set the input format if it can\[aq]t be autodetected from the file name. See \f[B]osmium\-file\-formats\f[](5) or the libosmium manual for details. .RS .RE .TP .B \-\-change\-file\-format=FORMAT The format of the OSM\-CHANGE\-FILE(s). Can be used to set the input format if it can\[aq]t be autodetected from the file name(s). This will set the format for all change files, there is no way to set the format for some change files only. See \f[B]osmium\-file\-formats\f[](5) or the libosmium manual for details. .RS .RE .SH OUTPUT OPTIONS .TP .B \-f, \-\-output\-format=FORMAT The format of the output file. Can be used to set the output file format if it can\[aq]t be autodetected from the output file name. See \f[B]osmium\-file\-formats\f[](5) or the libosmium manual for details. .RS .RE .TP .B \-\-fsync Call fsync after writing the output file to force flushing buffers to disk. .RS .RE .TP .B \-\-generator=NAME The name and version of the program generating the output file. It will be added to the header of the output file. Default is "\f[I]osmium/\f[]" and the version of osmium. .RS .RE .TP .B \-o, \-\-output=FILE Name of the output file. Default is \[aq]\-\[aq] (STDOUT). .RS .RE .TP .B \-O, \-\-overwrite Allow an existing output file to be overwritten. Normally \f[B]osmium\f[] will refuse to write over an existing file. .RS .RE .TP .B \-\-output\-header=OPTION=VALUE Add output header option. This command line option can be used multiple times for different OPTIONs. See the \f[I]libosmium manual\f[] for a list of available header options. .RS .RE .SH DIAGNOSTICS .PP \f[B]osmium apply\-changes\f[] exits with exit code .TP .B 0 if everything went alright, .RS .RE .TP .B 1 if there was an error processing the data, or .RS .RE .TP .B 2 if there was a problem with the command line arguments. .RS .RE .SH MEMORY USAGE .PP \f[B]osmium apply\-changes\f[] keeps the contents of all the change files in main memory. This will take roughly 10 times as much memory as the files take on disk in \f[I]\&.osm.bz2\f[] format. .SH EXAMPLES .PP Apply changes in \f[C]362.osc.gz\f[] to planet file and write result to \f[C]new.osm.pbf\f[]: .IP .nf \f[C] osmium\ apply\-changes\ \-\-output=new.osm.pbf\ planet.osm.pbf\ 362.osc.gz \f[] .fi .SH SEE ALSO .IP \[bu] 2 \f[B]osmium\f[](1), \f[B]osmium\-file\-formats\f[](5), \f[B]osmium\-merge\-changes\f[](1), \f[B]osmium\-derive\-changes\f[](1) .IP \[bu] 2 Osmium website (https://osmcode.org/osmium-tool/) .SH COPYRIGHT .PP Copyright (C) 2013\-2018 Jochen Topf . License GPLv3+: GNU GPL version 3 or later . This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. .SH CONTACT .PP If you have any questions or want to report a bug, please go to https://osmcode.org/contact.html .SH AUTHORS Jochen Topf .