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

Remove consts from defined structs to avoid errors with c++ #85

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

sebirdman
Copy link

This should properly resolve #51

@sebirdman sebirdman changed the title Remove consts from files to avoid errors with c++ Remove consts from defined structs to avoid errors with c++ Mar 5, 2020
@AppVeyorBot
Copy link

Build fff 85-appveyor failed (commit b27f8d19ad by @sebirdman)

@AppVeyorBot
Copy link

Build fff 86-appveyor failed (commit 6fb172869f by @sebirdman)

@sebirdman
Copy link
Author

I'm not sure what the tests are doing exactly, i'm not able to reproduce these failures on my machine

@johwech
Copy link

johwech commented May 2, 2020

The changes introduced by the original pull request require the fff.h to be not included within an extern "C" block when compiling with a cpp compiler.

I fixed the issue by wrapping an additional extern "C++" block around the whole fff.h:
https://ci.appveyor.com/project/johwech/fff/builds/32597466

Alternatively it's also possible to just fix the test and tell the users that fff.h cannot be included within an extern "C" segment when a CPP compiler is used:
https://ci.appveyor.com/project/johwech/fff/builds/32597324

@gndl
Copy link

gndl commented Mar 10, 2022

Hi,
first of all thank you for this great tool.
This PR allows me to use FFF, how can I help to get it integrated mainstream?

@meekrosoft meekrosoft force-pushed the master branch 2 times, most recently from b0792e6 to bdb7397 Compare August 4, 2022 08:23
@wulfgarpro wulfgarpro self-assigned this Aug 13, 2023
@leonardopsantos
Copy link

This feature would be great, but unfortunately the seems abandoned. There's a very ugly workaround that works for C++ compilers. Say that you want to test int foo(int a, const int b). In your test code, you can do:

foo.cpp:

bool foo(int a, const int b)
{
    ...
}

foo.hpp:

bool foo(int a, const int b);

test_foo.cpp:

#include <gtest/gtest.h>
#include <fff.h>

#include "foo.hpp"

DEFINE_FFF_GLOBALS;

extern "C" {

/**
 * Fakes
 */

FAKE_VALUE_FUNC(bool, __foo, int, int);

} // extern "C"

// Re-implementation of foo using linker-seam
// Must keep const-ness
bool foo(int a, const int b)
{
    // Call "actual fake"
    return __foo(a, (int) b);  // Need to use C-style casts to remove constness
}

Use __foo_fake normally, with RESET_FAKE(__foo), ASSERT_EQ(__foo_fake.call_count, 1);

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Attempting to FFF FreeRTOS.. getting "error: use of deleted function ... "
6 participants