Folder Synchronize Command Script File Syntax
Version 3.0
Funduc Software, Inc
Copyright 1997-2023
http://www.funduc.com    http://www.searchandreplace.com
support@funduc.com      

Listed below are the switches and settings available for Folder Synchronize. We present this information in the form of a commented script. Scripts are ASCII text files (PC format). You can create them manually with your text editor or use our freeware Folder Synchronize Script Editor

A text version of the script syntax is included with the distribution of Folder Synchronize in the file, "FoldSynchSyntax.sfs". 

Some abbreviated sample scripts with commented descriptive information and a test path with some dummy files is included in the 'SampleScripts.zip' file in the distribution..

Scripts are submitted to the program from the command line. Folder Synchronize does not have a user interface. Scripts are submitted to the program from the command line. The basic syntax is 

   FOLDSYNC.EXE <script file name>

Please see the program documentation for more information about command line syntax.


# Comment lines in a script are prefaced with # or ' characters

# in column 1. The comment characters _must_ go in column 1.

# Comments should not be placed after script commands -- keep

# comments on separate lines from your working script switches.

 

# Blank lines are ignored.

 

# Note: All script commands and comments must begin in column 1!!!

 

# GENERAL COMMENTS

# ================

# The [Default] Section, which is optional, is used to specify

# parameters for all [Action]'s in the script. You can also

# specify parameters within [Action] section(s). Any parameters

# that are present within an [Action] section override counterparts

# in [Default].

#

# All scripts must have at least one [Action] section!!

#

# For a single action script you can specify a [Default] if you

# want but [Action1] MUST be present. In practice, for single action

# scripts you may find it easiest to omit [Default] entirely and

# specify all parameters under [Action1].

#

# When present, [Default] should always be specified at the very top

# of the script.

#

# The order of processing for the [Action] sections is determined by

# their number. They can be placed in any order within the script.

# Numbers do not need to be inclusive -- you can skip numbers.

# For example, a with [Action8] [Action2] [Action5] will be processed

# in the order: [Action2] [Action5] [Action8].

#

# If an [Action] number is duplicated, the program will process

# the first of that number as it is found in the script. For

# example, in a script with [Action1], [Action2], [Action3], [Action2],

# the first [Action2] will be processed. The 2nd is ignored.

 

[Default]

 

# *** PATH SETTING ***

# Note: If Path1= or Path2= setting are listed in [Default],

# create a [Action1] tag with no Path1= or Path2= setting in

# order to use Path1= or Path2= as specified in [Default]. If

# your [Action1] section has a Path1= and Path2= settings they

# will supercede what is specified in [Default].

Path1=D:\Test\Folder1

Path2=D:\Test\Folder2

 

# Alternate Specification:

# Paths can also be specified in the form of variables that can then

# be employed as needed within specific [Action] sections. For example,

 

# TestPath1=D:\Test\Folder1

# TestPath2=D:\Test\Folder2

# MyDocsForWork=C:\Documents and Settings\BillsWork\My Documents

# DocsForGaming=C:\Documents and Settings\Game Player\My Documents

 

# The variable names can be any string except they must not begin

# with the # or ' characters and they should not contain spaces

#

# It is OK to use both forms within a single script.

#

# See the [Action4] and [Action5] sections below, and the

# Example4.sfs sample script for more info.

 

# *** FILE MASK ***

 # File masks are specified with the Mask= switch. Complex file masks

# can be used. If no mask is specified the default assumed is *.*

# If you have Directory Toolkit, see the Directory Toolkit complex

# mask dialog for a builder to help you construct complex masks.

# Some examples are:

# Mask Effect

# -------------------- -------------------------------------

# *.i?? Include files ending with .i followed

# by 3 characters

# win.ini This would be found by the above.

# ~moricons.dll Exclude this specific file.

# ~\images\te*\ A wildcard (te*) to skip images\test,

# images\testing, etc.

