diff options
| author | kaizhangNV <149626564+kaizhangNV@users.noreply.github.com> | 2024-07-23 10:45:26 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-07-23 08:45:26 -0700 |
| commit | 986256ffb92ab7c8fc7cf9f2c424919a439a824f (patch) | |
| tree | 260e37bd439275e3398d16fe238b20cd00d08cb7 /source/slang | |
| parent | c28d8b6aec721fa3350fc52647f1572a353f6151 (diff) | |
Feature/capture (#4625)
* Add decoder
* Add a replay executable to consume the decoded content
Add file-processor.cpp/h where we implement the logic to process
the captured file block by block. Each block is:
function header + parameter buffer + function tailer + function
output[optional].
After reading one block, the block of data is sent to decoder module
to dispatch the corresponding API.
Add slang-decoder.cpp/h where we implement the logic to dispatch
the slang API according to the input block data.
- Rename api_callId.h to capture-format.h
- Renmae capture_utility.cpp to capture-utility.cpp
- Renmae capture_utility.h to capture-utility.h
- Change the #include file name accordingly.
* Reorganize source files structure
Move all the capture logic code into `capture` directory.
- the capture code will be build with slang dll.
Move all the replay logic code into `relay` directoy.
- the replay code is not part of slang dll, it will be built
as a stand alone binary and link against slang dll.
Change the #include file names accordingly.
Add tools/slang-replay/main.cpp for the slang-replay stand alone
binary place holder. Will implement it later.
Update premake5.lua accordingly.
* Update cmake files
Update cmake files to change the build process for
capture and relay system.
- capture component should be build with slang dll, so we
should not include replay component.
- replay component should be a separate executable tool, which
should not include capture component.
- In order to easy use our current cmake infrastructure, move
the shared files to a `util` folder
- change the header include path
* Redesgin the interfaces of consumers
Fix some issues in capture
Finish implementing all slang-decoder functions
* Fix the AppleClang build issue
* Address few comments
- Fix the weird indent issues.
- Correct the function name for CreateGlobalSession()
- Rename file-processor to captureFile-processor to be more specific.
- Use Slang::List instead of std::vector
* record/replay: name refactor change
Refactor the naming.
Change the name "encoder/capture" to "record".
Diffstat (limited to 'source/slang')
| -rw-r--r-- | source/slang/CMakeLists.txt | 11 | ||||
| -rw-r--r-- | source/slang/slang-api.cpp | 12 |
2 files changed, 12 insertions, 11 deletions
diff --git a/source/slang/CMakeLists.txt b/source/slang/CMakeLists.txt index 27019f41a..fd20bbe22 100644 --- a/source/slang/CMakeLists.txt +++ b/source/slang/CMakeLists.txt @@ -161,6 +161,11 @@ set(SLANG_LOOKUP_GENERATOR_OUTPUT_DIR set(SLANG_LOOKUP_GENERATED_SOURCE "${SLANG_LOOKUP_GENERATOR_OUTPUT_DIR}/slang-lookup-GLSLstd450.cpp" ) +set(SLANG_RECORD_REPLAY_SYSTEM + "${slang_SOURCE_DIR}/source/slang-record-replay/record" + "${slang_SOURCE_DIR}/source/slang-record-replay/util" +) + add_custom_command( OUTPUT ${SLANG_LOOKUP_GENERATED_SOURCE} COMMAND @@ -201,10 +206,6 @@ slang_add_target( FOLDER generated ) -set(SLANG_CAPTURE_REPLAY_SYSTEM - "${slang_SOURCE_DIR}/source/slang-capture-replay" -) - # # Generate an embeddable stdlib # @@ -243,7 +244,7 @@ configure_file(${slang_SOURCE_DIR}/slang-tag-version.h.in slang-version-header/s # set(slang_common_args - EXTRA_SOURCE_DIRS ${SLANG_CAPTURE_REPLAY_SYSTEM} + EXTRA_SOURCE_DIRS ${SLANG_RECORD_REPLAY_SYSTEM} USE_EXTRA_WARNINGS LINK_WITH_PRIVATE core diff --git a/source/slang/slang-api.cpp b/source/slang/slang-api.cpp index 250b9edf3..c4f668fb2 100644 --- a/source/slang/slang-api.cpp +++ b/source/slang/slang-api.cpp @@ -5,8 +5,8 @@ #include "slang-repro.h" #include "../core/slang-shared-library.h" -#include "../slang-capture-replay/slang-global-session.h" -#include "../slang-capture-replay/capture_utility.h" +#include "../slang-record-replay/record/slang-global-session.h" +#include "../slang-record-replay/util/record-utility.h" // implementation of C interface @@ -119,11 +119,11 @@ SLANG_API SlangResult slang_createGlobalSession( } // Check if the SLANG_CAPTURE_ENABLE_ENV is enabled - if (SlangCapture::isCaptureLayerEnabled()) + if (SlangRecord::isRecordLayerEnabled()) { - SlangCapture::GlobalSessionCapture* globalSessionCapture = - new SlangCapture::GlobalSessionCapture(globalSession.detach()); - Slang::ComPtr<SlangCapture::GlobalSessionCapture> result(globalSessionCapture); + SlangRecord::GlobalSessionRecorder* globalSessionRecorder = + new SlangRecord::GlobalSessionRecorder(globalSession.detach()); + Slang::ComPtr<SlangRecord::GlobalSessionRecorder> result(globalSessionRecorder); *outGlobalSession = result.detach(); } else |
