================================================================================

DELPHIDABBLER CODESNIP v4 STANDARD EDITION README

================================================================================


What is CodeSnip?
================================================================================

DelphiDabbler CodeSnip 4 is a code snippets repository targetted at the Pascal /
Delphi programming languages. It can download and display code snippets from the
online DelphiDabbler Code Snippets database as well as maintain a database of
user-defined snippets.

It displays details of each snippet in the database and can test-compile them
with each installed Win32 version of Delphi from Delphi 2 to Delphi 12.x and
Free Pascal.

Compilable Pascal units can be created that contain selected snippets.


CodeSnip Editions
================================================================================

This document relates to the STANDARD edition of CodeSnip. This edition is
installed on the user's computer using a standard Windows installer and which
records its presence in the registry and stores data in the system's application
and user data directories.

There is also a portable edition of the program. This edition can be run from
any writeable removable storage medium (e.g. a USB memory stick) or from any
folder on the computer's hard disk. It makes no changes to the host computer.
This edition has no installer and is simply copied to the required location.

You can run both the portable and standard editions together on the same
computer and even run them at the same time. However, each edition maintains its
own settings and keeps its own copies of the snippets databases. To share user
defined snippets you must export them from one edition and import into the
other. CodeSnip provides no mechanism for keeping them synchronised.


Installation
================================================================================

CodeSnip requires Windows 2000 or later. It also requires MS Internet Explorer 6
or later, although IE 8, 9 or 10 are strongly recommended. Note that recent
releases have only been tested on Windows 11.

You will need administrator privileges to run the setup program. If you are
using a non-admin user account on Windows 2000 or XP you should run setup as
administrator. By default Windows Vista to Windows 11 will require admin
privileges and setup will attempt to elevate the process if required. If UAC
prompts are disabled you must run setup as administrator.

CodeSnip v4 will install alongside any v3 or earlier release that may already be
installed. If you want to replace the earlier version simply uninstall it in the
usual way. Uninstalling v3 or earlier after installing v4 will have no adverse
affect on v4.

CodeSnip's installation program is named codesnip-setup-4.x.x.exe, where x.x
is the program's minor version number. The install program is distributed in a
zip file.

Close any running instance of CodeSnip, run the install program then follow the
on-screen instructions.

The installer makes the following changes to your system:

+ The main program's executable file and documentation are installed into the
  chosen install folder (%ProgramFiles%\DelphiDabbler\CodeSnip-4 by default).

+ Files required by the uninstaller are stored in the main installation's Uninst
  sub-folder.