# ~\*\junk*\*\*.* Skips all files in any subdir junk*

# and all under that.

#

# All subdir specifications are relative Path1= and Path2=

# Separate multiple specifications with ; character. For example,

# *.*;~\*\junk*\*\*.*

#

Mask=*.*

 

# *** PROCESS SUBDIRECTORIES ***

# Use the Search_subdir= switch to include subdirectories or not.

# The default if not specified is to search and process all

# subdirectories.

# Possible Values:

# 0 = Do not recurse subdirs

# 1 = Include subdirs

Search_subdir=1

 

# *** SYNCHRONIZE/COMPARE OPERATION TO PERFORM ***

# Use the Operation= switch to control which synchronize

# operation to perform. If not specified, Default Operation = 6.

# Use only one switch per [Action] section. Use a value of 6

# (Compare Only) to generate an output report without performing

# any synchronize operations.

 

# The - value, 'prompted' switches below trigger a synchronize

# dialog that waits for user input.

 

# Note: Please see Prune Notes for info about the behavior of

# Operation=4 when no files are updated and/or no orphan files

# are to be removed.

 

# SWITCH VALUE

# No

# OPERATION Prompt Prompted ACTION

# ---------------- ------ -------- ------------------

# Synchronize 0 -2 Update & Add in both directions.

# Augment 1 -3 Add only new to target.

# Refresh 2 -4 Update only existing in target.

# Update 3 -5 Update & Add new to target.

# Prune 4 -6 Update, Add new, Remove Orphans.

# Remove Identical 5 -7 Remove identical files from target.

# Compare Only 6 -8 Display only - No synch operations.

# Recreate Dirs 7 -9 Recreate directory structure only.

# No other files are copied.

# Delete Empty Dirs 8 -10 Delete empty directories from the

# target. No other files are copied.

# Custom Operation 9 -11 Custom synch operations using the

# Synch Flags= switch. See below!!

# Prompt only -1 Display synch dialog with no default.

Operation=6

 

# *** CUSTOM SYNCH SWITCH ***

# This is a special switch for version 2.7+ that permits finer

# control over the synch operation(s) to be performed. It is

# used in combination with the Operation=9 or -11 switch values

# to do one or more types of operation(s).

#

# If Operation=-11 is specified, the Synchronize dialog is

# presented with "Custom" and your setting for Synch Flags= pre-

# selected. If Operation=9 you MUST specify something for

# Synch Flags= or the program will do nothing.

#

# The table of values below is used to determine which are done.

# You can use only one operation by specifying that one value or

# do multiple choices by adding the values together. For

# example, to only add new files to the target path, specify

# Operation=9 and Synch Flags=32. To add new files to the target

# and delete empty dirs on the target, specify Operation=9 &

# Synch Flags=288. (Note: For 'Prompted' use Operation=-11).

#

# Possible Values for Synch Flags= Switch:

# Remove Orphans From Source = 1

# Update Existing On Source = 2

# Add New Files To Source = 4

# Remove Orphans From Target = 8

# Update Existing On Target = 16

# Add New Files To Target = 32

# Delete Duplicates From Target = 64

# Create Subdirs On Target = 128

# Delete Empty Dirs On Target = 256

#

# The order of precedence of operations is:

# Delete files from target; Delete files from source

# Delete duplicates from target; Update source|target

# Add new to target; Add new to source

# Create dirs on target; Delete empty dirs on target

#

# Why is the precedence relevant? First, delete operations may

# eliminate chances for a lower precedence operation, e.g., delete

# files from source might mean that a create subdirs on target can't

# happen because the original file(s)/subdir(s) would be eliminated.

# Second, if confirmations are enabled and Cancel is issued for any

# of the deletes, all other possibilities are also canceled. Second,

# if a higher precedence step cannot be completed, or is canceled

# manually, lower precedence step(s) are not performed.

#

# Synch Flags=2

 

# *** OUTPUT FILE FUNCTIONS ***

