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

Add serverside isPedReloadingWeapon #3295

Conversation

znvjder
Copy link
Contributor

@znvjder znvjder commented Jan 16, 2024

Adds a new function:

bool isPedReloadingWeapon(ped thisPed)

Related to #1525 and #1529 due to lack of compatibility with BitStream.

@znvjder znvjder marked this pull request as ready for review January 16, 2024 23:31
@@ -68,6 +68,7 @@ CPed::CPed(CPedManager* pPedManager, CElement* pParent, unsigned short usModel)
m_fGravity = 0.008f;
m_bDoingGangDriveby = false;
m_bStealthAiming = false;
m_bReloadingWeapon = false;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's better to move it into the member initializer list.

// Add new ones in separate structs
struct
{
bool bIsReloadingWeapon : 1;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why not just put it into the existing data struct?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I want to maintain compatibility with older BitStream version on the server/client.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For this it's enough to permute BITCOUNT depending on a bitstream version.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Earlier, I tried to apply it like this, but there were issues with comparing the bitstream versions with different client <-> server versions.

@tederis tederis added the enhancement New feature or request label Jan 27, 2024
Comment on lines +272 to +273
bool IsReloadingWeapon() const { return m_bReloadingWeapon; }
void SetReloadingWeapon(bool bState) { m_bReloadingWeapon = bState; }
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

noexcept

@@ -1617,3 +1620,8 @@ int CLuaPedDefs::TakeAllWeapons(lua_State* luaVM)
lua_pushboolean(luaVM, false);
return 1;
}

bool CLuaPedDefs::IsPedReloadingWeapon(CPed* const ped)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

noexcept

@@ -79,4 +79,6 @@ class CLuaPedDefs : public CLuaDefs
LUA_DECLARE(SetPedHeadless);
LUA_DECLARE(SetPedFrozen);
LUA_DECLARE(reloadPedWeapon);

static bool IsPedReloadingWeapon(CPed* const ped);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

noexcept

@@ -316,6 +319,7 @@ class CPed : public CElement
bool m_bFrozen;
bool m_bStealthAiming;
CVehicle* m_pJackingVehicle;
bool m_bReloadingWeapon;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you could, please don't use hungarian notation: bool m_reloadingWeapon;

@Nico8340
Copy link
Contributor

Nico8340 commented Jan 9, 2025

#3936

@znvjder znvjder closed this Jan 9, 2025
@znvjder znvjder deleted the feature/server-isPedWeaponReloading branch January 9, 2025 08:13
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants