Infrastructure/Project Metadata: Difference between revisions
Dependency data was never introduced for this, remove from docs |
|||
Line 31: | Line 31: | ||
; <code>groups</code> | ; <code>groups</code> | ||
: This is set to an object describing the group layout of the layers described above. See [[#Grouping syntax|Grouping syntax]] for more details. | : This is set to an object describing the group layout of the layers described above. See [[#Grouping syntax|Grouping syntax]] for more details. | ||
==== Grouping syntax ==== | ==== Grouping syntax ==== | ||
Line 74: | Line 71: | ||
Using the example given above, the <code>kde/kde-workspace</code> repository would match its own group, <code>kde/kdeutils/kcalc</code> would match the <code>kde/*</code> group, while <code>kdesupport/phonon/phonon</code> would not match any group at all (and therefore would get default branch names, whatever 'default' means for that script). | Using the example given above, the <code>kde/kde-workspace</code> repository would match its own group, <code>kde/kdeutils/kcalc</code> would match the <code>kde/*</code> group, while <code>kdesupport/phonon/phonon</code> would not match any group at all (and therefore would get default branch names, whatever 'default' means for that script). | ||
=== Implementation notes === | === Implementation notes === | ||
Line 172: | Line 76: | ||
Some important notes for implementors (and eventual editors of this file): | Some important notes for implementors (and eventual editors of this file): | ||
* JSON does not support comments. | * JSON does not support comments. | ||
* '''JSON DOES NOT SUPPORT COMMENTS'''. | * '''JSON DOES NOT SUPPORT COMMENTS'''. | ||
Line 183: | Line 82: | ||
* The user/implementation keys may appear in any JSON object, not just the top-level object. | * The user/implementation keys may appear in any JSON object, not just the top-level object. | ||
** ''Note'': This means that the user/implementation keys may '''not''' appear in JSON arrays, such as the top-level <code>layers</code> array. | ** ''Note'': This means that the user/implementation keys may '''not''' appear in JSON arrays, such as the top-level <code>layers</code> array. | ||
** It is possible that these "comment objects" may need to be reserved to only specific JSON objects, as implementations will otherwise have to filter them out of things like <code> | ** It is possible that these "comment objects" may need to be reserved to only specific JSON objects, as implementations will otherwise have to filter them out of things like <code>layers</code> or <code>groups</code>. However as this is meant to be human-editable it seems wise to assume that this type of comment will eventually be left, and accordingly to program defensively. | ||
** Additionally some implementation-specific data might actually be needed within those objects and not at the top-level. | ** Additionally some implementation-specific data might actually be needed within those objects and not at the top-level. | ||
** Therefore implementations should be sure to first filter out all user/implementation comments from a JSON objects, if they will use all keys within that object (e.g. <code>groups</code> or <code> | ** Therefore implementations should be sure to first filter out all user/implementation comments from a JSON objects, if they will use all keys within that object (e.g. <code>groups</code> or <code>layers</code>). | ||
* All other key names are reserved for this specification. | * All other key names are reserved for this specification. | ||
Line 204: | Line 103: | ||
"groups" : { | "groups" : { | ||
"kde/ | "kde/*" : { | ||
"stable-qt4": "KDE/4. | "stable-qt4": "KDE/4.13", | ||
"latest-qt4": " | "latest-qt4": "master", | ||
"kf5-qt5": " | "kf5-qt5": "frameworks" | ||
}, | |||
"kde/workspace/kde-workspace" : { | |||
"stable-qt4": "KDE/4.13", | |||
"latest-qt4": "KDE/4.13", | |||
"kde/ | "kf5-qt5": "" | ||
" | |||
} | } | ||
} | } | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> |
Revision as of 00:25, 12 April 2014
KDE Project Metadata
Metadata describing the Git repositories that make up KDE software, and the relationships between those repositories, are contained in two different sources.
- A KDE Projects Management website, where various data about individual repos can be altered by git repository maintainers, including which branches are considered 'stable' and 'development' branches for i18n purposes.
- Metadata about the relationships between individual repositories are kept in a separate git repository,
kde-build-metadata
.
kde-build-metadata
The kde-build-metadata
repository contains several files which can be used by scripts and automated programs to properly handle the KDE git repositories. As of this writing there are several files that make up this repository:
- build-script-ignore: This file contains a list of git repositories that should be ignored by scripts used to build the KDE source repositories. Empty lines and comments (prefixed by a
#
) are permitted. Each other line should be the full kde-project path of a module to ignore. Most examples are for modules that simply have nothing to build and install, but other uses include convenience modules that duplicate functionality handled in other source code modules. - dependency-data: This file contains a list of dependencies between KDE git repositories. It is used by the kdesrc-build build script, and the continuous integration infrastructure.
Logical module grouping
In order to make it easy for the various groups building KDE software to get the version they wish, there is a proposal to add the concept of logical module groups so that scripts may automatically select the most appropriate branch for a given individual git repository.
The current proposal is to use a JSON file, with the following structure:
A top-level object, with the following key-value pairs:
version
- Will be set to the version supported by conforming scripts. This documentation documents version
0
(the number, not a string). It is intended that the version is only increased for changes that cannot be made in a backward-compatible fashion. Scripts should check that the version is set to a supported version and fail if not.
layers
- Will be set to an array of the logical module groupings that are available for use. Currently this is
stable-qt4
,latest-qt4
,kf5-qt5
, but this can change as needed. Scripts should allow groupings only from this array.
groups
- This is set to an object describing the group layout of the layers described above. See Grouping syntax for more details.
Grouping syntax
As described above, the groups
key has an object as its value, which itself contains key/value pairs, where each key describes the kde-project module path to operate on, with wildcards being acceptable. The value for this path is another object, describing the layers : branch name mappings for repositories included in the given kde-project module path.
For example:
{
/* .... */
"kde/*": {
"stable-qt4": "KDE/4.11",
"latest-qt4": "master",
"kf5-qt5": "frameworks"
},
"kde/kde-workspace" : {
"stable-qt4": "KDE/4.11",
"latest-qt4": "KDE/4.11",
"kf5-qt5": "master"
}
/* .... */
}
This shows that for kde/kde-workspace
(and only for this module, since there are no wildcards), that stable-qt4
and latest-qt4
logical groupings both pull from the remote git branch called KDE/4.11
, while kf5-qt5
developers / scripts should use the remote git branch called master
Selecting a logical group
A logical group may apply to multiple independent git repositories. However, each individual git repository will only match a single logical group (or none at all). In other words, there is no "cascading", so if a layer is not defined within that logical group there is no fallback to a more-generic logical group.
When deciding how to select a logical group, the rule is that the most specific possible match is selected. A *
wildcard may be used to stand in for a path component, and all remaining components on the module path. In other words, kde/*
would find all kde-project modules that begin with kde/
, even those with many intermediate path components, e.g. kde/kdelibs/nepomuk-core
.
An easy implementation of the wildcard logic (once we've failed to find an exact match) is to take the list of logical group specifiers, and sort them all by length in descending order. Search each logical group specifier in that order, seeing if the module path being considered starts with the full specifier (except the wildcard). The first specifier where this is true is chosen. Do not forget to handle the case of a specifier consisting of nothing but '*', which will match everything (though, this is probably a bad idea to include in the file itself!)
If a logical group is matched but does not define a branch name to use for a layer, the script should assume a branch name to use by default. This normally means master
, but the idea is that a failure to find a module name in a logical group will not completely stop a build, since many kde-project repositories will not differentiate between different development layers in this fashion.
Using the example given above, the kde/kde-workspace
repository would match its own group, kde/kdeutils/kcalc
would match the kde/*
group, while kdesupport/phonon/phonon
would not match any group at all (and therefore would get default branch names, whatever 'default' means for that script).
Implementation notes
Some important notes for implementors (and eventual editors of this file):
- JSON does not support comments.
- JSON DOES NOT SUPPORT COMMENTS.
- With that in mind, key names starting with "__" (2 underscores) should be reserved to allow for user comments. No special handling is needed on the part of implementations, though they may treat any such key/value pairs as comments.
- Key names starting with "_[a-zA-Z]" (1 underscore and an ASCII charset letter) are reserved for implementation-specific data. The part of the key name after the leading underscore should be the implementation name (it is required only that the key be namespaced, the key name can contain additional data beyond the implementation name). Nothing shall be assumed regarding the type or contents of the value. Implementors are reminded to consider using other top-level files within kde-build-metadata instead of storing data within this JSON file.
- The user/implementation keys may appear in any JSON object, not just the top-level object.
- Note: This means that the user/implementation keys may not appear in JSON arrays, such as the top-level
layers
array. - It is possible that these "comment objects" may need to be reserved to only specific JSON objects, as implementations will otherwise have to filter them out of things like
layers
orgroups
. However as this is meant to be human-editable it seems wise to assume that this type of comment will eventually be left, and accordingly to program defensively. - Additionally some implementation-specific data might actually be needed within those objects and not at the top-level.
- Therefore implementations should be sure to first filter out all user/implementation comments from a JSON objects, if they will use all keys within that object (e.g.
groups
orlayers
).
- Note: This means that the user/implementation keys may not appear in JSON arrays, such as the top-level
- All other key names are reserved for this specification.
Example
This is an example of a full shell JSON file.
{
"version" : 0,
"__README": "http://community.kde.org/Infrastructure/Project_Metadata#kde-build-metadata",
"layers" : [
"stable-qt4",
"latest-qt4",
"kf5-qt5"
],
"groups" : {
"kde/*" : {
"stable-qt4": "KDE/4.13",
"latest-qt4": "master",
"kf5-qt5": "frameworks"
},
"kde/workspace/kde-workspace" : {
"stable-qt4": "KDE/4.13",
"latest-qt4": "KDE/4.13",
"kf5-qt5": ""
}
}
}