# To create an Output File of the results, specify a path & file

# name using the Output File= switch. Leave Output File= blank

# to not write an output file. To write to the output file in

# Append mode, use the Append to Output File=1 setting.

# It is OK to define different Output File= and

# Append to Output File= settings for various [Action] section(s).

#

# IMPORTANT: Use a path for the output file other than one being used

# during a synchronize operation. If your output file is in a path that

# is being actively synchronized you may get file sharing errors.

# It is OK to define different Output Files for each [ActionX] section.

#

# Possible Values for append switch:

# 0 = Output file is overwritten.

# 1 = Output writes are in append mode.

Output File=

Append to Output File=1

 

# *** PREVIEW YOUR OPERATIONS ***

# The Destination Path= switch, if specified, is the path to copy the

# file(s) to instead of the Path2= path. For example, if your

# synchronize choice determines that letter.doc would be copied from

# the Source to the Target, if a path is specified in Destination= ,

# letter.doc would be copied there instead.

# Destination Path=c:\tools\foldsync\test_results

 

# *** PROGRESS METER ***

# The progress meter can be enabled/disabled with this switch.

# The default if nothing is specified is to display the meter.

# If the script has multiple [Action] sections, you can enable

# the meter for some [Action]'s but not others by using

# different settings in each [Action]. Or you can specify one

# setting in the [Default] section and different Show Progress=

# setting(s) in specific [Action] sections.

#

# To make the program run silently, disable confirmations and

# the progress meter. Example:

# Confirm Updates=0

# Show Progress=0

#

# Possible Values:

# 0 = No meter

# 1 = Progress meter enabled

Show Progress=1

 

# *** DISABLE/ENABLE CANCEL BUTTON ***

# The progress meter includes a Cancel button. The default if

# nothing is specified is to allow cancel. If the script contains

# multiple [Action ] sections, depending on the point at which the

# cancel button is clicked, the user is prompted to cancel

# the current [Action] or the entire script.

#

# If Show Progress=1 is not specified Allow Cancel= has no effect.

# You can vary Allow Cancel= across specific [Action] section(s)

# to allow cancel at some points but not others. If you do this

# you should put 'no-cancel' [Action]'s at the top of the script

# so the user cannot use cancel to abort the entire script.

#

# Note: Allow Cancel= only affects the Cancel button in the

# progress meter. If you enable file change confirmations with the

# Confirm Updates=1 switch a separate Cancel button is presented

# in that dialog. See Cancel Prompts for more information.

#

# Possible Values:

# 0 = Disable Cancel button

# 1 = Enable Cancel button

Allow Cancel=1

 

# *** DISPLAY CUSTOM BITMAP ***

# The program can display a bitmap (transparent) in the progress

# meter. The bottom left pixel of the .bmp is used as the transparent

# color. The suggested size for the .bmp is 195 x 65 pixels.

# Similar to how the progress meter can be enabled for some [Action]'s

# and not others, a different .bmp can be specified for various

# [Action ]'s. The Show Progress=1 switch must also be specified for

# Bitmap File= to have any effect.

# Bitmap File=D:\Scripts\Test1.bmp

 

# *** MESSAGE TO DISPLAY ***

# To display single line message in the progress meter, use the

# Custom Message= switch. Similar to how the progress meter can be

# enabled for some [Action]'s and not others, Custom Message=

# settings can be varied across [Action ]'s. Show Progress=1 must

# also be specified for Custom Message= to have any effect.

# Custom Message=Performing a synchronize....

 

# *** DISPLAY ERROR MESSAGES ***

# Use the Display Error Messages= switch to control whether or

# not the program issues small 'Action Completed' message

# boxes after a script is complete. We recommend using

# Display Error Messages=1 if you are doing operations to/from

# floppy media because this will help the program detect

# some OS-related driver error messages for some manufacturer's

# drivers such as zip disks, CDRW drives, etc. For totally

