-
Notifications
You must be signed in to change notification settings - Fork 28
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Initial Support for xeus-cpp-lite #199
Changes from 3 commits
665dff7
7b92a8f
83f6d17
ce35626
b04f641
29e82ee
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -84,7 +84,7 @@ if(EMSCRIPTEN) | |
set(XEUS_CPP_USE_SHARED_XEUS_CPP OFF) | ||
set(XEUS_CPP_BUILD_TESTS OFF) | ||
# ENV (https://github.com/emscripten-core/emscripten/commit/6d9681ad04f60b41ef6345ab06c29bbc9eeb84e0) | ||
set(EMSCRIPTEN_FEATURES "${EMSCRIPTEN_FEATURES} -s \"EXTRA_EXPORTED_RUNTIME_METHODS=[ENV']\"") | ||
set(EMSCRIPTEN_FEATURES "${EMSCRIPTEN_FEATURES} -s \"EXPORTED_RUNTIME_METHODS=[ENV']\"") | ||
endif() | ||
|
||
# Dependencies | ||
|
@@ -152,8 +152,22 @@ function(configure_kernel kernel) | |
endfunction() | ||
|
||
message("Configure kernels: ...") | ||
configure_kernel("/share/jupyter/kernels/xcpp17/") | ||
configure_kernel("/share/jupyter/kernels/xcpp20/") | ||
if(NOT EMSCRIPTEN) | ||
anutosh491 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
configure_kernel("/share/jupyter/kernels/xcpp17/") | ||
configure_kernel("/share/jupyter/kernels/xcpp20/") | ||
else() | ||
# TODO: Currently jupyterlite-xeus and xeus-lite do not provide | ||
# methods to fetch information from the arguments present in the | ||
# generated emscripten kernel. | ||
# The following needs to be done here : | ||
# 1) We need to configure the kernel properly | ||
# Check issue https://github.com/compiler-research/xeus-cpp/issues/185. | ||
# 2) Once the above is done we need to add support in jupyterlite-xeus & xeus-lite | ||
# to be able to deal with arguments present in kernel.json | ||
# 3) Finally we should fetch the C++ version from the kernel.json file and | ||
# be able to pass it to our wasm interpreter rather than forcing a version. | ||
configure_kernel("/share/jupyter/kernels/xcpp20/") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. TODO with respect to supporting more kernels raised here. We would be going ahead with xcpp20 for now but would like to support all. |
||
endif() | ||
|
||
# Source files | ||
# ============ | ||
|
@@ -401,8 +415,22 @@ if(EMSCRIPTEN) | |
xeus_cpp_set_kernel_options(xcpp) | ||
xeus_wasm_compile_options(xcpp) | ||
xeus_wasm_link_options(xcpp "web,worker") | ||
target_link_options(xcpp PUBLIC | ||
-sEXPORTED_RUNTIME_METHODS=FS,PATH,ERRNO_CODES | ||
anutosh491 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
# add sysroot location here | ||
--preload-file ${SYSROOT_PATH}/include@/include | ||
) | ||
# TODO: Emscripten supports preloading files just once before it generates | ||
# the xcpp.data file (containing the binary representation of the file(s) we | ||
# want to include in our application). | ||
# Hence although we are adding supporting for Standard Headers, Libraries etc | ||
# through emscripten's sysroot for now, we need to do the following: | ||
# 1) Enable CppInterOp to provide us with a resource dir. | ||
# 2) If the above cannot be done, we can use the resource dir provided | ||
# by llvm on emscripten-forge but would involve adding a dependency. | ||
# 3) Shift the resource dir and the sysroot to a common location. | ||
# 4) Preload everything required together. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. TODO with respect to preloading raised here. Please let me know of any questions you'll have or this needs to be rephrased. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Technically speaking in the long run we would have a better method to load files (and libraries like clad, xsimd etc) dynamically using |
||
endif() | ||
|
||
# Tests | ||
# ===== | ||
|
||
|
@@ -492,6 +520,7 @@ if(EMSCRIPTEN) | |
install(FILES | ||
"$<TARGET_FILE_DIR:xcpp>/xcpp.js" | ||
"$<TARGET_FILE_DIR:xcpp>/xcpp.wasm" | ||
"$<TARGET_FILE_DIR:xcpp>/xcpp.data" | ||
DESTINATION ${CMAKE_INSTALL_BINDIR}) | ||
endif () | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -87,13 +87,15 @@ pushd build | |
export PREFIX=$MAMBA_ROOT_PREFIX/envs/xeus-cpp-wasm-host | ||
export CMAKE_PREFIX_PATH=$PREFIX | ||
export CMAKE_SYSTEM_PREFIX_PATH=$PREFIX | ||
export SYSROOT_PATH=$HOME/emsdk/upstream/emscripten/cache/sysroot | ||
|
||
emcmake cmake \ | ||
-DCMAKE_BUILD_TYPE=Release \ | ||
-DCMAKE_PREFIX_PATH=$PREFIX \ | ||
-DCMAKE_INSTALL_PREFIX=$PREFIX \ | ||
-DXEUS_CPP_EMSCRIPTEN_WASM_BUILD=ON \ | ||
-DCMAKE_FIND_ROOT_PATH_MODE_PACKAGE=ON \ | ||
-DSYSROOT_PATH=$SYSROOT_PATH \ | ||
.. | ||
emmake make install | ||
``` | ||
|
@@ -105,12 +107,20 @@ micromamba activate xeus-lite-host | |
python -m pip install jupyterlite-xeus | ||
jupyter lite build --XeusAddon.prefix=$PREFIX | ||
``` | ||
|
||
We now need to shift necessary files like `xcpp.data` which contains the binary representation of the file(s) | ||
we want to include in our application. As of now this would contain all important files like Standard Headers, | ||
Libraries etc coming out of emscripten's sysroot. Assuming we are still inside build we should do the following | ||
```bash | ||
cp xcpp.data _output/extensions/@jupyterlite/xeus/static | ||
cp $PREFIX/lib/libclangCppInterOp.so _output/extensions/@jupyterlite/xeus/static | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Though we would always need to copy The second line here shifting Hence this is temporary. |
||
``` | ||
|
||
Once the Jupyter Lite site has built you can test the website locally by executing | ||
```bash | ||
jupyter lite serve --XeusAddon.prefix=$PREFIX | ||
``` | ||
|
||
|
||
## Trying it online | ||
|
||
To try out xeus-cpp interactively in your web browser, just click on the binder link: | ||
|
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -28,6 +28,7 @@ using Args = std::vector<const char*>; | |||||
|
||||||
void* createInterpreter(const Args &ExtraArgs = {}) { | ||||||
Args ClangArgs = {/*"-xc++"*/"-v"}; // ? {"-Xclang", "-emit-llvm-only", "-Xclang", "-diagnostic-log-file", "-Xclang", "-", "-xc++"}; | ||||||
#ifndef EMSCRIPTEN | ||||||
if (std::find_if(ExtraArgs.begin(), ExtraArgs.end(), [](const std::string& s) { | ||||||
return s == "-resource-dir";}) == ExtraArgs.end()) { | ||||||
std::string resource_dir = Cpp::DetectResourceDir(); | ||||||
|
@@ -42,6 +43,7 @@ void* createInterpreter(const Args &ExtraArgs = {}) { | |||||
ClangArgs.push_back("-isystem"); | ||||||
ClangArgs.push_back(CxxInclude.c_str()); | ||||||
} | ||||||
#endif | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. These instructions( There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||||||
ClangArgs.insert(ClangArgs.end(), ExtraArgs.begin(), ExtraArgs.end()); | ||||||
// FIXME: We should process the kernel input options and conditionally pass | ||||||
// the gpu args here. | ||||||
|
@@ -73,6 +75,7 @@ namespace xcpp | |||||
static std::string get_stdopt() | ||||||
{ | ||||||
// We need to find what's the C++ version the interpreter runs with. | ||||||
#ifndef EMSCRIPTEN | ||||||
const char* code = R"( | ||||||
int __get_cxx_version () { | ||||||
#if __cplusplus > 202302L | ||||||
|
@@ -93,12 +96,14 @@ int __get_cxx_version () { | |||||
} | ||||||
__get_cxx_version () | ||||||
)"; | ||||||
|
||||||
auto cxx_version = Cpp::Evaluate(code); | ||||||
return std::to_string(cxx_version); | ||||||
#else | ||||||
constexpr int cxx_version = 20; | ||||||
return std::to_string(cxx_version); | ||||||
anutosh491 marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
#endif | ||||||
anutosh491 marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
} | ||||||
|
||||||
|
||||||
interpreter::interpreter(int argc, const char* const* argv) : | ||||||
xmagics() | ||||||
, p_cout_strbuf(nullptr) | ||||||
|
@@ -357,7 +362,9 @@ __get_cxx_version () | |||||
|
||||||
void interpreter::init_includes() | ||||||
{ | ||||||
#ifndef EMSCRIPTEN | ||||||
Cpp::AddIncludePath((xeus::prefix_path() + "/include/").c_str()); | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This needs to go in createInterpreter as I suggested in previous comment. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think we should be able to do without it but let's do the above if you think we would need that ! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We had that functionality before and I do not see anything that explains why we should drop it. I think we should drop it generally and solve the problem with parameters to the kernel. If we want that pleas update the commit message and we can drop. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmm, maybe check this comment (#199 (comment)) So
Hence I removed it. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You won't see a difference with that command as the include path is added at a later stage than printing the invocation commands. Whatever, if somebody wants to re-enable this, we can solve it in a more consistent way by adding a |
||||||
#endif | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This can go in There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmm kinda confused as to why this should be treated as a system include rather than using Do we want to have something like There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As we won't be interested in the
We could only enable it for the non wasm case rather than doing this.
The same applies for
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Isn’t that folder containing other conda packages? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, I get it. Let's do one thing. As we don't expect the init_include, init_magic or init_preamble to work for starters. Hence a place we could start with rather than addressing everything separately is this as what I've done in my latest commit.
And one by one whatever we expect to get working for eg
We could start separating those out. And the ones that we don't expect to work for eg EDIT: Argh, playing with the CI a bit tells me that even the above might not be a great approach, hence reverted the changes. Can't think of a nice way to address this for now. Maybe let's keep it like this for now and make a point to improve in near future ? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why not doing what I suggested in the first place? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. My doubt is do we get rid of the init_includes method overall and just shift the functionality to createInterpreter ? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
That' what I am asking in this PR. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Actually you know what, the That's because it's overlapping with the following in kernel.json.in xeus-cpp/share/jupyter/kernels/xcpp20/kernel.json.in Lines 12 to 13 in a7649c0
So the location we are interested in is taken care of anyways as I see the following locally coming out of
|
||||||
} | ||||||
|
||||||
void interpreter::init_preamble() | ||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
EXTRA_EXPORTED_RUNTIME_METHODS
had been deprecated in favour ofEXPORTED_RUNTIME_METHODS
since2.0.18