diff options
| -rw-r--r-- | .github/workflows/build.yaml | 27 | ||||
| -rw-r--r-- | autobuild.xml | 108 | ||||
| -rwxr-xr-x | build.sh | 1 | ||||
| -rw-r--r-- | indra/llcommon/llcoros.cpp | 2 | ||||
| -rw-r--r-- | indra/llprimitive/llgltfmaterial.h | 13 | ||||
| -rw-r--r-- | indra/llprimitive/tests/llgltfmaterial_test.cpp | 2 | 
6 files changed, 82 insertions, 71 deletions
| diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 44f32c1c5d..4785273b78 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -5,7 +5,7 @@ on:    pull_request:    push:      branches: ["main", "release/*", "project/*"] -    tags: ["Second_Life_*"] +    tags: ["Second_Life*"]  jobs:    build: @@ -176,16 +176,22 @@ jobs:            # seen before, so numerous tests don't know about it.            [[ "$arch" == "MINGW6" ]] && arch=CYGWIN            export AUTOBUILD="$(which autobuild)" -          # Build with a tag like "Second_Life_Project_Shiny#abcdef0" to get a -          # viewer channel "Second Life Project Shiny" (ignoring "#hash", -          # needed to disambiguate tags). -          if [[ "$GITHUB_REF_TYPE" == "tag" && "${GITHUB_REF_NAME:0:12}" == "Second_Life_" ]] -          then viewer_channel="${GITHUB_REF_NAME%#*}" -               export viewer_channel="${viewer_channel//_/ }" -          else export viewer_channel="Second Life Test" + +          # determine the viewer channel from the branch name +          branch=$AUTOBUILD_VCS_BRANCH +          IFS='/' read -ra ba <<< $branch +          prefix=${ba[0]} +          if [ "$prefix" == "project" ]; then +              IFS='_' read -ra prj <<< "${ba[1]}" +              # uppercase first letter of each word +              export viewer_channel="Second Life Project ${prj[*]^}" +          elif  [[ "$prefix" == "release" || "$prefix" == "main" ]]; +          then +              export viewer_channel="Second Life Release" +          else +              export viewer_channel="Second Life Test"            fi            echo "viewer_channel=$viewer_channel" >> "$GITHUB_OUTPUT" -            # On windows we need to point the build to the correct python            # as neither CMake's FindPython nor our custom Python.cmake module            # will resolve the correct interpreter location. @@ -354,7 +360,8 @@ jobs:    release:      needs: [build, sign-and-package-windows, sign-and-package-mac]      runs-on: ubuntu-latest -    if: github.ref_type == 'tag' && startsWith(github.ref_name, 'Second_Life_') +      # Build with a tag like "Second_Life#abcdef0" to generate a release page (used for builds we are planning to deploy). +    if: github.ref_type == 'tag' && startsWith(github.ref_name, 'Second_Life')      steps:        - uses: actions/download-artifact@v4          with: diff --git a/autobuild.xml b/autobuild.xml index a876af5f0b..5c5919d0c4 100644 --- a/autobuild.xml +++ b/autobuild.xml @@ -455,18 +455,6 @@        </map>        <key>emoji_shortcodes</key>        <map> -        <key>canonical_repo</key> -        <string>https://github.com/secondlife/3p-emoji-shortcodes</string> -        <key>copyright</key> -        <string>Copyright 2017-2019 Miles Johnson.</string> -        <key>description</key> -        <string>Emoji shortcodes</string> -        <key>license</key> -        <string>MIT</string> -        <key>license_file</key> -        <string>LICENSES/emojibase-license.txt</string> -        <key>name</key> -        <string>emoji_shortcodes</string>          <key>platforms</key>          <map>            <key>darwin64</key> @@ -498,8 +486,20 @@              <string>windows64</string>            </map>          </map> +        <key>license</key> +        <string>MIT</string> +        <key>license_file</key> +        <string>LICENSES/emojibase-license.txt</string> +        <key>copyright</key> +        <string>Copyright 2017-2019 Miles Johnson.</string>          <key>version</key>          <string>6.1.0.5413f58</string> +        <key>name</key> +        <string>emoji_shortcodes</string> +        <key>canonical_repo</key> +        <string>https://github.com/secondlife/3p-emoji-shortcodes</string> +        <key>description</key> +        <string>Emoji shortcodes</string>        </map>        <key>expat</key>        <map> @@ -659,16 +659,6 @@        </map>        <key>freetype</key>        <map> -        <key>copyright</key> -        <string>Copyright 2006, 2007, 2008, 2009, 2010 by David Turner, Robert Wilhelm, and Werner Lemberg.</string> -        <key>description</key> -        <string>Font rendering library</string> -        <key>license</key> -        <string>FreeType</string> -        <key>license_file</key> -        <string>LICENSES/freetype.txt</string> -        <key>name</key> -        <string>freetype</string>          <key>platforms</key>          <map>            <key>darwin64</key> @@ -728,8 +718,18 @@              <string>windows64</string>            </map>          </map> +        <key>license</key> +        <string>FreeType</string> +        <key>license_file</key> +        <string>LICENSES/freetype.txt</string> +        <key>copyright</key> +        <string>Copyright 2006, 2007, 2008, 2009, 2010 by David Turner, Robert Wilhelm, and Werner Lemberg.</string>          <key>version</key>          <string>2.12.1.557becd</string> +        <key>name</key> +        <string>freetype</string> +        <key>description</key> +        <string>Font rendering library</string>        </map>        <key>glext</key>        <map> @@ -1503,15 +1503,6 @@        </map>        <key>llca</key>        <map> -        <key>copyright</key> -        <string>Copyright (c) 2016, Linden Research, Inc.; data provided by the Mozilla NSS Project. -      </string> -        <key>license</key> -        <string>mit</string> -        <key>license_file</key> -        <string>LICENSES/ca-license.txt</string> -        <key>name</key> -        <string>llca</string>          <key>platforms</key>          <map>            <key>common</key> @@ -1529,8 +1520,17 @@              <string>common</string>            </map>          </map> +        <key>license</key> +        <string>mit</string> +        <key>license_file</key> +        <string>LICENSES/ca-license.txt</string> +        <key>copyright</key> +        <string>Copyright (c) 2016, Linden Research, Inc.; data provided by the Mozilla NSS Project. +      </string>          <key>version</key>          <string>202402012004.0</string> +        <key>name</key> +        <string>llca</string>        </map>        <key>llphysicsextensions_source</key>        <map> @@ -1900,18 +1900,6 @@        </map>        <key>nanosvg</key>        <map> -        <key>canonical_repo</key> -        <string>https://bitbucket.org/lindenlab/3p-nanosvg</string> -        <key>copyright</key> -        <string>Copyright (c) 2013-14 Mikko Mononen</string> -        <key>description</key> -        <string>NanoSVG is a simple single-header-file SVG parser and rasterizer</string> -        <key>license</key> -        <string>Zlib</string> -        <key>license_file</key> -        <string>LICENSES/nanosvg.txt</string> -        <key>name</key> -        <string>nanosvg</string>          <key>platforms</key>          <map>            <key>darwin64</key> @@ -1951,8 +1939,20 @@              <string>windows64</string>            </map>          </map> +        <key>license</key> +        <string>Zlib</string> +        <key>license_file</key> +        <string>LICENSES/nanosvg.txt</string> +        <key>copyright</key> +        <string>Copyright (c) 2013-14 Mikko Mononen</string>          <key>version</key>          <string>2022.09.27</string> +        <key>name</key> +        <string>nanosvg</string> +        <key>canonical_repo</key> +        <string>https://bitbucket.org/lindenlab/3p-nanosvg</string> +        <key>description</key> +        <string>NanoSVG is a simple single-header-file SVG parser and rasterizer</string>        </map>        <key>nghttp2</key>        <map> @@ -2412,7 +2412,7 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>          <key>copyright</key>          <string>2010 Vivox, including audio coding using Polycom¨ Siren14TM (ITU-T Rec. G.722.1 Annex C)</string>          <key>version</key> -        <string>4.10.0000.32327.5fc3fe7c.571099</string> +        <string>4.10.0000.32327.5fc3fe7c.5942f08</string>          <key>name</key>          <string>slvoice</string>          <key>description</key> @@ -2658,16 +2658,6 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>        </map>        <key>viewer-fonts</key>        <map> -        <key>copyright</key> -        <string>Copyright 2016-2022 Brad Erickson CC-BY-4.0/MIT, Copyright 2016-2022 Twitter, Inc. CC-BY-4.0, Copyright 2013 Joe Loughry and Terence Eden MIT</string> -        <key>description</key> -        <string>Viewer fonts</string> -        <key>license</key> -        <string>Various open source</string> -        <key>license_file</key> -        <string>LICENSES/fonts.txt</string> -        <key>name</key> -        <string>viewer-fonts</string>          <key>platforms</key>          <map>            <key>darwin64</key> @@ -2695,8 +2685,18 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>              <string>windows64</string>            </map>          </map> +        <key>license</key> +        <string>Various open source</string> +        <key>license_file</key> +        <string>LICENSES/fonts.txt</string> +        <key>copyright</key> +        <string>Copyright 2016-2022 Brad Erickson CC-BY-4.0/MIT, Copyright 2016-2022 Twitter, Inc. CC-BY-4.0, Copyright 2013 Joe Loughry and Terence Eden MIT</string>          <key>version</key>          <string>1.579464</string> +        <key>name</key> +        <string>viewer-fonts</string> +        <key>description</key> +        <string>Viewer fonts</string>        </map>        <key>viewer-manager</key>        <map> @@ -178,6 +178,7 @@ pre_build()      "$autobuild" configure --quiet -c $variant \       ${eval_autobuild_configure_parameters:---} \ +     -DLL_TESTS:BOOL=ON \       -DPACKAGE:BOOL=ON \       -DHAVOK:BOOL="$HAVOK" \       -DRELEASE_CRASH_REPORTING:BOOL="$RELEASE_CRASH_REPORTING" \ diff --git a/indra/llcommon/llcoros.cpp b/indra/llcommon/llcoros.cpp index 20340397db..aa8eca7d90 100644 --- a/indra/llcommon/llcoros.cpp +++ b/indra/llcommon/llcoros.cpp @@ -123,7 +123,7 @@ LLCoros::LLCoros():      // Previously we used      // boost::context::guarded_stack_allocator::default_stacksize();      // empirically this is insufficient. -    mStackSize(900*1024), +    mStackSize(1024*1024),      // mCurrent does NOT own the current CoroData instance -- it simply      // points to it. So initialize it with a no-op deleter.      mCurrent{ [](CoroData*){} } diff --git a/indra/llprimitive/llgltfmaterial.h b/indra/llprimitive/llgltfmaterial.h index dac9c44f8a..c3fdc8d720 100644 --- a/indra/llprimitive/llgltfmaterial.h +++ b/indra/llprimitive/llgltfmaterial.h @@ -122,13 +122,20 @@ public:      F32 mRoughnessFactor = 1.f;      F32 mAlphaCutoff = 0.5f; -    bool mDoubleSided = false;      AlphaMode mAlphaMode = ALPHA_MODE_OPAQUE; +    bool mDoubleSided = false; +      // override specific flags for state that can't use off-by-epsilon or UUID hack      bool mOverrideDoubleSided = false;      bool mOverrideAlphaMode = false; +    // These fields are local to viewer and are a part of local bitmap support +    typedef std::map<LLUUID, LLUUID> local_tex_map_t; +    local_tex_map_t                  mTrackingIdToLocalTexture; + +public: +      // get a UUID based on a hash of this LLGLTFMaterial      LLUUID getHash() const; @@ -229,10 +236,6 @@ public:      virtual bool replaceLocalTexture(const LLUUID& tracking_id, const LLUUID &old_id, const LLUUID& new_id);      virtual void updateTextureTracking(); -    // These fields are local to viewer and are a part of local bitmap support -    typedef std::map<LLUUID, LLUUID> local_tex_map_t; -    local_tex_map_t mTrackingIdToLocalTexture; -  protected:      static LLVector2 vec2FromJson(const std::map<std::string, tinygltf::Value>& object, const char* key, const LLVector2& default_value);      static F32 floatFromJson(const std::map<std::string, tinygltf::Value>& object, const char* key, const F32 default_value); diff --git a/indra/llprimitive/tests/llgltfmaterial_test.cpp b/indra/llprimitive/tests/llgltfmaterial_test.cpp index 143cf8e9c0..006ab7688d 100644 --- a/indra/llprimitive/tests/llgltfmaterial_test.cpp +++ b/indra/llprimitive/tests/llgltfmaterial_test.cpp @@ -143,7 +143,7 @@ namespace tut  #if LL_WINDOWS          // If any fields are added/changed, these tests should be updated (consider also updating ASSET_VERSION in LLGLTFMaterial)          // This test result will vary between compilers, so only test a single platform -        ensure_equals("fields supported for GLTF (sizeof check)", sizeof(LLGLTFMaterial), 216); +        ensure_equals("fields supported for GLTF (sizeof check)", sizeof(LLGLTFMaterial), 224);  #endif  #endif          ensure_equals("LLGLTFMaterial texture info count", (U32)LLGLTFMaterial::GLTF_TEXTURE_INFO_COUNT, 4); | 
