RFR: 8213622 - Windows VS2013 build failure - "'snprintf': identifier not found"

JC Beyler jcbeyler at google.com
Mon Nov 12 06:38:32 UTC 2018


Hi all,

If I've caught up with the conversation, it sounds like:
  - My code breaks VS2013 build but that soon that won't be supported
  - We can't just do a renaming macro due to my use of sprintf with an
empty buffer
      - So we need to either do what was suggested by Kim:
"That first snprintf call could be rewritten using several calls to
strlen to calculate the needed size in some different manner. The
later call could also be rewritten to use several calls to strcpy
rather than snprintf."
         Or something to that effect

I can work on a fix that will handle this if we want, I'm just not sure if
that's the path that is being recommended here though. It seems that in
this particular case, it is not really hard to fix the code for now; the
day VS2013 is no longer build-able by other pieces of code we can come back
to this solution. To be honest, the reason this is like this is due to not
being able to have C++ strings when I tried initially. The day we can have
those, then this code can become even simpler.

Let me know what you think and would prefer,
Jc

On Sun, Nov 11, 2018 at 9:01 PM David Holmes <david.holmes at oracle.com>
wrote:

> Hi Michal,
>
> On 12/11/2018 2:18 PM, Michal Vala wrote:
> >
> >
> > On 11/10/18 12:07 AM, David Holmes wrote:
> >> cc'ing JC Beyler as this was his code.
> >>
> >> On 10/11/2018 4:35 AM, Kim Barrett wrote:
> >>>> On Nov 9, 2018, at 11:43 AM, Michal Vala <mvala at redhat.com> wrote:
> >>>>
> >>>> Hi,
> >>>>
> >>>> please review following patch fixing build failure on Windows with
> >>>> VS2013 toolchain.
> >>
> >> Not sure we're still supporting VS2013 ... ??
> >
> > Minimum accepted by configure is 2010. 2013 is 2nd in priorities after
> > 2017. It has `VS_SUPPORTED_2013=false` though, but why not keep it
> > buildable?
>
> That depends on how painful it is to achieve that. As Kim has explained
> the suggested fix may allow building but it isn't correct.
>
> And we may not be able to keep this ability to build with VS2013 going
> forward.
>
> Thanks,
> David
>
>
> >>
> >>>>
> >>>> http://cr.openjdk.java.net/~mvala/jdk/jdk/JDK-8213622/webrev.00/
> >>>
> >>> The failure is in a hotspot test.  It should be using os::snprintf.
> >>
> >> Tests don't have access to os::snprintf. The test is just C++ code.
> >>
> >> Cheers,
> >> David
> >>
> >>
> >
>


-- 

Thanks,
Jc



More information about the build-dev mailing list