From f988041f48cb7df2b7b34ee57f8c2e19e75a535a Mon Sep 17 00:00:00 2001 From: Chris Markiewicz Date: Wed, 10 Jul 2024 17:56:38 -0400 Subject: [PATCH] rf(schema): Remove indirection in context description --- src/metaschema.json | 9 +- src/schema/meta/context.yaml | 671 +++++++++++++++++------------------ 2 files changed, 337 insertions(+), 343 deletions(-) diff --git a/src/metaschema.json b/src/metaschema.json index 65ad1646dc..7e7baaf0ee 100644 --- a/src/metaschema.json +++ b/src/metaschema.json @@ -51,13 +51,8 @@ "additionalProperties": false }, "context": { - "type": "object", - "properties": { - "context": { - "description": "The context object is itself JSON schema", - "$ref": "http://json-schema.org/draft-07/schema#" - } - } + "description": "The context object is itself JSON schema", + "$ref": "http://json-schema.org/draft-07/schema#" }, "expression_tests": { "type": "array", diff --git a/src/schema/meta/context.yaml b/src/schema/meta/context.yaml index 99c9765112..280ae7b933 100644 --- a/src/schema/meta/context.yaml +++ b/src/schema/meta/context.yaml @@ -17,353 +17,352 @@ # principle. # --- -context: - type: object - properties: - schema: - description: 'The BIDS specification schema' - type: object - dataset: - description: 'Properties and contents of the entire dataset' - type: object - properties: - dataset_description: - description: 'Contents of /dataset_description.json' - type: object - files: - description: 'List of all files in dataset' - type: array - tree: - description: 'Tree view of all files in dataset' - type: object - ignored: - description: 'Set of ignored files' - type: array - datatypes: - description: 'Data types present in the dataset' - type: array - modalities: - description: 'Modalities present in the dataset' - type: array - subjects: - description: 'Collections of subjects in dataset' - type: object - properties: - sub_dirs: - description: 'Subjects as determined by sub-*/ directories' - type: array - items: - type: string - participant_id: - description: 'The participant_id column of participants.tsv' - type: array - items: - type: string - phenotype: - description: 'The union of participant_id columns in phenotype files' - type: array - items: - type: string - subject: - description: 'Properties and contents of the current subject' - type: object - properties: - sessions: - description: 'Collections of sessions in subject' - type: object - properties: - ses_dirs: - description: 'Sessions as determined by ses-*/ directories' - type: array - items: - type: string - session_id: - description: 'The session_id column of sessions.tsv' - type: array - items: - type: string - phenotype: - description: 'The union of session_id columns in phenotype files' - type: array - items: - type: string - - # Properties of the current file - path: - description: 'Path of the current file' - type: string - size: - description: 'Length of the current file in bytes' - type: integer - entities: - description: 'Entities parsed from the current filename' - type: object - datatype: - description: 'Datatype of current file, for examples, anat' - type: string - suffix: - description: 'Suffix of current file' - type: string - extension: - description: 'Extension of current file including initial dot' - type: string - modality: - description: 'Modality of current file, for examples, MRI' - type: string - - sidecar: - description: 'Sidecar metadata constructed via the inheritance principle' - type: object - associations: - # Note that this is not intended to be an exhaustive list of associated files - # or to expose every attribute of those files. It is specifically those files - # and attributes for which a rule needs to be applied from an originating file. - description: | - Associated files, indexed by suffix, selected according to the inheritance principle - type: object - properties: - events: - description: 'Events file' - type: object - properties: - path: - description: 'Path to associated events file' - type: string - onset: - description: 'Contents of the onset column' - type: array - items: - type: string - aslcontext: - description: 'ASL context file' - type: object - properties: - path: - description: 'Path to associated aslcontext file' +type: object +properties: + schema: + description: 'The BIDS specification schema' + type: object + dataset: + description: 'Properties and contents of the entire dataset' + type: object + properties: + dataset_description: + description: 'Contents of /dataset_description.json' + type: object + files: + description: 'List of all files in dataset' + type: array + tree: + description: 'Tree view of all files in dataset' + type: object + ignored: + description: 'Set of ignored files' + type: array + datatypes: + description: 'Data types present in the dataset' + type: array + modalities: + description: 'Modalities present in the dataset' + type: array + subjects: + description: 'Collections of subjects in dataset' + type: object + properties: + sub_dirs: + description: 'Subjects as determined by sub-*/ directories' + type: array + items: type: string - n_rows: - description: 'Number of rows in aslcontext.tsv' - type: integer - volume_type: - description: 'Contents of the volume_type column' - type: array - items: - type: string - m0scan: - description: 'M0 scan file' - type: object - properties: - path: - description: 'Path to associated M0 scan file' + participant_id: + description: 'The participant_id column of participants.tsv' + type: array + items: type: string - magnitude: - description: 'Magnitude image file' - type: object - properties: - path: - description: 'Path to associated magnitude file' + phenotype: + description: 'The union of participant_id columns in phenotype files' + type: array + items: type: string - magnitude1: - description: 'Magnitude1 image file' - type: object - properties: - path: - description: 'Path to associated magnitude1 file' + subject: + description: 'Properties and contents of the current subject' + type: object + properties: + sessions: + description: 'Collections of sessions in subject' + type: object + properties: + ses_dirs: + description: 'Sessions as determined by ses-*/ directories' + type: array + items: type: string - bval: - description: 'B value file' - type: object - properties: - path: - description: 'Path to associated bval file' + session_id: + description: 'The session_id column of sessions.tsv' + type: array + items: type: string - n_cols: - description: 'Number of columns in bval file' - type: integer - n_rows: - description: 'Number of rows in bval file' - type: integer - values: - description: 'B-values contained in bval file' - type: array - items: - type: number - bvec: - description: 'B vector file' - type: object - properties: - path: - description: 'Path to associated bvec file' + phenotype: + description: 'The union of session_id columns in phenotype files' + type: array + items: type: string - n_cols: - description: 'Number of columns in bvec file' - type: integer - n_rows: - description: 'Number of rows in bvec file' - type: integer - channels: - description: 'Channels file' - type: object - properties: - path: - description: 'Path to associated channels file' + + # Properties of the current file + path: + description: 'Path of the current file' + type: string + size: + description: 'Length of the current file in bytes' + type: integer + entities: + description: 'Entities parsed from the current filename' + type: object + datatype: + description: 'Datatype of current file, for examples, anat' + type: string + suffix: + description: 'Suffix of current file' + type: string + extension: + description: 'Extension of current file including initial dot' + type: string + modality: + description: 'Modality of current file, for examples, MRI' + type: string + + sidecar: + description: 'Sidecar metadata constructed via the inheritance principle' + type: object + associations: + # Note that this is not intended to be an exhaustive list of associated files + # or to expose every attribute of those files. It is specifically those files + # and attributes for which a rule needs to be applied from an originating file. + description: | + Associated files, indexed by suffix, selected according to the inheritance principle + type: object + properties: + events: + description: 'Events file' + type: object + properties: + path: + description: 'Path to associated events file' + type: string + onset: + description: 'Contents of the onset column' + type: array + items: type: string - type: - description: 'Contents of the type column' - type: array - items: - type: string - coordsystem: - description: 'Coordinate system file' - type: object - properties: - path: - description: 'Path to associated coordsystem file' + aslcontext: + description: 'ASL context file' + type: object + properties: + path: + description: 'Path to associated aslcontext file' + type: string + n_rows: + description: 'Number of rows in aslcontext.tsv' + type: integer + volume_type: + description: 'Contents of the volume_type column' + type: array + items: type: string - # The following properties are populated if the current file is of an appropriate type - columns: - description: 'TSV columns, indexed by column header, values are arrays with column contents' - type: object - additionalProperties: - type: array - json: - description: 'Contents of the current JSON file' - type: object - gzip: - description: 'Parsed contents of gzip header' - type: object - properties: - timestamp: - description: 'Modification time, unix timestamp' - type: number - filename: - description: 'Filename' - type: string - comment: - description: 'Comment' - type: string - nifti_header: - name: 'NIfTI Header' - description: 'Parsed contents of NIfTI header referenced elsewhere in schema.' - type: object - properties: - dim_info: - name: 'Dimension Information' - description: 'Metadata about dimensions data.' - type: object - properties: - freq: - name: 'Frequency' - description: 'These fields encode which spatial dimension (1, 2, or 3).' - type: integer - phase: - name: 'Phase' - description: 'Corresponds to which acquisition dimension for MRI data.' - type: integer - slice: - name: 'Slice' - description: 'Slice dimensions.' - type: integer - dim: - name: 'Data Dimensions' - description: 'Data seq dimensions.' - type: array - minItems: 8 - maxItems: 8 - items: + m0scan: + description: 'M0 scan file' + type: object + properties: + path: + description: 'Path to associated M0 scan file' + type: string + magnitude: + description: 'Magnitude image file' + type: object + properties: + path: + description: 'Path to associated magnitude file' + type: string + magnitude1: + description: 'Magnitude1 image file' + type: object + properties: + path: + description: 'Path to associated magnitude1 file' + type: string + bval: + description: 'B value file' + type: object + properties: + path: + description: 'Path to associated bval file' + type: string + n_cols: + description: 'Number of columns in bval file' type: integer - pixdim: - name: 'Pixel Dimension' - description: 'Grid spacings (unit per dimension).' - type: array - minItems: 8 - maxItems: 8 - items: - type: number - shape: - name: 'Data shape' - description: 'Data array shape, equal to dim[1:dim[0] + 1]' - type: array - minItems: 0 - maxItems: 7 - items: + n_rows: + description: 'Number of rows in bval file' type: integer - voxel_sizes: - name: 'Voxel sizes' - description: 'Voxel sizes, equal to pixdim[1:dim[0] + 1]' - type: array - minItems: 0 - maxItems: 7 - items: - type: number - xyzt_units: - name: 'XYZT Units' - description: 'Units of pixdim[1..4]' - type: object - properties: - xyz: - name: 'XYZ Units' - description: 'String representing the unit of voxel spacing.' - type: string - enum: - - $ref: objects.enums.unknown.value - # TODO: Add definitions for these values. (perhaps don't specify) - - 'meter' - - 'mm' - - 'um' - t: - name: 'Time Unit' - description: 'String representing the unit of inter-volume intervals.' + values: + description: 'B-values contained in bval file' + type: array + items: + type: number + bvec: + description: 'B vector file' + type: object + properties: + path: + description: 'Path to associated bvec file' + type: string + n_cols: + description: 'Number of columns in bvec file' + type: integer + n_rows: + description: 'Number of rows in bvec file' + type: integer + channels: + description: 'Channels file' + type: object + properties: + path: + description: 'Path to associated channels file' + type: string + type: + description: 'Contents of the type column' + type: array + items: type: string - enum: - - $ref: objects.enums.unknown.value - # TODO: Add definitions for these values. (perhaps don't specify) - - 'sec' - - 'msec' - - 'usec' - qform_code: - name: 'qform code' - description: 'Use of the quaternion fields.' - type: integer - sform_code: - name: 'sform code' - description: 'Use of the affine fields.' + coordsystem: + description: 'Coordinate system file' + type: object + properties: + path: + description: 'Path to associated coordsystem file' + type: string + # The following properties are populated if the current file is of an appropriate type + columns: + description: 'TSV columns, indexed by column header, values are arrays with column contents' + type: object + additionalProperties: + type: array + json: + description: 'Contents of the current JSON file' + type: object + gzip: + description: 'Parsed contents of gzip header' + type: object + properties: + timestamp: + description: 'Modification time, unix timestamp' + type: number + filename: + description: 'Filename' + type: string + comment: + description: 'Comment' + type: string + nifti_header: + name: 'NIfTI Header' + description: 'Parsed contents of NIfTI header referenced elsewhere in schema.' + type: object + properties: + dim_info: + name: 'Dimension Information' + description: 'Metadata about dimensions data.' + type: object + properties: + freq: + name: 'Frequency' + description: 'These fields encode which spatial dimension (1, 2, or 3).' + type: integer + phase: + name: 'Phase' + description: 'Corresponds to which acquisition dimension for MRI data.' + type: integer + slice: + name: 'Slice' + description: 'Slice dimensions.' + type: integer + dim: + name: 'Data Dimensions' + description: 'Data seq dimensions.' + type: array + minItems: 8 + maxItems: 8 + items: type: integer - ome: - name: 'Open Microscopy Environment fields' - description: 'Parsed contents of OME-XML header, which may be found in OME-TIFF or OME-ZARR files' - type: object - properties: - PhysicalSizeX: - name: 'PhysicalSizeX' - description: 'Pixels / @PhysicalSizeX' - type: number - PhysicalSizeY: - name: 'PhysicalSizeY' - description: 'Pixels / @PhysicalSizeY' - type: number - PhysicalSizeZ: - name: 'PhysicalSizeZ' - description: 'Pixels / @PhysicalSizeZ' + pixdim: + name: 'Pixel Dimension' + description: 'Grid spacings (unit per dimension).' + type: array + minItems: 8 + maxItems: 8 + items: type: number - PhysicalSizeXUnit: - name: 'PhysicalSizeXUnit' - description: 'Pixels / @PhysicalSizeXUnit' - type: string - PhysicalSizeYUnit: - name: 'PhysicalSizeYUnit' - description: 'Pixels / @PhysicalSizeYUnit' - type: string - PhysicalSizeZUnit: - name: 'PhysicalSizeZUnit' - description: 'Pixels / @PhysicalSizeZUnit' - type: string - tiff: - name: 'TIFF' - description: 'TIFF file format metadata' - type: object - properties: - version: - name: 'Version' - description: 'TIFF file format version (the second 2-byte block)' + shape: + name: 'Data shape' + description: 'Data array shape, equal to dim[1:dim[0] + 1]' + type: array + minItems: 0 + maxItems: 7 + items: type: integer + voxel_sizes: + name: 'Voxel sizes' + description: 'Voxel sizes, equal to pixdim[1:dim[0] + 1]' + type: array + minItems: 0 + maxItems: 7 + items: + type: number + xyzt_units: + name: 'XYZT Units' + description: 'Units of pixdim[1..4]' + type: object + properties: + xyz: + name: 'XYZ Units' + description: 'String representing the unit of voxel spacing.' + type: string + enum: + - $ref: objects.enums.unknown.value + # TODO: Add definitions for these values. (perhaps don't specify) + - 'meter' + - 'mm' + - 'um' + t: + name: 'Time Unit' + description: 'String representing the unit of inter-volume intervals.' + type: string + enum: + - $ref: objects.enums.unknown.value + # TODO: Add definitions for these values. (perhaps don't specify) + - 'sec' + - 'msec' + - 'usec' + qform_code: + name: 'qform code' + description: 'Use of the quaternion fields.' + type: integer + sform_code: + name: 'sform code' + description: 'Use of the affine fields.' + type: integer + ome: + name: 'Open Microscopy Environment fields' + description: 'Parsed contents of OME-XML header, which may be found in OME-TIFF or OME-ZARR files' + type: object + properties: + PhysicalSizeX: + name: 'PhysicalSizeX' + description: 'Pixels / @PhysicalSizeX' + type: number + PhysicalSizeY: + name: 'PhysicalSizeY' + description: 'Pixels / @PhysicalSizeY' + type: number + PhysicalSizeZ: + name: 'PhysicalSizeZ' + description: 'Pixels / @PhysicalSizeZ' + type: number + PhysicalSizeXUnit: + name: 'PhysicalSizeXUnit' + description: 'Pixels / @PhysicalSizeXUnit' + type: string + PhysicalSizeYUnit: + name: 'PhysicalSizeYUnit' + description: 'Pixels / @PhysicalSizeYUnit' + type: string + PhysicalSizeZUnit: + name: 'PhysicalSizeZUnit' + description: 'Pixels / @PhysicalSizeZUnit' + type: string + tiff: + name: 'TIFF' + description: 'TIFF file format metadata' + type: object + properties: + version: + name: 'Version' + description: 'TIFF file format version (the second 2-byte block)' + type: integer