summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2025-07-28Update Rich Presence location on region changeErik Kundiman
I had to find a spot in source code where it doesn't cause a crash (it did in LLAgent::setRegion), but I'm not removing the one in llstartup.cpp because on login, the one in llviewermessage.cpp gets only the placeholder coords (10, 10, 10).
2025-07-28Location for Discord Rich Presence Activity StateErik Kundiman
I was going to use LLAgentUI::buildLocationString but there's no location format that shows only region and coords without having to have the parcel name empty, so I copied buildLocationString implementation in the case of LOCATION_FORMAT_NO_MATURITY but when the parcel name is empty. I had to make updateDiscordActivity check agent's ID and the existence of agent avatar pointer first before trying to set Activity Details or State, cause I like the "Show location" button be checkable not only after online when both the ID & pointer will have existed. I think this way is simpler than programmatically enabling the "Show location" button after the user is logged in. I put a trigger to Activity update somewhere after the user is logged in for now, not yet after a TP. The elapsed time gets reset whenever Activity is updated for now, but I'll try to make elapsed time extended instead. No Party for now, because I couldn't find a way to make a Party shown without showing its CurrentSize (I could still get away not showing its MaxSize by setting it to 0), so the State (location) is shown above the elapsed time, not on the right of it. I'll try to figure out to get some representative numbers for its CurrentSize & MaxSize next. Also no privacy on hiding the username for now, until the UI is ready.
2025-07-27Connect to Discord now through privacy tabErik Kundiman
Now the access token is saved the way passwords are saved, but without a username, so we can have some persistence without having to implement an OAuth2 backend server cause we would have to store those tokens there anyway still and that would even require more disclosure that the user token gets saved on a server, and it's just simpler to not go that way. Discord Social SDK doesn't have to have a helper for sending code to a custom server anyway, that we would have to have some asynchronous HTTP requestor ready. Show location check button gets enabled only when Discord integration is enabled, though it's not functioning yet.
2025-07-27Shorten Discord-related local variable namesErik Kundiman
and minimise difference from SL main.
2025-07-27panel_preferences_privacy tabsSecret Foxtail
Add tab and checkboxes for discord social SDK integration options to panel_preferences_privacy.xml
2025-07-27Move Discord-related code to llappviewer.cppErik Kundiman
The doFrame is the one called over and over again, so running the Discord callbacks from there shouldn't have one extra function overhead, while running the Discord initialisation is only once so it's much more okay to have the extra function overhead there.
2025-07-26Update test plan to match current functionality per suggested/requested ↵Darl
change in #4406
2025-07-26Fix incorrectly calculated number in comment and where it was referencedDarl
2025-07-26Media first click interact large number value fixDarl
2025-07-25Merge pull request #4442 from secondlife/geenz/main-to-2025.05Jonathan "Geenz" Goodman
Geenz/main to 2025.05
2025-07-25Merge branch 'main' into release/2025.05Jonathan "Geenz" Goodman
2025-07-25Media first click interact self check fix (#4406, #4426)Darl
2025-07-25#3969 Log time it takes to create inventory from cacheAndrey Kleshchev
2025-07-25#4415 fix crash when cancelling large model process on MacOSMaxim Nikolenko
2025-07-23#4400 Model Import "use lod above" was not updatingAndrey Kleshchev
2025-07-23Reorganise shared macros closer to "attach" codeErik Kundiman
and reindent the appearance manager functions to call to match how they will be placed on the combining macro.
2025-07-23Minimal @remoutfit[:<part>]=force implementationErik Kundiman
Copying from LLEditTakeOff implementation in llviewermenu.cpp.
2025-07-23@detach:<folder_name>=force implementationErik Kundiman
Per specification, the folder must be directly under "#RLV" for this to work, hence not using the shared folder ID retrieval macro.
2025-07-23Shared macros for attach-related RLV commandsErik Kundiman
2025-07-23RLV shared folder needs to be directly under rootErik Kundiman
2025-07-23Fix linking to c_dfDIJoystick error when on SDLErik Kundiman
Copied from llwindowwin32.cpp.
2025-07-22#4393 Handle unknown exceptions in uploader betterAndrey Kleshchev
Output is highly technical, but better than nothing
2025-07-22#4318 Warn or log when texture gets scaled downAndrey Kleshchev
for material and model upload
2025-07-21#4399 Crash at load_face_from_dom_trianglesAndrey Kleshchev
Since these offsets are used for idx[i+offset] where i starts from 0, they shouldn't be below 0 to not go out of bounds.
2025-07-21Merge branch 'main' into 2025.05Erik Kundiman
2025-07-21Dependency on libnss3 & libnspr4 on Debian/UbuntuErik Kundiman
for libcef.so. On a minimal system, those two wouldn't be pulled automatically by some other package(s).
2025-07-21Fix crash upon login on Linux aarch64Erik Kundiman
Tested on Debian Asahi so far, will try on Fedora Asahi next. I had to trace this down, setting Logging Level to Debug, and comparing SecondLife.log with a successful login on Linux x86-64. At first setWeight() in LLViewerVisualParam::setInfo seemed to be avoiding a crash too when commented out, but turns out it's still okay when re-enabled.
2025-07-19#4320 MacOS crash handlingAndrey Kleshchev
2025-07-19Exclude Debian arm64 from WebRTCErik Kundiman
When WebRTC was compiled with the viewer, we got this: Fatal error in: ../webrtc/src/media/engine/adm_helpers.cc, line 39 last system error: 88 Check failed: 0 == adm->Init() (0 vs. -1) Failed to initialize the ADM. This commit hasn't included the additional preprocessor macro for the platform in indra/newview/llvoiceclient.cpp yet, because there's no such macro yet to distinguish such distro from any other GNU/Linux distro.
2025-07-18Merge branch 'main' into 2025.05Erik Kundiman
2025-07-18Revert "LL_WEBRTC for marking WebRTC supporting platforms"Erik Kundiman
This reverts commit a8dfeed4632aad0233ff08d1efd950b620fd1be7.
2025-07-18Add one more tester to the teamErik Kundiman
2025-07-18Bring back Arch install prefix setting instructionErik Kundiman
previously unintentionally left out from commit 829e4
2025-07-18Fix incomplete type & forward declaration GCC errorErik Kundiman
In file included from /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/lltrace.h:38, from /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llfasttimer.h:31, from /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llviewerprecompiledheaders.h:61, from /usr/home/erik/Documents/Megapahit/viewer/build-linux-x86_64/newview/CMakeFiles/megapahit.dir/cmake_pch.hxx:5, from <command-line>: /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h: In instantiation of ‘void LLPointer<Type>::ref() [with Type = LLViewerObject]’: /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h:60:9: required from ‘LLPointer<Type>::LLPointer(Type*) [with Type = LLViewerObject]’ /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llreflectionmap.h:127:47: required from here /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h:174:23: error: invalid use of incomplete type ‘class LLViewerObject’ 174 | mPointer->ref(); | ~~~~~~~~~~^~~ In file included from /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llviewerregion.h:45, from /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llagentlanguage.cpp:32: /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llreflectionmap.h:33:7: note: forward declaration of ‘class LLViewerObject’ 33 | class LLViewerObject; | ^~~~~~~~~~~~~~ /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h: In instantiation of ‘void LLPointer<Type>::unref() [with Type = LLViewerObject]’: /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h:92:9: required from ‘LLPointer<Type>::~LLPointer() [with Type = LLViewerObject]’ /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llreflectionmap.h:127:47: required from here /usr/home/erik/Documents/Megapahit/viewer/indra/llcommon/llpointer.h:184:19: error: invalid use of incomplete type ‘class LLViewerObject’ 184 | temp->unref(); | ~~~~~~^~~~~ /usr/home/erik/Documents/Megapahit/viewer/indra/newview/llreflectionmap.h:33:7: note: forward declaration of ‘class LLViewerObject’ 33 | class LLViewerObject; | ^~~~~~~~~~~~~~
2025-07-18Merge tag 'Second_Life_Release#f5d350fb-2025.05-gltf-mesh-import' into 2025.05Erik Kundiman
2025-07-18Merge branch 'main' into 2025.05Erik Kundiman
2025-07-17Merge pull request #4381 from secondlife/geenz/frametime-events-per-minuteJonathan "Geenz" Goodman
Add support for frametime events per minute.
2025-07-17Add support for frametime events per minute.Jonathan "Geenz" Goodman
2025-07-17Merge pull request #4380 from secondlife/andreyk/gltf_mesh_importAndrey Kleshchev
Merge develop into gltf mesh import
2025-07-17Merge branch 'develop' into gltf_mesh_importAndrey Kleshchev
2025-07-17Reapply "Merge develop into glTF mesh import"Andrey Kleshchev
To simplify merging into mesh import branch This reverts commit b0c951ffe348f478f27a85720cc7aeffea32fe73.
2025-07-16#4353 abbreviate text label for standard deviationMaxim Nikolenko
2025-07-16widgets/Stepper adjustmentSecret Foxtail
Make downstepper better match upstepper
2025-07-16#4349 fix repeats cannot be adjusted for specular when a normal map is not ↵Maxim Nikolenko
applied
2025-07-15#4204 Cache material names, centralize texture index validationAndrey Lihatskiy
2025-07-14#4294 Make upload order more deterministic #2Andrey Kleshchev
2025-07-14#4204 Refactor material name and texture handling in GLTF loaderAndrey Lihatskiy
2025-07-14#4204 Cache processed materialsAndrey Lihatskiy
2025-07-12Rich Presence support using Discord Social SDKErik Kundiman
Download DiscordSocialSdk-1.4.9649.zip https://discord.com/developers/applications/1393451183741599796/social-sdk/downloads to your ~/Downloads folder. Add -DUSE_DISCORD:BOOL=ON to your cmake line. The authorisation is triggered by selecting Help > Discord Social. It seems that the user will need to do this every time they want Rich Presence support on the viewer while using Discord. The Discord app is still set to be a public client in the OAuth2 tab, I'm going to try to make it work with the app set to be a confidential client, next. All Discord-related code are contained within one file, llstartup.cpp, and other classes access it through some opaque layer, static functions, otherwise we'd get these "duplicate symbol" linking errors.
2025-07-12#4294 Make upload order more deterministicAndrey Kleshchev
to make root prim more deterministic instead of being random each try