public class NotFileComparer : FileComparer
The NotFileComparer class can be used for the Upload and Download operations. The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer.
using ComponentPro.IO; using ComponentPro.Net; ... using (Ftp client = new Ftp()) { // Connect to the FTP server. client.Connect(MyFtpServer, MyFtpPort); // Authenticate. client.Authenticate("test", "test"); // Create a new instance of the TransferOptions. TransferOptions opt = new TransferOptions(); // Set transfer options // Files with the same size and different modification date time will not be uploaded. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.FileOverwriteMode = FileOverwriteMode.CustomCompare; // Indicates that the above Comparer is used. // Upload files and subdirectories in "C:\test" to the current remote directory. client.Upload( "c:\\test", // Source directory path "", // Destination directory path - "" means current directory opt ); }
The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer in a Mirror operation.
using ComponentPro.IO; using ComponentPro.Net; ... using (Ftp client = new Ftp()) { // Connect to the FTP server. client.Connect(MyFtpServer, MyFtpPort); // Authenticate. client.Authenticate("test", "test"); // Create a new instance of the MirrorOptions class. QuickSyncOptions opt = new QuickSyncOptions(); // Set mirror settings // Files with the same size and different modification date time will not be processed. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.Recursive = true; // Mirror folders. client.QuickSynchronize( "", // Source directory path - "" means current remote dir "c:\\test", // Destination directory path. true, // Source directory is master. It means contents of "c:\test" will be identical to the remote dir's. opt ); }
The NotFileComparer class can be used for the Upload and Download operations. The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer.
using ComponentPro.IO; using ComponentPro.Net; ... using (Sftp client = new Sftp()) { // Connect to the SFTP server. client.Connect(MySftpServer, MySftpPort); // Authenticate. client.Authenticate("test", "test"); // Create a new instance of the TransferOptions. TransferOptions opt = new TransferOptions(); // Set transfer options // Files with the same size and different modification date time will not be uploaded. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.FileOverwriteMode = FileOverwriteMode.CustomCompare; // Indicates that the above Comparer is used. // Upload files and subdirectories in "C:\test" to the current remote directory. client.Upload( "c:\\test", // Source directory path "", // Destination directory path - "" means current directory opt ); }
The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer in a Mirror operation.
using ComponentPro.IO; using ComponentPro.Net; ... using (Sftp client = new Sftp()) { // Connect to the SFTP server. client.Connect(MySftpServer, MySftpPort); // Authenticate. client.Authenticate("test", "test"); // Create a new instance of the MirrorOptions class. QuickSyncOptions opt = new QuickSyncOptions(); // Set mirror settings // Files with the same size and different modification date time will not be processed. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.Recursive = true; // Mirror folders. client.QuickSynchronize( "", // Source directory path - "" means current remote dir "c:\\test", // Destination directory path. true, // Source directory is master. It means contents of "c:\test" will be identical to the remote dir's. opt ); }
The NotFileComparer class can be used for the UploadFiles and ExtractFiles operations. The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer.
using ComponentPro.Compression; using ComponentPro.IO; ... using (Zip arc = new Zip()) { // Create a new ZIP file. arc.Create("myzip.zip"); // Create a new instance of the TransferOptions. TransferOptions opt = new TransferOptions(); // Set transfer options // Files with the same size and different modification date time will not be uploaded. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.FileOverwriteMode = FileOverwriteMode.CustomCompare; // Indicates that the above Comparer is used. // Upload files and subdirectories in "C:\test" to the current remote directory. arc.AddFiles( "c:\\test", // Source directory path "", // Destination directory path - "" means current directory opt ); }
The following example code demonstrates how to use the NotFileComparer class to create a logical NOT comparer from a file comparer in a Mirror operation.
using ComponentPro.Compression; using ComponentPro.IO; ... using (Zip arc = new Zip()) { // Open an existing ZIP file. arc.Open("myzip.zip"); // Create a new instance of the QuickSyncOptions class. QuickSyncOptions opt = new QuickSyncOptions(); // Set mirror settings // Files with the same size and different modification date time will not be processed. opt.Comparer = FileComparers.FileSizeComparer & !FileComparers.FileLastWriteTimeComparer; // Equivalent to 'new AndFileComparer(FileComparers.FileSizeComparer, new NotFileComparer(FileComparers.FileLastWriteTimeComparer, FileComparers.FileSizeComparer))' opt.Recursive = true; // Mirror folders. arc.QuickSynchronize( "", // Source directory path - "" means current remote dir "c:\\test", // Destination directory path. true, // Source directory is master. It means contents of "c:\test" will be identical to the remote dir's. opt ); }