RFR: 8301302: Platform preferences API [v39]
Michael Strauß
mstrauss at openjdk.org
Wed Dec 6 20:38:47 UTC 2023
On Wed, 6 Dec 2023 19:59:25 GMT, Kevin Rushforth <kcr at openjdk.org> wrote:
>> Yes. This is the copy-and-swap idiom, where the copy is made by using a pass-by-value parameter.
>
> I see.
>
> I did happen to spot this compiler warning while compiling:
>
>
> .../VC/bin/x64/cl.exe /nologo /W3 /EHsc /c /DINLINE=__inline /DUNICODE /D_UNICODE /DWIN32 /DIAL /D_LITTLE_ENDIAN /DWIN32_LEAN_AND_MEAN /IC:/Users/kcr/dev/jdks/jdk-19.0.2/include /I.../jdk-19.0.2/include/win32 /O2 /MD /DNDEBUG -Imodules\javafx.graphics\build\gensrc\headers\javafx.graphics -Imodules\javafx.graphics\src\main\native-glass\win /Fomodules\javafx.graphics\build\native\glass\win\RoActivationSupport.obj modules\javafx.graphics\src\main\native-glass\win\RoActivationSupport.cpp
> VC\include\utility(103) : warning C4717: 'std::swap<RoException,0>': recursive on all control paths, function will cause runtime stack overflow
> modules\javafx.graphics\src\main\native-glass\win\RoActivationSupport.cpp(233) : warning C4717: 'RoException::operator=': recursive on all control paths, function will cause runtime stack overflow
>
>
> you can see that in your GHA build as well. I don't know for certain whether this is a problem in practice or not, but it would be good to eliminate the warning.
I can fix this by swapping the `message_` fields directly, which doesn't change the logic of the copy-and-swap.
-------------
PR Review Comment: https://git.openjdk.org/jfx/pull/1014#discussion_r1417949026
More information about the openjfx-dev
mailing list