+ The program's uninstall information is registered with the "Installed App"
  (a.k.a. "Apps and Features", a.k.a. "Programs and Features", a.k.a. "Add /
  Remove Programs") control panel app.

+ A program group may be created in the start menu (optional).

+ A %ProgramData%\DelphiDabbler\CodeSnip.4 folder is created. A configuration
  file is stored in the folder. If the online database is installed, it will be
  copied to the "Database" sub-folder.

+ An %AppData%\DelphiDabbler\CodeSnip.4 folder is also created. This is used to
  hold a file that stores per-user configuration data and, sometimes, another
  file that records any favourite snippets. A "UserDatabase" sub-folder is used
  to store any user defined snippets. These folders are created when CodeSnip is
  first run.

  Users can move the user defined snippets data from the "UserDatabase"
  sub-folder to another location, in which case "UserDatabase" will not be
  present. You might want to do this to place the snippets data in a folder that
  will be backed up, e.g. a Dropbox or GoogleDrive sub-directory.

If you are updating to CodeSnip 4 from version 3 or earlier, CodeSnip will give
you the option of bringing forward your old settings and / or user defined
database. This happens the first time v4 is run for each user.


Uninstallation
================================================================================

CodeSnip can be uninstalled using your version of Windows' application
uninstaller, run from Control Panel. Alternatively you can choose "Uninstall
DelphiDabbler CodeSnip" from the program's start menu group.

Administrator privileges will be required to uninstall CodeSnip.

The uninstall program will delete any local copy of the online Code Snippets
database but will leave any user defined database, configuration data and
favourites intact. To remove user defined databases and configuration data,
delete the %AppData%\DelphiDabbler\CodeSnip.4 directory and all its contents for
each user who ran CodeSnip. If any user has moved the user database directory
those directories also need to be deleted.


Downloading & Updating the Code Snippets Database
================================================================================

The online DelphiDabbler Code Snippets database is not installed with the
program.

CodeSnip's start-up screen shows details of any installed databases. If there is
no copy of the online database then a link is displayed that enables the
database to be installed. This link opens the "Install or Update DelphiDabbler
Snippets Database" wizard dialogue box. The dialogue box explains how to
download and install the database.

You can download or update the database later by opening the same dialogue box
using the "Database | Install or Update DelphiDabbler Snippets Database" menu
option.

During installation the setup program will detect if an older database version
is present and will give the option to carry it forward. When setup completes it
checks for the presence of the database and puts up a message if it is not
present.

Database updates will apply to all users of the computer the next time they
start CodeSnip.


Configuring CodeSnip to Work With Your Compilers
================================================================================

A feature of CodeSnip is its ability to test compile snippets with any installed
Windows 32 version of Delphi (from Delphi 2 to Delphi.x) and FreePascal,
providing some simple rules are followed.

When CodeSnip is first installed it knows nothing about the available compilers
and so test compilations cannot be performed. If any supported Delphi compiler
is detected when the program is first run you will be given the option of
registering it. This does not work for Free Pascal.

You can also tell CodeSnip about the available compilers by using the "Tools |
Configure Compilers" menu option. The resulting dialogue can automatically
detect all installed versions of supported Delphi compilers at the click of a
button. Free Pascal, where installed, must be set up manually. The Welcome page
displays a list of compilers it has been configured to work with.

Compilers that do not use English as their output language will need further
configuration. See the help file for information (look up "configure compilers
dialogue" in the help file index).

Each user can configure compilers differently.

Delphi XE2 and later may need to be configured to search for required units in
the correct namespaces. This is explained in the Add/Edit Snippet Dialogue Box
help topic and in the FAQ at
https://github.com/delphidabbler/codesnip-faq/blob/master/UsingCodeSnip.md#faq-7

Any type of snippet other than "freeform" can be test compiled.


Updating the Program
================================================================================

Updates are published on GitHub. See
https://github.com/delphidabbler/codesnip/releases

News of new updates is published on the CodeSnip Blog:
https://codesnip-app.blogspot.com/.


Known Installation and Upgrading Issues
================================================================================

+ Any syntax highlighter customisation you have made will be lost if you are
  updating from any v2 or earlier.

  You will need to redo any customisation using the "Syntax Highlighter" page of
  the Preferences dialogue box displayed from the "Tools | Preferences" menu
  option.

+ Your source code formatting preferences will have been lost if you are
  updating from v1.7.4 or earlier.

  You will need to reconfigure them using the "Code Formatting" page of the
  Preferences dialogue box displayed from the "Tools | Preferences" menu option.

+ If you have updated to CodeSnip v4.2.0 or later from any earlier v4 release,
  and then run the earlier version of the program again, its saved main window
  state, size, position and layout will have been lost and the program will
  display in its default size.

+ If you have updated to CodeSnip v4.3.0 or later from v4.2.x or earlier any -NS
  command line options you have specified on the "Switches" (aka "Command Line")
  tab of the Configure Compilers dialogue box for Delphi XE2 or later will be
  removed and equivalent entries will have been made on the "Namespaces" tab.

+ CodeSnip v4.16.0 and later cannot be registered. Any previous registration
  information may be lost.


License & Disclaimer
================================================================================

CodeSnip is made available under the terms of the Mozilla Public License v2.0.
The license is explained in full in the file License.html that is installed with
CodeSnip. A summary of the license can be viewed from the "Help | License" menu
option.

CodeSnip is supplied on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
express or implied. See License.html for details.

The source code of any snippet managed by CodeSnip, whether from the
DelphiDabbler Code Snippets Database or the user database, is used WITHOUT
WARRANTY OF ANY KIND, either express or implied. The code is used entirely at
the user's own risk.

The snippets from the DelphiDabbler Code Snippets Database are open source. See
the "About The Database" tab of the About dialogue box for details of the
applicable license. (You can display the About box from the "Help" menu.)

The user is responsible to ensure that any code snippets managed by CodeSnip are
used in accordance with any applicable license.


Source Code
================================================================================

CodeSnip's source code is freely available. For details of how to obtain the
source see the FAQ at
https://github.com/delphidabbler/codesnip-faq/blob/master/SourceCode.md#faq-1

The standard edition of CodeSnip shares the same source code base with the
portable edition.

The original source code of v4 is released under the Mozilla Public license
v2.0 (see https://www.mozilla.org/MPL/) and other open source licenses. See the
file "License.html" in the "Docs" directory of the repository for full licensing
information.


Bugs & Feature Requests
================================================================================

Please do report any bugs you find. Suggestions for new features are also
welcomed.

Both bug reports and feature requests are made using the GitHub issue tracker
(GitHub account required). For details about using the issue tracker see
https://github.com/delphidabbler/codesnip/blob/master/CONTRIBUTING.md#issues.


FAQs
================================================================================

There are Frequently Asked Questions pages for CodeSnip on the web, at
https://github.com/delphidabbler/codesnip-faq/blob/master/README.md


Privacy
================================================================================

From v4.16.0 CodeSnip neither stores nor transmits any personally identifiable
data.

Do note though that CodeSnip can display web pages via your default web browser,
but only in response to user input. No guarantee is made about any personal data
collected by such web pages.


Thanks
================================================================================

Thanks to:

+ David Mustard and Bill Miller for providing information that enabled me to add
  Delphi 2007 and Delphi 2009 support, respectively, to the program.

+ geoffsmith82 and an anonymous contributor for information about getting
  CodeSnip to work with Delphi XE2.

+ The authors of the third party source code and images used by the program. See
  the program's about box or License.html for details.

+ Various contributors to the DelphiDabbler Code Snippets database. Names of
  contributors are listed in the program's About Box (use the "Help | About"
  menu option then select the "About the Database" tab). The list will be empty
  if the Code Snippets Database has not been installed.


================================================================================