mirror of
https://gitlab.com/mbunkus/mkvtoolnix.git
synced 2025-01-08 03:02:38 +00:00
545 lines
18 KiB
JSON
545 lines
18 KiB
JSON
{
|
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
"id": "https://mkvtoolnix.download/doc/mkvmerge-identification-output-schema-v17.json",
|
|
"title": "mkvmerge identification output",
|
|
"description": "The JSON output produced by mkvmerge's file identification mode",
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"attachments": {
|
|
"description": "an array describing the attachments found if any",
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"content_type": {
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"description": {
|
|
"type": "string"
|
|
},
|
|
"file_name": {
|
|
"type": "string"
|
|
},
|
|
"id": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"size": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"properties": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"uid": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
}
|
|
},
|
|
"additionalProperties": false
|
|
},
|
|
"type": {
|
|
"type": "string"
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"file_name",
|
|
"id",
|
|
"properties",
|
|
"size"
|
|
]
|
|
}
|
|
},
|
|
"chapters": {
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"num_entries": {
|
|
"type": "integer"
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"num_entries"
|
|
]
|
|
}
|
|
},
|
|
"container": {
|
|
"additionalProperties": false,
|
|
"description": "information about the identified container",
|
|
"type": "object",
|
|
"properties": {
|
|
"properties": {
|
|
"additionalProperties": false,
|
|
"description": "additional properties for the container varying by container format",
|
|
"type": "object",
|
|
"properties": {
|
|
"container_type": {
|
|
"description": "A unique number identifying the container type that's supposed to stay constant over all future releases of MKVToolNix",
|
|
"type": "integer",
|
|
"minLength": 1
|
|
},
|
|
"date_local": {
|
|
"description": "The muxing date in ISO 8601 format (in local time zone)",
|
|
"type": "string",
|
|
"pattern": "^[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}([+-][0-9]{2}:[0-9]{2}|Z)$"
|
|
},
|
|
"date_utc": {
|
|
"description": "The muxing date in ISO 8601 format (in UTC)",
|
|
"type": "string",
|
|
"pattern": "^[0-9]{4}-[0-9]{2}-[0-9]{2}T[0-9]{2}:[0-9]{2}:[0-9]{2}([+-][0-9]{2}:[0-9]{2}|Z)$"
|
|
},
|
|
"duration": {
|
|
"description": "The file's/segment's duration in nanoseconds",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"is_providing_timestamps": {
|
|
"description": "States whether or not the container has timestamps for the packets (e.g. Matroska, MP4) or not (e.g. SRT, MP3)",
|
|
"type": "boolean"
|
|
},
|
|
"muxing_application": {
|
|
"description": "A Unicode string containing the name and possibly version of the low-level library or application that created the file",
|
|
"type": "string"
|
|
},
|
|
"next_segment_uid": {
|
|
"description": "A hexadecimal string of the next segment's UID (only for Matroska files)",
|
|
"type": "string",
|
|
"minLength": 32,
|
|
"maxLength": 32
|
|
},
|
|
"other_file": {
|
|
"description": "An array of names of additional files processed as well",
|
|
"type": "array",
|
|
"items": {
|
|
"type": "string"
|
|
}
|
|
},
|
|
"playlist": {
|
|
"description": "States whether or not the identified file is a playlist (e.g. MPLS) referring to several other files",
|
|
"type": "boolean"
|
|
},
|
|
"playlist_chapters": {
|
|
"description": "The number of chapters in a playlist if it is a one",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"playlist_duration": {
|
|
"description": "The total duration in nanoseconds of all files referenced by the playlist if it is a one",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"playlist_file": {
|
|
"description": "An array of file names the playlist contains",
|
|
"type": "array",
|
|
"items": {
|
|
"type": "string"
|
|
}
|
|
},
|
|
"playlist_size": {
|
|
"description": "The total size in bytes of all files referenced by the playlist if it is a one",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"previous_segment_uid": {
|
|
"description": "A hexadecimal string of the previous segment's UID (only for Matroska files)",
|
|
"type": "string",
|
|
"minLength": 32,
|
|
"maxLength": 32
|
|
},
|
|
"programs": {
|
|
"description": "A container describing multiple programs multiplexed into the source file, e.g. multiple programs in one DVB transport stream",
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"description": "Properties describing a single program",
|
|
"type": "object",
|
|
"properties": {
|
|
"program_number": {
|
|
"description": "A unique number identifying a set of tracks that belong together; used e.g. in DVB for multiplexing multiple stations within a single transport stream",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"service_name": {
|
|
"description": "The name of a service provided by this program, e.g. a TV channel name such as 'arte HD'",
|
|
"type": "string"
|
|
},
|
|
"service_provider": {
|
|
"description": "The name of the provider of the service provided by this program, e.g. a TV station name such as 'ARD'",
|
|
"type": "string"
|
|
}
|
|
}
|
|
}
|
|
},
|
|
"segment_uid": {
|
|
"description": "A hexadecimal string of the segment's UID (only for Matroska files)",
|
|
"type": "string",
|
|
"minLength": 32,
|
|
"maxLength": 32
|
|
},
|
|
"title": {
|
|
"type": "string"
|
|
},
|
|
"writing_application": {
|
|
"description": "A Unicode string containing the name and possibly version of the high-level application that created the file",
|
|
"type": "string"
|
|
}
|
|
},
|
|
"additionalProperties": false
|
|
},
|
|
"recognized": {
|
|
"description": "States whether or not mkvmerge knows about the format",
|
|
"type": "boolean"
|
|
},
|
|
"supported": {
|
|
"description": "States whether or not mkvmerge can read the format",
|
|
"type": "boolean"
|
|
},
|
|
"type": {
|
|
"description": "A human-readable description/name for the container format",
|
|
"type": "string",
|
|
"minLength": 1
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"recognized",
|
|
"supported"
|
|
]
|
|
},
|
|
"errors": {
|
|
"type": "array",
|
|
"items": {
|
|
"type": "string"
|
|
}
|
|
},
|
|
"file_name": {
|
|
"description": "the identified file's name",
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"global_tags": {
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"num_entries": {
|
|
"type": "integer"
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"num_entries"
|
|
]
|
|
}
|
|
},
|
|
"identification_format_version": {
|
|
"description": "The output format's version",
|
|
"type": "integer",
|
|
"minimum": 17,
|
|
"maximum": 17
|
|
},
|
|
"track_tags": {
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"num_entries": {
|
|
"type": "integer"
|
|
},
|
|
"track_id": {
|
|
"type": "integer"
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"num_entries",
|
|
"track_id"
|
|
]
|
|
}
|
|
},
|
|
"tracks": {
|
|
"type": "array",
|
|
"items": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"codec": {
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"id": {
|
|
"type": "integer",
|
|
"minLength": 0
|
|
},
|
|
"type": {
|
|
"type": "string"
|
|
},
|
|
"properties": {
|
|
"additionalProperties": false,
|
|
"type": "object",
|
|
"properties": {
|
|
"aac_is_sbr": {
|
|
"type": "string",
|
|
"enum": [
|
|
"true",
|
|
"false",
|
|
"unknown"
|
|
]
|
|
},
|
|
"audio_bits_per_sample": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"audio_channels": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"audio_emphasis": {
|
|
"description": "Audio emphasis applied on audio samples. The player MUST apply the inverse emphasis to get the proper audio samples.",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"audio_sampling_frequency": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"cb_subsample": {
|
|
"type": "string",
|
|
"pattern": "^-?[0-9]+,-?[0-9]+$"
|
|
},
|
|
"chroma_siting": {
|
|
"type": "string",
|
|
"pattern": "^-?[0-9]+,-?[0-9]+$"
|
|
},
|
|
"chroma_subsample": {
|
|
"type": "string",
|
|
"pattern": "^-?[0-9]+,-?[0-9]+$"
|
|
},
|
|
"chromaticity_coordinates": {
|
|
"type": "string",
|
|
"pattern": "^-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?$"
|
|
},
|
|
"codec_delay": {
|
|
"type": "integer"
|
|
},
|
|
"codec_id": {
|
|
"type": "string"
|
|
},
|
|
"codec_name": {
|
|
"type": "string"
|
|
},
|
|
"codec_private_data": {
|
|
"type": "string"
|
|
},
|
|
"codec_private_length": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"content_encoding_algorithms": {
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"color_bits_per_channel": {
|
|
"type": "integer"
|
|
},
|
|
"color_matrix_coefficients": {
|
|
"type": "integer"
|
|
},
|
|
"color_primaries": {
|
|
"type": "integer"
|
|
},
|
|
"color_range": {
|
|
"type": "integer"
|
|
},
|
|
"color_transfer_characteristics": {
|
|
"type": "integer"
|
|
},
|
|
"default_duration": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"default_track": {
|
|
"type": "boolean"
|
|
},
|
|
"display_dimensions": {
|
|
"type": "string",
|
|
"pattern": "^[0-9]+x[0-9]+$"
|
|
},
|
|
"display_unit": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"enabled_track": {
|
|
"type": "boolean"
|
|
},
|
|
"encoding": {
|
|
"description": "The encoding/character set of a track containing text (e.g. subtitles) if it can be determined with confidence. For such tracks the encoding cannot be changed by the user.",
|
|
"type": "string"
|
|
},
|
|
"forced_track": {
|
|
"type": "boolean"
|
|
},
|
|
"flag_hearing_impaired": {
|
|
"description": "Can be set if that track is suitable for users with hearing impairments.",
|
|
"type": "boolean"
|
|
},
|
|
"flag_visual_impaired": {
|
|
"description": "Can be set if that track is suitable for users with visual impairments.",
|
|
"type": "boolean"
|
|
},
|
|
"flag_text_descriptions": {
|
|
"description": "Can be set if that track contains textual descriptions of video content suitable for playback via a text-to-speech system for a visually-impaired user.",
|
|
"type": "boolean"
|
|
},
|
|
"flag_original": {
|
|
"description": "Can be set if that track is in the content's original language (not a translation).",
|
|
"type": "boolean"
|
|
},
|
|
"flag_commentary": {
|
|
"description": "Can be set if that track contains commentary.",
|
|
"type": "boolean"
|
|
},
|
|
"language": {
|
|
"description": "The track's language as an ISO 639-2 language code",
|
|
"type": "string"
|
|
},
|
|
"language_ietf": {
|
|
"description": "The track's language as an IETF BCP 47/RFC 5646 language tag",
|
|
"type": "string"
|
|
},
|
|
"max_content_light": {
|
|
"type": "integer"
|
|
},
|
|
"max_frame_light": {
|
|
"type": "integer"
|
|
},
|
|
"max_luminance": {
|
|
"type": "number"
|
|
},
|
|
"min_luminance": {
|
|
"type": "number"
|
|
},
|
|
"minimum_timestamp": {
|
|
"description": "The minimum timestamp in nanoseconds of all the frames of this track found within the first couple of seconds of the file",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"multiplexed_tracks": {
|
|
"description": "An array of track IDs indicating which tracks were originally multiplexed within the same track in the source file",
|
|
"type": "array",
|
|
"items": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
}
|
|
},
|
|
"number": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"packetizer": {
|
|
"type": "string",
|
|
"minLength": 1
|
|
},
|
|
"pixel_dimensions": {
|
|
"type": "string",
|
|
"pattern": "^[0-9]+x[0-9]+$"
|
|
},
|
|
"program_number": {
|
|
"description": "A unique number identifying a set of tracks that belong together; used e.g. in DVB for multiplexing multiple stations within a single transport stream",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"projection_pose_pitch": {
|
|
"type": "number"
|
|
},
|
|
"projection_pose_roll": {
|
|
"type": "number"
|
|
},
|
|
"projection_pose_yaw": {
|
|
"type": "number"
|
|
},
|
|
"projection_private": {
|
|
"type": "string",
|
|
"pattern": "^([0-9A-F]{2})*$"
|
|
},
|
|
"projection_type": {
|
|
"type": "integer"
|
|
},
|
|
"stereo_mode": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"stream_id": {
|
|
"description": "A format-specific ID identifying a track, possibly in combination with a 'sub_stream_id' (e.g. the program ID in an MPEG transport stream)",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"sub_stream_id": {
|
|
"description": "A format-specific ID identifying a track together with a 'stream_id'",
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"tag_artist": {
|
|
"type": "string"
|
|
},
|
|
"tag_bitsps": {
|
|
"type": "string"
|
|
},
|
|
"tag_bps": {
|
|
"type": "string"
|
|
},
|
|
"tag_fps": {
|
|
"type": "string"
|
|
},
|
|
"tag_title": {
|
|
"type": "string"
|
|
},
|
|
"teletext_page": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"text_subtitles": {
|
|
"type": "boolean"
|
|
},
|
|
"track_name": {
|
|
"type": "string"
|
|
},
|
|
"uid": {
|
|
"type": "integer",
|
|
"minimum": 0
|
|
},
|
|
"white_color_coordinates": {
|
|
"type": "string",
|
|
"pattern": "^-?[0-9]+(\\.[0-9]+)?,-?[0-9]+(\\.[0-9]+)?$"
|
|
}
|
|
},
|
|
"additionalProperties": false
|
|
}
|
|
},
|
|
"additionalProperties": false,
|
|
"required": [
|
|
"codec",
|
|
"id",
|
|
"type"
|
|
]
|
|
}
|
|
},
|
|
"warnings": {
|
|
"type": "array",
|
|
"items": {
|
|
"type": "string"
|
|
}
|
|
}
|
|
}
|
|
}
|