# silent operations specify Display Error Messages=0.

Display Error Messages=1

 

# *** REPLACEMENT CONFIRMATIONS ***

# Controls whether prompting for file replaces and deletions is made.

# The Use OS Operations=1 switch determines the style of the

# prompting offered. If not specified, Default = 1.

# Possible Values:

# 0 = No update prompts for file replacements are supplied.

# 1 = Confirmation prompts will be made.

Confirm Updates=1

 

# *** BINARY FILE CONTENTS COMPARISON ***

# Use this to perform a byte level contents comparison when two

# files have an alike name but different file date. The files

# will be considered identical if the contents are the same.

# Enable this only if you need it -- because the entire file must

# be read, processing will be slower, especially when network

# paths are involved. If not specified, Default = 0.

# Possible Values:

# 0 = Do not perform binary file checks.

# 1 = Perform binary file checks.

Check Same Size Files=0

 

# *** BINARY FILE CONTENTS COMPARISON - SAME DATE FILES ***

# To not perform a binary contents check on same date/size files,

# turn off the Binary Check Same Date Files= switch.

# This will speed up operations when Check Same Size Files=1 is

# enabled. However, use this only if you are sure your same

# date/size files are identical. This switch has no effect if

# Check Same Size Files=0 is in place. Default = 1.

# Possible Values:

# 0 = Do not binary compare same size/date files.

# 1 = Perform binary file compare on all files.

Binary Check Same Date Files=1

 

# *** UNIX COMPARE MODES ***

# Two special 'Unix' Directory Compare modes are available as a

# subset of Binary File Comparison (above) to compare files that

# have matching date/time stamps but different file sizes. The

# first, 'Ignore Whitespace Compare', disregards whitespace

# including spaces and line terminators. This mode can be used to

# compare Unix vs. PC files that are the same name and have matching

# time/date stamps. The second, 'Ignore Case Compare', disregards

# the case of the text within the files.

# Important Notes - Please Read:

# - The Check Same Size Files=1 switch MUST also be specified for

# either of these switches to work.

# - Ignore Whitespace Compare can be done alone.

# - To use Ignore Case Compare you MUST also enable Ignore Whitespace

# Compare.

# - The default for both switches if not specified is =0, e.g.,

# Ignore Whitespace Compare=0, Ignore Case Compare=0

# Settings if you want Unix Compare alone:

# Check Same Size Files=1

# Ignore Whitespace Compare=1

# Ignore Case Compare=0

# Settings if you want Unix Compare and Ignore Case Compare:

# Check Same Size Files=1

# Ignore Whitespace Compare=1

# Ignore Case Compare=1

 

# *** DISPLAY DIFFERENT / IDENTICAL FILES ***

# Use these switches to control whether the program includes

# different &/or identical in your synchronize or comparison

# operation. If not specified, Default = 1.

# Possible Values:

# 0 = Do not include those files

# 1 = Include those files

Show Different=1

Show Identical=1

 

# *** LOCATE SAME NAMED FILES ***

# Use the Match In Subdir=1 switch to enable a special mode to

# search for duplicate files on your disk, e.g., to scan for

# duplicate DLLs or ferret out like-named documents across

# different subdirectories. In general, you would specify the

# same path for Path1= and Path2= when using this mode, although

# other two different paths can be scanned as well. Do not enable

# Match In Subdir=1 if you do not need it - the file lists returned

# are generally not what you would want for a typical

# synchronize operation. Operation=6 is the most common usage.

# The default is Match In Subdir=0

# Possible Values:

# 0 = Do not search for duplicate files in the paths.

# 1 = Perform a Match Duplicate Files comparison.

Match In Subdir=0

 

# *** TIME CHECK PRECISION ***

# Because NT-class operating systems such as Windows XP & above

# use a more accurate time stamp than Windows 95/98, comparisons

# between a Win95/98 and NT-class machine may lead to false

