This Set is a local variable in a method, so I don't think that it's possible for multiple threads to access it.
-- Josh Tynjala Bowler Hat LLC <https://bowlerhat.dev> On Mon, Apr 17, 2023 at 10:58 AM Alex Harui <aha...@adobe.com.invalid> wrote: > I was going to suggest using a Set like you just did in the commit, but in > looking at it, (and it has been a long time since I did Java work), I would > also see what it takes to lock out other threads during the Set test. > Otherwise, two threads can both do the set test, and then since both would > get "false", the two threads could still each add to the set. When the Set > is being checked and added, no other thread should be able to run that same > code. > > HTH, > -Alex > > > On 4/17/23, 8:07 AM, "Josh Tynjala" <joshtynj...@bowlerhat.dev <mailto: > joshtynj...@bowlerhat.dev>> wrote: > > > EXTERNAL: Use caution when clicking on links or opening attachments. > > > > > I'll be working on this one out later today. I have a couple of ideas to > try. > > > -- > Josh Tynjala > Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > > > > On Sun, Apr 16, 2023 at 5:59 AM Yishay Weiss <yishayj...@hotmail.com > <mailto:yishayj...@hotmail.com>> wrote: > > > > >I still need to figure out the duplicate hoisted variables in MXRoyale. > > > > I can confirm it's still happening. It does not happen on my machine with > > a simple "mvn clean install". > > ________________________________ > > From: Josh Tynjala <joshtynj...@bowlerhat.dev <mailto: > joshtynj...@bowlerhat.dev>> > > Sent: Friday, April 7, 2023 2:01 AM > > To: dev@royale.apache.org <mailto:dev@royale.apache.org> < > dev@royale.apache.org <mailto:dev@royale.apache.org>> > > Subject: Re: 0.9.10 Release > > > > My latest commits make the Jewel and JewelJS SWC files match between my > > macOS and Windows machines. I ended up having to switch to a different > > Maven Sass plugin because I realized the one we were using was no longer > > maintained, and it was misbehaving. This new plugin is based on the newer > > Sass that doesn't support CRLF output at all, so the changes I talked > about > > in my previous email ended up being a strict requirement. > > > > I still need to figure out the duplicate hoisted variables in MXRoyale. > > I'll need to dive into that on another day. > > > > -- > > Josh Tynjala > > Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > > > > > On Thu, Apr 6, 2023 at 9:57 AM Josh Tynjala <joshtynj...@bowlerhat.dev > <mailto:joshtynj...@bowlerhat.dev>> > > wrote: > > > > > Some more findings: > > > > > > The difference in Jewel appears to be caused by defaults.css. The Maven > > > build at some point was updated to force Sass to output CRLF on > Windows, > > to > > > keep Git from saying that the file is modified after regenerating it. > > > Unfortunately, this breaks the ability to do a cross-platform > > reproducible > > > build because every other platform uses LF. I'm probably going to undo > > this > > > change (sorry, Greg!). However, it looks like adding a .gitattributes > > file > > > to the repo allows us to force line endings for specific files or > > > extensions, regardless of autocrlf behavior. It should provide the same > > > benefit as Greg's commit, while restoring reproducible builds. Side > > note: I > > > also found that modern Sass doesn't even provide the option to use > CRLF, > > so > > > this change is probably for the best because we may need to upgrade > Sass > > in > > > the future. > > > > > > The situation with duplicates of hoisted variables in > > > MXRoyaleBase/MXRoyale in JDK 17 might be a threading conflict (and > > probably > > > could happen with JDK 11 too, if conditions are correct). When the > issue > > > reproduces, I see that the function scope actually contains duplicate > > > definitions of every local variable, instead of just one of each. > > > Interestingly, if I add enough logging to help myself debug this issue, > > the > > > scope ends up containing one of each local variable, and it doesn't > > > duplicate the hoisted variables anymore. That makes me think multiple > > > threads may be manipulating the scope. > > > > > > -- > > > Josh Tynjala > > > Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > > > > > > > > On Wed, Apr 5, 2023 at 2:42 PM Josh Tynjala <joshtynj...@bowlerhat.dev > <mailto:joshtynj...@bowlerhat.dev>> > > > wrote: > > > > > >> Some preliminary findings: > > >> > > >> Jewel: > > >> - Some plaintext [Embed] content was not matching up between macOS and > > >> Windows. It was clearly a text encoding issue. I fixed a compiler bug > > >> where it was using the system default encoding instead of UTF-8. A > > >> workaround would be to use JAVA_TOOL_OPTIONS=-Dfile.encoding=UTF8. > > >> - The SWF files inside the Jewel SWCs still do not match between my > > >> machines. I still need to figure out why. Probably a missing compiler > > >> option in the Jewel pom.xml file. > > >> > > >> MXRoyale and MXRoyaleBase: > > >> - On Windows, I was seeing hoisted variables appear in the JS output > > >> twice. I noticed that I was using JDK 11 on macOS, and JDK 17 on > > Windows. > > >> When I switched to JDK 11 on Windows, the problem went away. It looks > > like > > >> there's a bug in the compiler that needs to be fixed to support JDK > 17. > > >> Until then, I recommend building with JDK 11 or older (8 should be > fine > > >> too). > > >> > > >> -- > > >> Josh Tynjala > > >> Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > >> > > >> > > >> On Wed, Apr 5, 2023 at 10:11 AM Josh Tynjala < > joshtynj...@bowlerhat.dev <mailto:joshtynj...@bowlerhat.dev> > > > > > >> wrote: > > >> > > >>> Alright, I built the distribution locally with Maven on two different > > >>> machines, and I can see that the following SWCs don't match: Jewel, > > >>> MXRoyale, and MXRoyaleBase > > >>> > > >>> It affects both the JS and SWF versions of the SWCs. > > >>> > > >>> I'll see what I can do. > > >>> > > >>> -- > > >>> Josh Tynjala > > >>> Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > >>> > > >>> > > >>> On Mon, Apr 3, 2023 at 8:04 AM Josh Tynjala < > joshtynj...@bowlerhat.dev <mailto:joshtynj...@bowlerhat.dev> > > > > > >>> wrote: > > >>> > > >>>> Yes, it's on by default. > > >>>> > > >>>> I guess that there must be some other reason why the builds don't > > match > > >>>> up. I just happened to notice this, in particular, was different > > between > > >>>> the Ant build and the Maven build. > > >>>> > > >>>> You may need to extract the .swc files and manually compare the > > >>>> contents to see what is different. > > >>>> > > >>>> -- > > >>>> Josh Tynjala > > >>>> Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > >>>> > > >>>> > > >>>> On Sun, Apr 2, 2023 at 4:01 AM Yishay Weiss <yishayj...@hotmail.com > <mailto:yishayj...@hotmail.com>> > > >>>> wrote: > > >>>> > > >>>>> Is that option on by default? I just tried building both on release > > >>>>> machine and locally and am still getting the mismatch. > > >>>>> > > >>>>> <exec executable="${mvn}" dir="${artifactfolder}/sources" > > >>>>> failonerror="true" > > > >>>>> <arg value="-X" /> > > >>>>> <arg value="-P" /> > > >>>>> <arg > > >>>>> > > > value="royale-release,apache-release,_reproducible-build,with-distribution,with-examples,with-manualtests,option-with-swf" > > >>>>> /> > > >>>>> <arg value="clean" /> > > >>>>> <arg value="install" /> > > >>>>> </exec> > > >>>>> > > >>>>> Is how it gets built now locally. Intuitively debug info should not > > be > > >>>>> part of the release but I need to look into it further. > > >>>>> ________________________________ > > >>>>> From: Josh Tynjala <joshtynj...@bowlerhat.dev <mailto: > joshtynj...@bowlerhat.dev>> > > >>>>> Sent: Tuesday, March 28, 2023 6:17 PM > > >>>>> To: dev@royale.apache.org <mailto:dev@royale.apache.org> < > dev@royale.apache.org <mailto:dev@royale.apache.org>> > > >>>>> Subject: Re: 0.9.10 Release > > >>>>> > > >>>>> Hey Yishay, > > >>>>> > > >>>>> I recently made a commit that adds the swf-debugfile-alias compiler > > >>>>> option > > >>>>> for SWC files built by Maven. This compiler option was being used > by > > >>>>> Ant > > >>>>> already, but it never got added to the Maven build. And I think > that > > >>>>> binaries would fail comparison without it. This may be why Release > > >>>>> Step 11 > > >>>>> was failing for you. > > >>>>> > > >>>>> Basically, swf-debugfile-alias ensures that the debugging > information > > >>>>> in > > >>>>> the SWC doesn't include the local path to the .as/.mxml source > files > > >>>>> (starting with something like C:\Users\joshtynjala\ or > > >>>>> /Users/CoolGuy19/). > > >>>>> Instead, it sets a generic path that will always match among builds > > >>>>> from > > >>>>> different machines. Considering this was missing, it sure sounds > > like a > > >>>>> reason why binary comparison would fail. > > >>>>> > > >>>>> -- > > >>>>> Josh Tynjala > > >>>>> Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/;> > > >>>>> > > >>>>> > > >>>>> On Wed, Feb 22, 2023 at 10:38 AM Yishay Weiss < > > yishayj...@hotmail.com <mailto:yishayj...@hotmail.com>> > > >>>>> wrote: > > >>>>> > > >>>>> > FYI I am put this on hold about 2 weeks ago after failing to > debug > > a > > >>>>> > binary reproducibility issue in as-js repo. > > >>>>> > > > >>>>> > @Harbs<mailto:harbs.li...@gmail.com <mailto: > harbs.li...@gmail.com>>, can you see if the same > > issue > > >>>>> > exists for you? > > >>>>> > > > >>>>> > You can follow instructions [1] and tell me if step 2 succeeded > or > > >>>>> failed > > >>>>> > for you. > > >>>>> > > > >>>>> > Thanks. > > >>>>> > > > >>>>> > [1] > > >>>>> > > > >>>>> > > > apacheroyale.francecentral.cloudapp.azure.com:8080/job/Royale_Release_Step_011/ws/Success-5.txt > > >>>>> > < > > >>>>> > > > >>>>> > > > http://apacheroyale.francecentral.cloudapp.azure.com:8080/job/Royale_Release_Step_011/ws/Success-5.txt > < > http://apacheroyale.francecentral.cloudapp.azure.com:8080/job/Royale_Release_Step_011/ws/Success-5.txt > > > > >>>>> > > > > >>>>> > ________________________________ > > >>>>> > From: Josh Tynjala <joshtynj...@bowlerhat.dev <mailto: > joshtynj...@bowlerhat.dev>> > > >>>>> > Sent: Tuesday, January 17, 2023 10:08 PM > > >>>>> > To: dev@royale.apache.org <mailto:dev@royale.apache.org> < > dev@royale.apache.org <mailto:dev@royale.apache.org>> > > >>>>> > Subject: Re: 0.9.10 Release > > >>>>> > > > >>>>> > Oops! I meant NO further changes. Sorry about that. You're good > to > > >>>>> go on my > > >>>>> > end. > > >>>>> > > > >>>>> > -- > > >>>>> > Josh Tynjala > > >>>>> > Bowler Hat LLC <https://bowlerhat.dev/> <https://bowlerhat.dev/ > ;> > > >>>>> > > > >>>>> > > > >>>>> > On Tue, Jan 17, 2023 at 11:32 AM Yishay Weiss < > > >>>>> yishayj...@hotmail.com <mailto:yishayj...@hotmail.com>> > > >>>>> > wrote: > > >>>>> > > > >>>>> > > Thanks for the update, let me know when to pull the trigger. > > >>>>> > > > > >>>>> > > Get Outlook for Android<https://aka.ms/AAb9ysg> < > https://aka.ms/AAb9ysg;> > > >>>>> > > ________________________________ > > >>>>> > > From: Josh Tynjala <joshtynj...@bowlerhat.dev <mailto: > joshtynj...@bowlerhat.dev>> > > >>>>> > > Sent: Tuesday, January 17, 2023 7:05:29 PM > > >>>>> > > To: dev@royale.apache.org <mailto:dev@royale.apache.org> < > dev@royale.apache.org <mailto:dev@royale.apache.org>> > > >>>>> > > Subject: Re: 0.9.10 Release > > >>>>> > > > > >>>>> > > I've updated the release notes with my changes. I have further > > >>>>> changes > > >>>>> > > planned before the release. > > >>>>> > > > > >>>>> > > -- > > >>>>> > > Josh Tynjala > > >>>>> > > Bowler Hat LLC <https://bowlerhat.dev/> < > https://bowlerhat.dev/;> > > >>>>> > > > > >>>>> > > > > >>>>> > > On Mon, Jan 16, 2023 at 12:40 AM Yishay Weiss < > > >>>>> yishayj...@hotmail.com <mailto:yishayj...@hotmail.com>> > > >>>>> > > wrote: > > >>>>> > > > > >>>>> > > > Hi Guys, > > >>>>> > > > > > >>>>> > > > We’re starting a new release soon. As it’s been a while and I > > >>>>> expect > > >>>>> > some > > >>>>> > > > issues I have agreed with Harbs to do this release. 0.9.11 > > >>>>> should be > > >>>>> > > easier > > >>>>> > > > if we don’t wait too long, so the goal is for a different > > >>>>> volunteer to > > >>>>> > do > > >>>>> > > > the next one. > > >>>>> > > > > > >>>>> > > > If anybody wants to commit changes they are welcome to do so > > >>>>> now, and > > >>>>> > > > update the release notes. > > >>>>> > > > > > >>>>> > > > Please make sure the integration tests are working post > > commits. > > >>>>> > > > > > >>>>> > > > Thanks, > > >>>>> > > > Yishay > > >>>>> > > > > > >>>>> > > > > >>>>> > > > >>>>> > > >>>> > > > > > >