mirror of
https://github.com/status-im/Vulkan-Docs.git
synced 2025-01-26 14:20:33 +00:00
b9e9296cd8
* Bump API patch number and header version number to 53 for this update. Github Issues: Internal Issues: * Clarify mappings of coordinates for mutable, compatible image views in slink:VkImageViewCreateInfo (internal issue 815). * Make ename:VK_BIND_SFR_BIT require a logical device with multiple physical devices, so that standard sparse image block dimensions are only required on systems that support multi-GPU (internal issue 835). * Convert all files from use of // refBegin .. // refEnd comments to delimit ref pages, to use of open blocks, and update style guide accordingly (internal issue 839). * Add valid usage for slink:VkWriteDescriptorSet when performing updates to a ename:VK_STORAGE_IMAGE descriptor with layout ename:VK_IMAGE_LAYOUT_GENERAL. * Add a hack to the validity generator script to support an odd interaction between flink:vkCmdFillBuffer and an extension (internal issue 853). * Remove redundant text describing slink:VkBufferCreateInfo::pname:usage, which was already covered by implicit valid usage (internal issue 854). * Update implicit validity generator script to properly handle the pname:sType and pname:pNext members of "returnedonly" structures (internal issue 874). * Note that slink:VkApplicationInfo::pname:pApplicationName & slink:VkApplicationInfo::pname:pEngineName are optional, and add missing implicit valid usage statements for flink:vkDestroyInstance. * Added missing valid usage for flink:vkCmdWriteTimestamp to require a timestamp query pool. * Simplify and/or split "`non-atomic`" valid usage statements. New Extensions: * `VK_AMD_gpu_shader_int16` * `VK_EXT_blend_operation_advanced` * `VK_EXT_sampler_filter_minmax` * `VK_NV_framebuffer_mixed_samples` ----------------------------------------------------- Note: the 1.0.52 spec wasn't published on github, so the 1.0.53 release combines both change sets. ----------------------------------------------------- Change log for June 13, 2017 Vulkan 1.0.52 spec update: * Bump API patch number and header version number to 52 for this update. Github Issues: Internal Issues: * Clarify behavior when non-coherent memory has <<memory-device-unmap-does-not-flush, not been flushed before being unmapped>> (internal issue 819). * Fix description of code:WorkgroupSize builtin to note it decorates an object, not a variable (internal issue 836). * Fix asciidoc attributes so that trailing '{plus}' symbols in [eq] style equations are rendered properly (internal issue 845). * Add language to the "`Extension Handles, Objects, Enums, and Typedefs`" section of the Procedures and Conventions document stating that any new handle type requires a corresponding entry in the elink:VkObjectType enumerated type (internal issue 856). * Update style guide to use slink macro for Vulkan handle type names, and define narrow conditions under which to use the *name and *text macros instead of *link (internal issue 886). * Add a dependency of the <<VK_KHX_device_group,VK_KHX_device_group>> extension on VK_KHX_device_group_creation to +vk.xml+ and the extension appendix. * Change the copyright on Vulkan specification asciidoc *source* files to CC-BY 4.0, and update the proprietary Khronos copyright applied to the generated *output* formats (internal issue 327). This enables broader re-use and modification of the Vulkan specification sources, while not affecting the Reciprocal IP License between Vulkan Adopters and Working Group Members. New Extensions: * `VK_NV_fill_rectangle` * `VK_NV_fragment_coverage_to_color`
213 lines
7.2 KiB
Python
Executable File
213 lines
7.2 KiB
Python
Executable File
#!/usr/bin/python3
|
|
#
|
|
# Copyright (c) 2016-2017 The Khronos Group Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# fixupRef.py - replace old // refBegin .. // refEnd syntax with new
|
|
# open block syntax
|
|
#
|
|
# Usage: fixupRef.py [-outdir path] [-overwrite] files
|
|
|
|
from reflib import *
|
|
from vkapi import *
|
|
import argparse, copy, io, os, pdb, re, string, sys
|
|
|
|
# Return 'None' for None, the string otherwise
|
|
def noneStr(str):
|
|
if str == None:
|
|
return '(None)'
|
|
else:
|
|
return str
|
|
|
|
# Escape single quotes in a string for asciidoc
|
|
def escapeQuote(str):
|
|
return str.replace("'", "\'")
|
|
|
|
# Start a refpage open block
|
|
def openBlock(pi, fp):
|
|
if pi.refs != '':
|
|
print("[open,refpage='" + pi.name +
|
|
"',desc='" + pi.desc +
|
|
"',type='" + pi.type +
|
|
"',xrefs='" + pi.refs + "']",
|
|
file=fp)
|
|
else:
|
|
print("[open,refpage='" + pi.name +
|
|
"',desc='" + pi.desc +
|
|
"',type='" + pi.type + "']",
|
|
file=fp)
|
|
print('--', file=fp)
|
|
|
|
# End a refpage open block
|
|
def closeBlock(pi, fp):
|
|
print('--', file=fp)
|
|
# Just for finding block ends while debugging
|
|
# print("// end [open,refpage='" + pi.name + "']", file=fp)
|
|
|
|
# Replace old // refBegin .. // refEnd references in an asciidoc
|
|
# file with open blocks, per # ??? .
|
|
# specFile - filename to extract from
|
|
# outDir - output directory to write updated file to, if not overwritten
|
|
# overwrite - True if the file should be overwritten in place
|
|
# skipped - set of filenames containing commands which weren't
|
|
# rewritten with open blocks (e.g. enums). Updated in place.
|
|
def replaceRef(specFile, outDir, overwrite = False, skipped = set()):
|
|
file = loadFile(specFile)
|
|
if file == None:
|
|
return
|
|
|
|
# Save the path to this file for later use in rewriting relative includes
|
|
specDir = os.path.dirname(os.path.abspath(specFile))
|
|
|
|
pageMap = findRefs(file)
|
|
logDiag(specFile + ': found', len(pageMap.keys()), 'potential pages')
|
|
|
|
sys.stderr.flush()
|
|
|
|
# Fix up references in pageMap
|
|
fixupRefs(pageMap, specFile, file)
|
|
|
|
# Map the page info dictionary into a dictionary of actions
|
|
# keyed by line number they're performed on/after:
|
|
# 'action' : 'begin' or 'end'. What to do on a refBegin or refEnd line
|
|
# 'replace': True if this line needs to be replaced
|
|
# 'name' : Name of the ref page being defined
|
|
# 'desc' : One-line description of the ref page being defined
|
|
# 'type' : Type of the ref page being defined, 'structs', 'protos', etc.
|
|
# 'refs' : Space-separated string of crossreferenced pages
|
|
|
|
actions = { }
|
|
|
|
for name in pageMap.keys():
|
|
pi = pageMap[name]
|
|
|
|
# Cleanup parameters for output
|
|
pi.name = noneStr(pi.name)
|
|
pi.desc = escapeQuote(noneStr(pi.desc))
|
|
|
|
if pi.extractPage:
|
|
if (file[pi.begin][0:11] == '// refBegin'):
|
|
# Replace line
|
|
actions[pi.begin] = {
|
|
'action' : 'begin',
|
|
'replace' : True,
|
|
'pageinfo' : pi
|
|
}
|
|
else:
|
|
# Insert line
|
|
actions[pi.begin] = {
|
|
'action' : 'begin',
|
|
'replace' : False,
|
|
'pageinfo' : pi
|
|
}
|
|
|
|
if (file[pi.end][0:9] == '// refEnd'):
|
|
# Replace line
|
|
actions[pi.end] = {
|
|
'action' : 'end',
|
|
'replace' : True,
|
|
'pageinfo' : pi
|
|
}
|
|
else:
|
|
# Insert line
|
|
actions[pi.end] = {
|
|
'action' : 'end',
|
|
'replace' : False,
|
|
'pageinfo' : pi
|
|
}
|
|
else:
|
|
logWarn('Skipping replacement for', pi.name, 'at', specFile,
|
|
'line', pi.begin)
|
|
print('Skipping replacement for', pi.name, 'at', specFile,
|
|
'line', pi.begin)
|
|
printPageInfo(pi, file)
|
|
skipped.add(specFile)
|
|
|
|
if overwrite:
|
|
pageName = specFile
|
|
else:
|
|
pageName = outDir + '/' + os.path.basename(specFile)
|
|
|
|
fp = open(pageName, 'w', encoding='utf-8')
|
|
|
|
line = 0
|
|
for text in file:
|
|
if line in actions.keys():
|
|
action = actions[line]['action']
|
|
replace = actions[line]['replace']
|
|
pi = actions[line]['pageinfo']
|
|
|
|
logDiag('ACTION:', action, 'REPLACE:', replace, 'at line', line)
|
|
logDiag('PageInfo of action:')
|
|
printPageInfo(pi, file)
|
|
|
|
if action == 'begin':
|
|
openBlock(pi, fp)
|
|
if not replace:
|
|
print(text, file=fp, end='')
|
|
elif action == 'end':
|
|
if not replace:
|
|
print(text, file=fp, end='')
|
|
closeBlock(pi, fp)
|
|
else:
|
|
print('ERROR: unrecognized action:', action, 'in',
|
|
specFile, 'at line', line)
|
|
print(text, file=fp, end='')
|
|
else:
|
|
print(text, file=fp, end='')
|
|
line = line + 1
|
|
|
|
fp.close()
|
|
|
|
#for line in sorted(actions.keys()):
|
|
# action = actions[line]
|
|
# print('action at line', line, '\t',
|
|
# action[0], action[1], action[2])
|
|
|
|
if __name__ == '__main__':
|
|
global genDict
|
|
genDict = {}
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument('-diag', action='store', dest='diagFile',
|
|
help='Set the diagnostic file')
|
|
parser.add_argument('-warn', action='store', dest='warnFile',
|
|
help='Set the warning file')
|
|
parser.add_argument('-log', action='store', dest='logFile',
|
|
help='Set the log file for both diagnostics and warnings')
|
|
parser.add_argument('-outdir', action='store', dest='outDir',
|
|
default='out',
|
|
help='Set the base directory in which pages are generated')
|
|
parser.add_argument('-overwrite', action='store_true',
|
|
help='Overwrite input filenames instead of writing different output filenames')
|
|
parser.add_argument('files', metavar='filename', nargs='*',
|
|
help='a filename to extract ref pages from')
|
|
parser.add_argument('--version', action='version', version='%(prog)s 1.0')
|
|
|
|
results = parser.parse_args()
|
|
|
|
setLogFile(True, True, results.logFile)
|
|
setLogFile(True, False, results.diagFile)
|
|
setLogFile(False, True, results.warnFile)
|
|
|
|
skipped = set()
|
|
for file in results.files:
|
|
replaceRef(file, results.outDir, results.overwrite, skipped)
|
|
|
|
if len(skipped) > 0:
|
|
print('Files containing skipped feature blocks:')
|
|
for file in sorted(skipped):
|
|
print('\t' + file)
|