# mismatches a second apart (Win95/98 precision is on even

# seconds). The Time Check Precision= switch can be used to

# establish a +/- range, inside of which two files will be

# considered identical if their name & size are the same. Specify

# the value in seconds to use for Time Check Precision.

# Specify the value in seconds to use for Time Check Precision.

# If not specified, Default = 3.

Time Check Precision=3

 

# *** PATH 2 TIME COMPENSATION ***

# The Add Seconds To Second Dir= switch can be used compensate

# for a known, exact time difference between two paths. This

# switch can be useful if time zone differences are affecting the

# reported file times for one or the other path and if you do not

# wish to use 'Binary File Contents' compare mode (Check Same

# Size Files= switch). If Add Seconds To Second Dir= is

# specified the program adds or subtracts the specified number of

# seconds from the reported file times for Path2.

# For example, if a file time stamp is 08:00 and Add Seconds To

# Second Dir= 3600 is specified, the program will use 09:00 for

# the file time when evaluating comparisons. The value can be +

# or -. All files in path2 are affected. Add Seconds To Second

# Dir= is a fixed value, not a range. Omit this switch entirely

# if you do not need it.

# Add Seconds To Second Dir=

 

# *** USE OS vs INTERNAL CONFIRMATION DIALOGS ***

# The Use OS Operations= switch controls the type of file

# confirmation dialog used: internal file vs. standard Windows

# dialogs. The internal dialogs provide more information and

# choices than the native Windows dialogs. Some network drivers

# & removable media may require 'native' mode. If you have

# trouble with subdirs not being created on a path, try

# Use OS Operations=1. If not specified, Default = 1.

# Possible Values:

# 0 = Use internal file confirmation dialogs.

# 1 = Use native OS file operations.

Use OS Operations=0

 

# *** INCLUDE FILES THAT EXIST ONLY IN ONE PATH ***

# Show Files in 1 Dir= is used to control whether orphan files in

# one or the other path are included in an operation. In most

# cases you will probably want Show Files in 1 Dir=1. If not

# specified, the default = 1.

# Possible Values:

# 0 = Do not include files that exist in one dir only.

# 1 = Include files that exist in one directory only.

Show Files in 1 Dir=1

 

# *** CASE SENSITIVE NAME MATCHING ***

# Use this to compare file names case sensitive or not. If not

# specified, Default = 0.

# Possible Values:

# 0 = File name matching not case sensitive.

# 1 = File name matching is case sensitive.

Case Sensitive=0

 

# *** OVERWRITE BLOCKS - NEWER &/or OLDER FILES ***

# The two switches below are used to prevent the replacement of

# newer and/or older files. For safety reasons you probably should

# keep 'Newer Overwrite' turned off -- If enabled, a synchronize

# could replace newer files with older versions!!! If 'Newer

# Overwrite' is not specified the program default is disabled.

# 'Older Overwrite' should probably be enabled (this is the

# default). If you disable 'Older Overwrite', older versions of

# files will not be updated with newer versions during a

# synchronize. If not specified, Newer Overwrite=0 and

# Older Overwrite= 1.

# Possible Values:

# 0 = Do not overwrite.

# 1 = Allow overwrites.

Newer Overwrite=0

Older Overwrite=1

 

# *** GROUPING SIMILAR FILES ***

# When Group Files=1 is specified, the program clusters files in

# a comparison display by file name, with orphaned files grouped

# at the top or bottom of the list. When Group Files=0,

# comparisons are organized such that 'missing' or 'unmatched'

# files are visible within the context of other files according

# to the sort order. If not specified, Default = 0.

# Possible Values:

# 0 = Do not group files.

# 1 = Group files.

Group Files=0

 

# *** DISPLAY AND OUTPUT COLUMN SETTINGS ***

# The Display Columns= and Output Columns= switches can be used

# to control the layout of Directory Toolkit's GUI display and

# the layout of the output report in Directory Toolkit and Folder

