Skip to content
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

export operator new and operator delete #4644

Closed
huangqinjin opened this issue Apr 30, 2024 · 10 comments
Closed

export operator new and operator delete #4644

huangqinjin opened this issue Apr 30, 2024 · 10 comments
Labels
bug Something isn't working compiler Compiler work involved invalid This issue is incorrect or by design modules C++23 modules, C++20 header units

Comments

@huangqinjin
Copy link

operator new and operator delete are exported in vcruntime_new.h

extern "C++" {
_VCRT_EXPORT_STD _NODISCARD _Ret_notnull_ _Post_writable_byte_size_(_Size) _VCRT_ALLOCATOR
void* __CRTDECL operator new(
    size_t _Size
    );

_VCRT_EXPORT_STD void __CRTDECL operator delete(
    void* _Block
    ) noexcept;
}

But according to https://eel.is/c++draft/basic.stc.dynamic#general-2, there functions are implicitly declared in global scope in each translation unit and are attached to the global module. So re-exporting them may violates https://eel.is/c++draft/module.interface#6

A redeclaration of an entity X is implicitly exported if X was introduced by an exported declaration; otherwise it shall not be exported.

Related llvm/llvm-project#90620.

@frederick-vs-ja
Copy link
Contributor

frederick-vs-ja commented May 1, 2024

Seems to be a compiler bug - sounds like that P2465R3 "Standard Library Modules std And std.compat" needs compilers to change.

Oh, perhaps I was wrong. They should be properly made available in the std module.

@StephanTLavavej StephanTLavavej added bug Something isn't working modules C++23 modules, C++20 header units labels May 1, 2024
@StephanTLavavej
Copy link
Member

extern "C++" will also attach to the global module.

@cdacamar, is this a Stuff Just Works scenario? I can't control your implicit declarations emitted by the compiler.

@cdacamar
Copy link
Contributor

cdacamar commented May 1, 2024

This does fall under the "it just works" scenario for MSVC. One possible workaround would be to move the vcruntime header to the GMF and do something like:

export using ::operator new;
export using ::operator delete;

To enable users to access them from the module interface.

@StephanTLavavej
Copy link
Member

This also affects rttidata.h's forward declaration of type_info. Because I'm lazy, I'd like the compiler to take care of its own implicit declarations (i.e. creating special exemptions from the "must export on first decl" rule), instead of having to restructure how I export VCRuntime entities yet again.

@huangqinjin
Copy link
Author

Could we adopt export using for operator new, operator delete as well as type_info?

By removing _VCRT_EXPORT_STD from their declarations and export using them in std.ixx, clang can import std from STL for example:

main.cpp
import std;
int main() {
    std::println("{}", "Hello, World!");
}

by command

clang -std=c++23 -Wno-reserved-module-identifier -Wno-include-angled-in-module-purview -fprebuilt-module-path=. -fmodule-output=std.pcm -x c++-module "%VCToolsInstallDir%/modules/std.ixx" -x c++ main.cpp -o hello.exe

For clang-cl, -x c++-module is not supported currently (I have sent a PR to LLVM to enable this), a workaround could be

std.cppm
#include <modules/std.ixx>

and build with command

clang-cl /EHsc /std:c++latest -Wno-reserved-module-identifier -Wno-include-angled-in-module-purview /clang:-fprebuilt-module-path=. /clang:-fmodule-output -I"%VCToolsInstallDir%/" std.cppm main.cpp /Fehello.exe

@StephanTLavavej
Copy link
Member

At this point I haven't yet validated Clang with import std;. My preference would be for them to similarly special-case their pre-declarations, but if I must modify std.ixx then I will.

@frederick-vs-ja
Copy link
Contributor

frederick-vs-ja commented May 9, 2024

Could we adopt export using for operator new, operator delete as well as type_info?

IMO type_info shouldn't be treated specially as it is not implicitly declared.

@huangqinjin
Copy link
Author

Could we adopt export using for operator new, operator delete as well as type_info?

IMO type_info shouldn't be treated specially as it is not implicitly declared.

It is at least for MSVC and clang-cl, if you declare union type_info; without any file included, compilers still complain about different declarations.

@huangqinjin
Copy link
Author

Since operator new and operator delete are implicitly declared, do they really need to be exported? Anyway we need to export the definition of type_info.

@StephanTLavavej StephanTLavavej added the compiler Compiler work involved label May 10, 2024
@huangqinjin
Copy link
Author

FYI. According to llvm/llvm-project#98583, extern "C++" is probably becoming an exception from https://eel.is/c++draft/module.interface#6. So re-exporting them with extern "C++" is no longer illegal.

Since Clang 19 landed the exception and added all options that are required to build C++ Modules, clang-cl (19.1.1) now can import std by

clang-cl /EHsc /std:c++latest -Wno-reserved-module-identifier -Wno-include-angled-in-module-purview -fprebuilt-module-path=. -fmodule-output=std.pcm -x c++-module "%VCToolsInstallDir%/modules/std.ixx" -x c++ main.cpp /Fehello.exe

Feel free to close this issue.

@StephanTLavavej StephanTLavavej closed this as not planned Won't fix, can't repro, duplicate, stale Jan 8, 2025
@StephanTLavavej StephanTLavavej added the invalid This issue is incorrect or by design label Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working compiler Compiler work involved invalid This issue is incorrect or by design modules C++23 modules, C++20 header units
Projects
None yet
Development

No branches or pull requests

4 participants