diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 591044908c..24641c5b49 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -4,31 +4,34 @@ Thank you for considering contributing to the Shader-Slang project! We welcome your help to improve and enhance our project. Please take a moment to read through this guide to understand how you can contribute. -This document is to guide you to contribute to the project. This document is intended to be easy to follow without sending the readers to other pages and links. You can simply copy and paste command lines described on this document. +This document is designed to guide you in contributing to the project. It is intended to be easy to follow without sending readers to other pages and links. You can simply copy and paste the command lines described in this document. * Contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant the rights to use your contribution. * When you submit a pull request, a CLA bot will determine whether you need to sign a CLA. Simply follow the instructions provided. * Please read and follow the contributor [Code of Conduct](CODE_OF_CONDUCT.md). -* Bug reports and feature requests should go through the GitHub issue tracker -* Changes should ideally come in as small pull requests on top of master, coming from your own personal fork of the project -* Large features that will involve multiple contributors or a long development time should be discussed in issues, and broken down into smaller pieces that can be implemented and checked in in stages +* Bug reports and feature requests should be submitted via the GitHub issue tracker. +* Changes should ideally come in as small pull requests on top of master, coming from your own personal fork of the project. +* Large features that will involve multiple contributors or a long development time should be discussed in issues and broken down into smaller pieces that can be implemented and checked in stages. ## Table of Contents 1. [Contribution Process](#contribution-process) - [Forking the Repository](#forking-the-repository) - - [Cloning your Fork](#cloning-your-fork) + - [Cloning Your Fork](#cloning-your-fork) - [Creating a Branch](#creating-a-branch) - [Build Slang from Source](#build-slang-from-source) - [Making Changes](#making-changes) - [Testing](#testing) - [Commit to the Branch](#commit-to-the-branch) - [Push to Forked Repository](#push-to-forked-repository) - - [Request Pull](#request-pull) -1. [Update your Repository](#update-your-repository) -1. [Code Style](#code-style) -1. [Issue Tracking](#issue-tracking) -1. [Communication](#communication) -1. [License](#license) +2. [Pull Request](#pull-request) + - [Addressing Code Reviews](#addressing-code-reviews) + - [Labeling Breaking Changes](#labeling-breaking-changes) + - [Source Code Formatting](#source-code-formatting) + - [Document Changes](#document-changes) +3. [Code Style](#code-style) +4. [Issue Tracking](#issue-tracking) +5. [Communication](#communication) +6. [License](#license) ## Contribution Process @@ -36,17 +39,17 @@ This document is to guide you to contribute to the project. This document is int Navigate to the [Shader-Slang repository](https://github.com/shader-slang/slang). Click on the "Fork" button in the top right corner to create a copy of the repository in your GitHub account. This document will assume that the name of your forked repository is "slang". -Make sure your "Actions" are enabled. Visit your forked repository and click on the "Actions" tab and enable the actions. +Make sure your "Actions" are enabled. Visit your forked repository, click on the "Actions" tab, and enable the actions. -### Cloning your Fork -1. Clone your fork locally, replacing "USER-NAME" in the command below with your actual username.. +### Cloning Your Fork +1. Clone your fork locally, replacing "USER-NAME" in the command below with your actual username. ``` $ git clone --recursive --tags https://github.com/USER-NAME/slang.git $ cd slang ``` -1. Fetch tags by adding the original repository as an upstream. - It is important to have tags in your forked repository, because our workflow/action uses the information for the build process. But the tags are not fetched by default when you fork a repository in github. You need to add the original repository as an upstream and fetch tags manually. +2. Fetch tags by adding the original repository as an upstream. + It is important to have tags in your forked repository because our workflow/action uses the information for the build process. But the tags are not fetched by default when you fork a repository in GitHub. You need to add the original repository as an upstream and fetch tags manually. ``` $ git remote add upstream https://github.com/shader-slang/slang.git $ git fetch --tags upstream @@ -57,8 +60,8 @@ Make sure your "Actions" are enabled. Visit your forked repository and click on $ git tag -l ``` -1. Push tags to your forked repository - The tags are fetched to your local machine but it hasn't been pushed to the forked repository yet. You need to push tags to your forked repository with the following command. +3. Push tags to your forked repository. + The tags are fetched to your local machine but haven't been pushed to the forked repository yet. You need to push tags to your forked repository with the following command. ``` $ git push --tags origin ``` @@ -70,22 +73,22 @@ $ git checkout -b feature/your-feature-name ``` ### Build Slang from Source -Please follow the instructions of how to [Building Slang from Source](docs/building.md). +Please follow the instructions on how to [Build Slang from Source](docs/building.md). For a quick reference, follow the instructions below. #### Windows -Download and install CMake from [CMake.org/download](https://cmake.org/download) +Download and install CMake from [CMake.org/download](https://cmake.org/download). Run CMake with the following command to generate a Visual Studio 2022 Solution: ``` -C:\git\slang> cmake.exe --preset vs2022 # For VisualStudio 2022 -C:\git\slang> cmake.exe --preset vs2019 # For VisualStudio 2019 +C:\git\slang> cmake.exe --preset vs2022 # For Visual Studio 2022 +C:\git\slang> cmake.exe --preset vs2019 # For Visual Studio 2019 ``` -Open `build/slang.sln` with VisualStudio IDE and build it for "x64". +Open `build/slang.sln` with Visual Studio IDE and build it for "x64". -Or you can build with a following command: +Or you can build with the following command: ``` C:\git\slang> cmake.exe --build --preset release ``` @@ -97,90 +100,113 @@ $ sudo apt-get install cmake ninja-build ``` > Warning: Currently the required CMake version is 3.25 or above. -Run CMake with a following command to generate Makefile: +Run CMake with the following command to generate Makefile: ``` $ cmake --preset default ``` -Build with a following command: +Build with the following command: ``` $ cmake --build --preset release ``` #### MacOS -Install XCode from AppStore. +Install Xcode from the App Store. -Install CMake and Ninja; we recommend using [homebrew](https://brew.sh/) for installing them. +Install CMake and Ninja; we recommend using [Homebrew](https://brew.sh/) for installing them. ``` -brew install ninja -brew install cmake +$ brew install ninja +$ brew install cmake ``` -Run CMake with a following command to generate Makefile: +Run CMake with the following command to generate Makefile: ``` $ cmake --preset default ``` -Build with a following command: +Build with the following command: ``` $ cmake --build --preset release ``` -#### Building with a local build of slang-llvm -slang-llvm is required to run slang-test properly. -Follow the instructions below if you wish to build slang-llvm locally. +#### Building with a Local Build of slang-llvm +`slang-llvm` is required to run `slang-test` properly. +Follow the instructions below if you wish to build `slang-llvm` locally. ``` $ external/build-llvm.sh --source-dir build/slang-llvm_src --install-prefix build/slang-llvm_install ``` -You need to use the following command to re-generate Makefile, +You need to use the following command to regenerate the Makefile: ``` $ cmake --preset default --fresh -DSLANG_SLANG_LLVM_FLAVOR=USE_SYSTEM_LLVM -DLLVM_DIR=build/slang-llvm_install/lib/cmake/llvm -DClang_DIR=build/slang-llvm_install/lib/cmake/clang ``` -Build with a following command: +Build with the following command: ``` $ cmake --build --preset release ``` +#### GitHub REST API Limit +When you execute `cmake --preset`, CMake uses the GitHub REST API, and there is a daily/hourly API limit for each IP address. If you are using an IP address shared by many people, you may hit this limit occasionally. Refer to [Rate limits for the REST API](https://docs.github.com/en/rest/using-the-rest-api/rate-limits-for-the-rest-api) for more information. + +When this happens, you will see a warning message from CMake as follows: +``` +CMake Warning at cmake/GitHubRelease.cmake:53 (message): + If API rate limit is exceeded, Github allows a higher limit when you use + token. Try a cmake option -DSLANG_GITHUB_TOKEN=your_token_here +Call Stack (most recent call first): + cmake/GitHubRelease.cmake:114 (check_release_and_get_latest) + CMakeLists.txt:141 (get_best_slang_binary_release_url) +``` + +The limit is higher when you use your personal account with a "Passkey". + +To generate a "Passkey" on GitHub: + 1. Go to GitHub "Settings" for your account. + 2. Go to "Password and Authentication". + 3. Click "Add a passkey" button. + 4. GitHub will generate a "Passkey". + +Use the generated "Passkey" with a cmake option "-DSLANG_GITHUB_TOKEN=your-pass-key-here". + ### Making Changes Make your changes and ensure to follow our [Design Decisions](docs/design/README.md). ### Testing -Test your changes thoroughly to ensure they do not introduce new issues. This is done by building and running a "slang-test" from the repository root directory. For more details about "slang-test", please refer to a [Documentation on testing](tools/slang-test/README.md). +Test your changes thoroughly to ensure they do not introduce new issues. This is done by building and running `slang-test` from the repository root directory. For more details about `slang-test`, please refer to the [Documentation on testing](tools/slang-test/README.md). -> Note: slang-test is meant to launch from the root of the repository. It uses a hard-coded directory name "tests/" that is expected to exist in the current working directory. +> Note: `slang-test` is meant to be launched from the root of the repository. It uses a hard-coded directory name "tests/" that is expected to exist in the current working directory. -> Note: One of the options for `slang-test.exe` is `-api`, and it takes an additional keyword to specify which API to test. When the option is `-api all-cpu`, as an example, it means it tests all APIs except CPU. The minus sign (-) after `all` means "exclude" and you can "include" with plus sign (+) like `-api gl+dx11`. +> Note: One of the options for `slang-test.exe` is `-api`, and it takes an additional keyword to specify which API to test. When the option is `-api all-cpu`, as an example, it means it tests all APIs except CPU. The minus sign (-) after `all` means "exclude," and you can "include" with a plus sign (+) like `-api gl+dx11`. -If you are familiar with Workflow/Actions in github, you can check [Our Workflows](.github/workflows). "Test Slang" section in [ci.yml](.github/workflows/ci.yml) is where "slang-test" runs. +If you are familiar with Workflows/Actions in GitHub, you can check [Our Workflows](.github/workflows). The "Test Slang" section in [ci.yml](.github/workflows/ci.yml) is where `slang-test` runs. For a quick reference, follow the instructions below. #### Windows -1. Download and install VulkanSDK from [LunarG SDK page](https://www.lunarg.com/vulkan-sdk). -1. Set an environment variable to enable SPIR-V validation in Slang compiler, +1. Download and install VulkanSDK from the [LunarG SDK page](https://www.lunarg.com/vulkan-sdk). +2. Set an environment variable to enable SPIR-V validation in the Slang compiler: ``` C:\git\slang> set SLANG_RUN_SPIRV_VALIDATION=1 ``` -1. Run slang-test with multiple threads. This may take 10 minutes or less depending on the performance of your computer. +3. Run `slang-test` with multiple threads. This may take 10 minutes or less depending on the performance of your computer. ``` C:\git\slang> build\Release\bin\slang-test.exe -use-test-server -server-count 8 ``` - > Note: if you increase `-server-count` more than 16, you may find some of tests randomly fail. This is a known issue on the graphics driver side. -1. Check whether the test is finished as expected. + > Note: If you increase `-server-count` to more than 16, you may find some of the tests randomly fail. This is a known issue on the graphics driver side. +4. Check whether the tests finished as expected. #### Linux -1. Install Vulkan-SDK by following the [Instructions in LunarG ](https://vulkan.lunarg.com/doc/view/latest/linux/getting_started_ubuntu.html). +1. Install VulkanSDK by following the [Instructions from LunarG](https://vulkan.lunarg.com/doc/view/latest/linux/getting_started_ubuntu.html). ``` $ sudo apt update $ sudo apt install vulkan-sdk ``` -1. Run slang-test with multiple threads. This may take 10 minutes or less depending on the performance of your computer. +2. Run `slang-test` with multiple threads. This may take 10 minutes or less depending on the performance of your computer. ``` $ ./build/Release/bin/slang-test -use-test-server -server-count 8 ``` -1. Check whether the test is finished as expected. +3. Check whether the tests finished as expected. ### Commit to the Branch Commit your changes to the branch with a descriptive commit message: @@ -188,9 +214,10 @@ Commit your changes to the branch with a descriptive commit message: $ git commit ``` -It is important to have a descriptive commit message. Unlike comments inside of the source code, the commit messages don't spoil over time because it is tied to a specific change and it can be reviewed by many people many years later. +It is important to have a descriptive commit message. Unlike comments inside the source code, the commit messages don't spoil over time because they are tied to specific changes and can be reviewed by many people many years later. + +Here is a good example of a commit message: -Here is a good example of a commit message > Add user authentication feature > > Fixes #1234 @@ -198,26 +225,42 @@ Here is a good example of a commit message > This commit introduces a new user authentication feature. It includes changes to the login page, user database, and session management to provide secure user authentication. ### Push to Forked Repository -Push your branch to your forked repository with the following command. +Push your branch to your forked repository with the following command: ``` $ git push origin feature/your-feature-name ``` -### Request Pull +After the changes are pushed to your forked repository, the change needs to be merged to the final destination `shader-slang/slang`. +In order to proceed, you will need to create a "Pull Request," or "PR" for short. -Open a pull request against `shader-slang/slang`. +When you push to your forked repository, `git-push` usually prints a URL that allows you to create a PR. -Code formatting can be automatically fixed on your branch by commenting `/format`, a bot will proceed to open a PR targeting *your* branch. +If you missed a chance to use the URL, you can still create a PR from the GitHub webpage. +Go to your forked repository and change the branch name to the one you used for `git-push`. +It will show a message like "This branch is 1 commit ahead of `shader-slang/slang:master`." +You can create a PR by clicking on the message. -For the Pull Request, you will need to write a PR message. This message is for a set of commits you are requesting to pull. Try to make it brief because the actual details should be in the commit messages of each commit. - -The PR requires an approval from people who have permissions. They will review the changes before approve the Pull. During this step, you will get feedbacks from other people and they may request you to make some changes. When you need to make adjustments, you can commit new changes to the branch in your forlked repository that already has the changes in PR process. When new commits are added to the branch, they will automatically appear in the PR. +## Pull Request +Once a PR is created against `shader-slang/slang:master`, the PR will be merged when the following conditions are met: +1. The PR is reviewed and got approval. +1. All of the workflows pass. -## Addressing Code Reviews and Keep Branch In-Sync -After your pull request is submitted, you will receive code reviews from the community within 24 hours. Follow-up changes that address review comments should be pushed to your pull request branch as additional commits. When your branch is out of sync with top-of-tree, submit a merge commit to keep them in-sync. Do not rebase and force push after the PR is created to keep the change history during the review process. +When the conditions above are all met, you will have a chance to rewrite the commit message. Since the Slang repo uses the "squash" strategy for merging, multiple commits in your PR will become one commit. By default, GitHub will concatenate all of the commit messages sequentially, but often it is not readable. Please rewrite the final commit message in a way that people can easily understand what the purpose of the commit is. -Use these commands to sync your branch: +There are two cases where the workflow may fail for reasons that are not directly related to the change: +1. "Breaking change" labeling is missing. +1. Source code "Format" needs to be changed. + +### Addressing Code Reviews +After your pull request is created, you will receive code reviews from the community within 24 hours. + +The PR requires approval from people who have permissions. They will review the changes before approving the pull. During this step, you will get feedback from other people, and they may request you to make some changes. + +Follow-up changes that address review comments should be pushed to your pull request branch as additional commits. Any additional commits made to the same branch in your forked repository will show up on the PR as incremental changes. +When your branch is out of sync with top-of-tree, submit a merge commit to keep them in sync. Do not rebase and force push after the PR is created to keep the change history during the review process. + +Use these commands to sync your branch: ``` $ git fetch upstream master $ git merge upstream/master # resolve any conflicts here @@ -226,31 +269,50 @@ $ git submodule update --recursive The Slang repository uses the squash strategy for merging pull requests, which means all your commits will be squashed into one commit by GitHub upon merge. -## Labeling Breaking Changes - +### Labeling Breaking Changes All pull requests must be labeled as either `pr: non-breaking` or `pr: breaking change` before it can be merged to the main branch. If you are already a committer, you are expected to label your PR when you create it. If you are not yet a committer, a reviewer will do this for you. A PR is considered to introduce a breaking change if an existing application that uses Slang may no longer compile or behave the same way with the change. Typical examples of breaking changes include: -- Changes to `slang.h` that modifies the Slang API in a way that breaks binary compatibility. -- Changes to the language syntax or semantics that may cause existing Slang code to not compile or produce different run-time result. For example changing the overload resolution rules. +- Changes to `slang.h` that modify the Slang API in a way that breaks binary compatibility. +- Changes to the language syntax or semantics that may cause existing Slang code to not compile or produce different run-time results. For example, changing the overload resolution rules. - Removing or renaming an existing intrinsic from the core module. +### Source Code Formatting +When the PR contains source code changes, one of the workflows will check the formatting of the code. + +Code formatting can be automatically fixed on your branch by commenting `/format`; a bot will proceed to open a PR targeting *your* branch. You can merge the generated PR into your branch, and the problem will be resolved. + +### Document Changes +When the PR contains document changes for the [Slang User's Guide](https://shader-slang.com/slang/user-guide/), you need to update the table of contents by running a PowerShell script as follows: +``` +# Open PowerShell on Windows +cd docs +.\build_toc.ps1 + +# Add to git commit +git add gfx-user-guide/toc.html +git add user-guide/toc.html +``` + +Similar to the `/format` bot-command described in the previous section, you can also use `/regenerate-toc` instead. + +When the PR is limited to document changes, the build workflows may not start properly. This is because the building process is unnecessary when the PR is limited to document changes. This may lead to a case where some of the required build workflows are stuck waiting to start. When this happens, the committers will manually merge the PR as a workaround, and it will not give you a chance to rewrite the commit message. ## Code Style -Follow our [Coding conventions](docs/design/coding-conventions.md) to maintain consistency throughout the project. +Follow our [Coding Conventions](docs/design/coding-conventions.md) to maintain consistency throughout the project. -Here are a few highlights +Here are a few highlights: 1. Indent by four spaces. Don't use tabs except in files that require them (e.g., Makefiles). 1. Don't use the STL containers, iostreams, or the built-in C++ RTTI system. 1. Don't use the C++ variants of C headers (e.g., use `` instead of ``). 1. Don't use exceptions for non-fatal errors (and even then support a build flag to opt out of exceptions). 1. Types should use UpperCamelCase, values should use lowerCamelCase, and macros should use `SCREAMING_SNAKE_CASE` with a prefix `SLANG_`. 1. Global variables should have a `g` prefix, non-const static class members can have an `s` prefix, constant data (in the sense of static const) should have a `k` prefix, and an `m_` prefix on member variables and a `_` prefix on member functions are allowed. -1. Prefixes based on types (e.g., p for pointers) should never be used. +1. Prefixes based on types (e.g., `p` for pointers) should never be used. 1. In function parameter lists, an `in`, `out`, or `io` prefix can be added to a parameter name to indicate whether a pointer/reference/buffer is intended to be used for input, output, or both input and output. 1. Trailing commas should always be used for array initializer lists. -1. Try to write comments that explain the "why" of your code more than the "what". +1. Try to write comments that explain the "why" of your code more than the "what." ## Issue Tracking We track all our work with GitHub issues. Check the [Issues](https://github.com/shader-slang/slang/issues) for open issues. If you find a bug or want to suggest an enhancement, please open a new issue. @@ -262,4 +324,3 @@ Join our [Discussions](https://github.com/shader-slang/slang/discussions). ## License By contributing to Shader-Slang, you agree that your contributions will be licensed under the MIT License. The full text of the License can be found in the [LICENSE](LICENSE) file in the root of the repository. - diff --git a/source/core/slang-string-util.cpp b/source/core/slang-string-util.cpp index 6f1dc2ccb8..ba234e30b6 100644 --- a/source/core/slang-string-util.cpp +++ b/source/core/slang-string-util.cpp @@ -461,7 +461,7 @@ String StringUtil::replaceAll( StringBuilder builder; for (Index i = 0; i < text.getLength();) { - if (i + subStr.getLength() >= text.getLength()) + if (i + subStr.getLength() > text.getLength()) { builder.append(text.subString(i, text.getLength() - i)); break; diff --git a/source/slang/slang-check-conversion.cpp b/source/slang/slang-check-conversion.cpp index 0c06fb1130..74151a4bb0 100644 --- a/source/slang/slang-check-conversion.cpp +++ b/source/slang/slang-check-conversion.cpp @@ -1327,7 +1327,7 @@ bool SemanticsVisitor::_coerce( // For general types of implicit conversions, we issue a warning, unless `fromExpr` // is a known constant and we know it won't cause a problem. bool shouldEmitGeneralWarning = true; - if (isScalarIntegerType(toType)) + if (isScalarIntegerType(toType) || isHalfType(toType)) { if (auto intVal = tryFoldIntegerConstantExpression( fromExpr, diff --git a/source/slang/slang-check-decl.cpp b/source/slang/slang-check-decl.cpp index eeb75e3fd1..7f07444dc9 100644 --- a/source/slang/slang-check-decl.cpp +++ b/source/slang/slang-check-decl.cpp @@ -5070,7 +5070,9 @@ bool SemanticsVisitor::trySynthesizePropertyRequirementWitness( synPropertyDecl->nameAndLoc.name = getName(String("$syn_property_") + getText(requiredMemberDeclRef.getName())); synPropertyDecl->parentDecl = context->parentDecl; - + synPropertyDecl->ownedScope = m_astBuilder->create(); + synPropertyDecl->ownedScope->containerDecl = synPropertyDecl; + synPropertyDecl->ownedScope->parent = context->parentDecl->ownedScope; // The type of our synthesized property can be derived from the // specialized declref to the requirement decl. @@ -7421,6 +7423,15 @@ bool SemanticsVisitor::isScalarIntegerType(Type* type) return isIntegerBaseType(baseType) || baseType == BaseType::Bool; } +bool SemanticsVisitor::isHalfType(Type* type) +{ + auto basicType = as(type); + if (!basicType) + return false; + auto baseType = basicType->getBaseType(); + return baseType == BaseType::Half; +} + bool SemanticsVisitor::isValidCompileTimeConstantType(Type* type) { return isScalarIntegerType(type) || isEnumType(type); @@ -7466,6 +7477,9 @@ bool SemanticsVisitor::isIntValueInRangeOfType(IntegerLiteralValue value, Type* #endif return value >= std::numeric_limits::min() && value <= std::numeric_limits::max(); + + case BaseType::Half: + return value >= -2048 && value <= 2048; default: return false; } diff --git a/source/slang/slang-check-impl.h b/source/slang/slang-check-impl.h index 7f0609bac9..45e8991321 100644 --- a/source/slang/slang-check-impl.h +++ b/source/slang/slang-check-impl.h @@ -1991,6 +1991,9 @@ struct SemanticsVisitor : public SemanticsContext /// Is `type` a scalar integer type. bool isScalarIntegerType(Type* type); + /// Is `type` a scalar half type. + bool isHalfType(Type* type); + /// Is `type` something we allow as compile time constants, i.e. scalar integer and enum types. bool isValidCompileTimeConstantType(Type* type); diff --git a/source/slang/slang-parser.cpp b/source/slang/slang-parser.cpp index 2c208a62eb..2fb44921d6 100644 --- a/source/slang/slang-parser.cpp +++ b/source/slang/slang-parser.cpp @@ -5979,22 +5979,25 @@ ForStmt* Parser::ParseForStatement() FillPosition(stmt); ReadToken("for"); ReadToken(TokenType::LParent); - auto modifiers = ParseModifiers(this); - if (peekTypeName(this) || !modifiers.isEmpty()) - { - stmt->initialStatement = parseVarDeclrStatement(modifiers); - } - else + if (!LookAheadToken(TokenType::Semicolon)) { - if (!LookAheadToken(TokenType::Semicolon)) + stmt->initialStatement = ParseStatement(); + if (as(stmt->initialStatement) || as(stmt->initialStatement)) { - stmt->initialStatement = ParseExpressionStatement(); + // These are the only allowed form of initial statements of a for loop. } else { - ReadToken(TokenType::Semicolon); + sink->diagnose( + stmt->initialStatement->loc, + Diagnostics::unexpectedTokenExpectedTokenType, + "expression"); } } + else + { + ReadToken(TokenType::Semicolon); + } if (!LookAheadToken(TokenType::Semicolon)) stmt->predicateExpression = ParseExpression(); ReadToken(TokenType::Semicolon); diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp index e4de612762..9e9b5fbe35 100644 --- a/source/slang/slang.cpp +++ b/source/slang/slang.cpp @@ -4257,7 +4257,7 @@ SourceFile* Linkage::findFile(Name* name, SourceLoc loc, IncludeSystem& outInclu // Next, try to find the file of the given name, // using our ordinary include-handling logic. - auto searchDirs = getSearchDirectories(); + auto& searchDirs = getSearchDirectories(); outIncludeSystem = IncludeSystem(&searchDirs, getFileSystemExt(), getSourceManager()); // Get the original path info diff --git a/tests/bugs/dynamic-interface-property.slang b/tests/bugs/dynamic-interface-property.slang new file mode 100644 index 0000000000..4243ce71b0 --- /dev/null +++ b/tests/bugs/dynamic-interface-property.slang @@ -0,0 +1,24 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK):-output-using-type + +public interface ITest { + property int value; +}; + +struct Test : ITest { + int value; +}; + +//TEST_INPUT: type_conformance Test:ITest = 1; + +//TEST_INPUT: set inputBuffer = ubuffer(data=[0 0 1 0 1 0 0 0], stride=4) +RWStructuredBuffer inputBuffer; + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +[NumThreads(1, 1, 1)] +void computeMain() +{ + // CHECK: 1 + outputBuffer[0] = inputBuffer[0].value; +} diff --git a/tests/bugs/half-coercion.slang b/tests/bugs/half-coercion.slang new file mode 100644 index 0000000000..43a12cf895 --- /dev/null +++ b/tests/bugs/half-coercion.slang @@ -0,0 +1,10 @@ +//DIAGNOSTIC_TEST:SIMPLE(filecheck=CHECK): -target spirv + +// CHECK-NOT: warning + +RWStructuredBuffer output; +[numthreads(1,1,1)] +void computeMain() +{ + output[0] = 0; // coercion from 0 to half should not result in a warning. +} \ No newline at end of file diff --git a/tests/language-feature/modules/gh-5799/Common/Common.slang b/tests/language-feature/modules/gh-5799/Common/Common.slang new file mode 100644 index 0000000000..d60907cb69 --- /dev/null +++ b/tests/language-feature/modules/gh-5799/Common/Common.slang @@ -0,0 +1,3 @@ +module Common; + +__include Common.Test; diff --git a/tests/language-feature/modules/gh-5799/Common/Test.slang b/tests/language-feature/modules/gh-5799/Common/Test.slang new file mode 100644 index 0000000000..231519ae7e --- /dev/null +++ b/tests/language-feature/modules/gh-5799/Common/Test.slang @@ -0,0 +1,8 @@ +//#pragma once +#include "Simple.h" +// +//#ifndef HOST_CODE +//implementing Common; +//#endif +implementing Common; + diff --git a/tests/language-feature/modules/gh-5799/HelloTriangleFS.slang b/tests/language-feature/modules/gh-5799/HelloTriangleFS.slang new file mode 100644 index 0000000000..2d47b5b2b2 --- /dev/null +++ b/tests/language-feature/modules/gh-5799/HelloTriangleFS.slang @@ -0,0 +1,37 @@ +//TEST:SIMPLE(filecheck=CHECK): -target spirv -I $dirname + +//CHECK: OpEntryPoint + +// shaders.slang + +// +// This file provides a simple vertex and fragment shader that can be compiled +// using Slang. This code should also be valid as HLSL, and thus it does not +// use any of the new language features supported by Slang. +// + +import Scene.Scene; + +// Output of the vertex shader, and input to the fragment shader. +struct CoarseVertex +{ + float3 color; +}; + +// Output of the fragment shader +struct Fragment +{ + float4 color; +}; + + +// Fragment Shader + +[shader("fragment")] +float4 main( + CoarseVertex coarseVertex : CoarseVertex) : SV_Target +{ + float3 fragColor = coarseVertex.color; + + return float4(fragColor, 1.0); +} diff --git a/tests/language-feature/modules/gh-5799/Scene/Scene.slang b/tests/language-feature/modules/gh-5799/Scene/Scene.slang new file mode 100644 index 0000000000..9551c9f08a --- /dev/null +++ b/tests/language-feature/modules/gh-5799/Scene/Scene.slang @@ -0,0 +1,3 @@ +module Scene; +import Common.Common; + diff --git a/tests/language-feature/modules/gh-5799/Simple.h b/tests/language-feature/modules/gh-5799/Simple.h new file mode 100644 index 0000000000..e69de29bb2 diff --git a/tests/language-feature/modules/typealias/lib.slang b/tests/language-feature/modules/typealias/lib.slang new file mode 100644 index 0000000000..72a31ef09f --- /dev/null +++ b/tests/language-feature/modules/typealias/lib.slang @@ -0,0 +1,3 @@ +//TEST_IGNORE_FILE: + +typealias i32 = int32_t; diff --git a/tests/language-feature/modules/typealias/main.slang b/tests/language-feature/modules/typealias/main.slang new file mode 100644 index 0000000000..965aec6425 --- /dev/null +++ b/tests/language-feature/modules/typealias/main.slang @@ -0,0 +1,24 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -output-using-type + +// Regression test for bug https://github.com/shader-slang/slang/issues/5808 + +// Using a type defined from a different module +// in a for loop should work. + +import lib; + +//TEST_INPUT:set output = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer output; + +[numthreads(1,1,1)] +void computeMain() +{ + // CHECK: 0 + // CHECK: 1 + // CHECK: 2 + // CHECK: 3 + for (i32 i = 0; i < 4; i++) + { + output[i] = i; + } +} \ No newline at end of file diff --git a/tools/slang-test/slang-test-main.cpp b/tools/slang-test/slang-test-main.cpp index ae6eb62164..376d0e0bd2 100644 --- a/tools/slang-test/slang-test-main.cpp +++ b/tools/slang-test/slang-test-main.cpp @@ -524,6 +524,17 @@ static SlangResult _extractCommand(const char** ioCursor, UnownedStringSlice& ou } } +static void applyMacroSubstitution(String filePath, TestDetails& details) +{ + for (auto& arg : details.options.args) + { + arg = StringUtil::replaceAll( + arg.getUnownedSlice(), + toSlice("$dirname"), + Path::getParentDirectory(filePath).getUnownedSlice()); + } +} + // Try to read command-line options from the test file itself static SlangResult _gatherTestsForFile( TestCategorySet* categorySet, @@ -597,6 +608,7 @@ static SlangResult _gatherTestsForFile( if (command == "TEST") { SLANG_RETURN_ON_FAIL(_gatherTestOptions(categorySet, &cursor, testDetails.options)); + applyMacroSubstitution(filePath, testDetails); // See if the type of test needs certain APIs available const RenderApiFlags testRequiredApis = @@ -611,6 +623,7 @@ static SlangResult _gatherTestsForFile( else if (command == "DIAGNOSTIC_TEST") { SLANG_RETURN_ON_FAIL(_gatherTestOptions(categorySet, &cursor, testDetails.options)); + applyMacroSubstitution(filePath, testDetails); // Apply the file wide options _combineOptions(categorySet, fileOptions, testDetails.options);