# Synchronize. The default used for a script are the settings in

# place when the program was last run interactively. Describing

# the possible manual settings is complicated. Please see

# 'ScriptColumnDefinitionSettings.txt', that is installed in the

# program path, more information and some example settings.

# Display Columns=

# Output Columns=

 

# *** SORTING OPTIONS ***

# To sort the file listing, use one of the values below.

# To control ascending vs descending, use the Sort Type=

# switch.

# Field to sort on:

# SORT_BY_NONE = -1 (default if nothing specified)

# SORT_BY_NAME = 0

# SORT_BY_TYPE = 1

# SORT_BY_DATE = 2

# SORT_BY_SIZE = 3

# SORT_BY_PATH = 4

# SORT_BY_CHKSUM = 5

# SORT_BY_CRC32 = 6

# SORT_BY_ADATE = 7

# SORT_BY_CDATE = 8

Sort Compare=-1

 

# For Ascending vs Descending, Sort Type= values are:

# 0 = Descending

# 1 = Ascending

Sort Type=1

 

# *** FILTERING FILES ***

#

# The Mask= switch filters files by name &/or path.

#

# Other switches are available to filter files by size, date, and

# file attribute. The Reverse Filters= switch is used to cause

# these switches to function as 'exclude' or 'include'.

#

# The values at below are the defaults if not specified (all

# files included). Omit those entirely if you do not need any

# special settings. The switches work in tandem with each other and

# the combinations of values can be complex. Please see

# Please see Date and Size Filters in the program documentation

# for more information. Also see the 'ScriptFilterSettings.txt'

# file that is installed with the program.

#

# Also note that you can use the string, %%today%%, for the two

# date filters. When specified, %%today%% automatically uses the

# current computer date for the respective filter setting. You can

# add or subtract days by specifying a +/- value before the ending

# %%. Examples: %%today-5%% uses a date filter of the current date

# minus 5 days; %%today+1%% adds one day to the current date.

#

# Min Size Filter=0

# Max Size Filter=100000

# Min Date Filter=8/21/2003

# Max Date Filter=8/23/2004

#

# Skip Files Mask=0

# Ignore Attributes=55

# Reverse Filters=0

 

# *** ADDITIONAL ACTIONS ***

#

# Scripts can carry out more than one action. To do this, make

# [ActionX] as modeled below. They can be specified in any

# order in the script. The program parses the entire

# script and implements the 'Actions' sequentially, based

# on their number,

# e.g., [Action1], [Action2], [Action3], etc.

# Setting specified in [Default] will be in effect if that same

# switch is not specified in a given Action section.

 

[Action1]

Path1=D:\Test\Folder1

Path2=D:\Test\Folder2

Mask=*.*

Search_subdir=0

Operation=6

 

[Action2]

Path1=D:\Test\Folder1\SubFolder

Path2=D:\Test\Folder2\SubFolder

Mask=*.*

Search_subdir=0

Operation=1

Confirm Updates=0

 

[Action3]

Path1=C:\My Documents\Current Projects

Path2=C:\My Documents\Backup

Operation=2

Mask=*.doc;*.txt;~\*\Project10\*\*.doc

Confirm Updates=1

Search_subdir=1

 

# The next two [Action] sections use the "Alternate Specification"

# described in the [Default] section. Note that [Action5] uses a literal

# path and a variable path that is defined in the [Default] section.

 

[Action4]

Path1=TestPath2

Path2=MyDocsForWork

Operation=2

Mask=*.doc

Confirm Updates=0

Search_subdir=1

 

[Action5]

Path1=D:\Old_Work_Stuff

Path2=MyDocsForWork

Operation=2

Mask=*.txt

Confirm Updates=0

Search_subdir=1 

 


[Back] [Home]

© 1995-2025 Funduc Software. All rights reserved.
http://www.funduc.com
http://www.searchandreplace.com
Send comments to webmaster@funduc.com