Skip to content

Publishing your Project for Delphinus

Alexander Benikowski edited this page Aug 5, 2015 · 37 revisions

Requirements

To publish your project for Delphinus you need to

  • put it on github
  • add an info.json to the repository root
  • add an install.json to the repository root
  • add at least one version (optional) see: Versioning your package
  • add "Delphinus-Support" (without quotes) to your readme within your repository

Info.json

The Info.json contains some meta-information of your package. An example can look like this:

{
	"id": "{420D1B9B-86DB-4B1F-8D84-9CAE0F0EB2F6}",
	"picture": "Logo.jpg",
	"compiler_min": 22,
	"compiler_max": 26,
    "first_release": "name of release",
    "dependencies":
     [
       {
         "id": "{420D1B9B-86DB-4B1F-8D84-9CAE0F0EB2F6}",
         "version_min": "v1.0"
       }
     ]
}

id: Specifies the ID of your package. Once you have specified one, never ever change it. It's used to Identify a package. If you change this ID afterwards, it becomes incompatible to previous versions, as it's recorgnized as a different one. To generate one, use the Delphi IDE by pressing CTRL+Shift+G in a Source-Window or got to http://createguid.com/

picture: (Optional) Specifies a relative path to a jpeg file within your repository, which is presented in the Delphinus GUI for your package.

compiler_min: (Optional) Specifies the minimal supported compiler version, supported by your package

compiler_max: (Optional) Specifies the maximum supported compiler version, supported by your package

first_release: (Optional) Marks the first release, which supports Delphinus. This is usefull, if your repository contains releases, which you created before Delphinus. Those older releases are not visible to the user through Delphinus.

Info: you you do not specify a min or max compiler version, its assumed it runs on all versions (keep in mind that Delphinus is only supported for XE and up). You don't have to specify both. Mostly simply defining compiler_min is what you want, to tell the minimum required compiler version for your package

###dependencies Describes a list of packages, and their required minimal version, which need to be installed before installing your package. If a dependencie is not installed or at a lower version than required, it is installed/updated automatically

id: The Id of the package which is required

version_min: The minimal required version of the package

Install.json

Specifies steps for the installation. An example can look like this:

{
        "search_pathes": 
	[
		{
			"pathes": "Core;Core\\Interfaces",
			"platforms": "Win32;Win64;OSX32"
		}
	],
	"browsing_pathes": 
	[
		{
			"pathes": "Core;Core\\Interfaces",
			"platforms": "Win32;Win64;OSX32"
		}
	],
	
	"source_folders":
	[
		{
			"folder": "source",
			"base": "source",
			"recursive": true,
			"filter": "*;*.*"
		}
	],
	
	"projects":
	[
		{
			"project": "Packages\\DelphiXE6\\Spring4D.Groupproj"
		}
	]
}

search_pathes

Specifies an array of path-entries which are added to the global Search Path in the IDE

pathes: contains the pathes, relative to the source folder(see source_folders), seperated by semicolon ";".

platforms: Specifies the platforms, to add the specified pathes to. If you do not specify this, Win32 is assumed. Currently supported values:

*Win32 *Win64 *OSX32

Mobile might follow one day(if i ever get my hands on a mobile-addon, which i doubt). The identifiers used here, are the same as from a DelphiProject-Files Platforms section.

browsing_pathes

same as search_pathes but adds the specified pathes to the global Browsing Path in the IDE

source_folders

specifies the folders and their files to copy into the source-subdirectory of the installation

folder: specifies the relative path of a folder in your repository to copy into the source-subdirectory

base: specifies the base-part of your relative path, which is cut off. This is usefull if your source is already stored in a subdirectory of your repository called "source". This would lead to a targetpath like (InstallarionDirectory)\source\source, where the first "source" the the components source-folder, and the second one comes from your repository. Example to avoid this:

"folder": "source\\Core",
"base": "source"

this will copy the folder Source\Core to (InstallationDirectory)\source\core

recursive: specifies if it iterates through all subdirectories

filter: specifies a list of filters seperated by semicolon ";" to tell which files to copy. You can use stars "*" as Wildcards, to specify simple masks, like ".pas" or ".dfm". Internally the Delphi function MatchesMask is used.

projects

Specifies a list of projects to compile. If a project is a package, the path of the precompiled DCUs is added to the search_pathes before any other specified search_pathes. If a package includes the Designtime-Flag, it's automatically installed for the IDE. A Project is compiled for the enabled platforms in its Project-File (if no platform is specified, like for XE, Win32 is assumed)

project: specifies a relative path to a .dproj Project-File or a .groupproj GroupProjectfile.

Info: For all elements of search_pathes, browsing_pathes, source_folders and projects, the properties compiler_min, compiler_max (to specify a range, see info.json) and compiler (to specify a specific version) are supported. These allow you to specify specific compilers for each element which results in skipping of an element if the compiler version does not fit.