Coder Social home page Coder Social logo

Sourcemap absolute path issue about emscripten HOT 12 OPEN

dwz8 avatar dwz8 commented on May 30, 2024
Sourcemap absolute path issue

from emscripten.

Comments (12)

sbc100 avatar sbc100 commented on May 30, 2024

To be clear, this issue also occurs if emscripten and the project are on the same drive right?

You mentioned on the mailing list that the source map contained a path that looked like: myArea/myApp/C:/Users/myName/emsdk/upstream/emscripten.

It seems like that both is simply broken, regardless of which drive emsdk is on. Or is it the cast that these bad paths are not generated when emsdk is on the same drive as the project?

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

If emscripten and the project are on the same drive, the source will contain relative paths to the emscripten files:

{"version":3,"sources":["test.c","../Users/diete/emsdk/upstream/emscripten/system/lib/libc/emscripten_get_heap_size.c","...

So it looks as if the bad paths are only generated when emsdk and project reside on different drives.

from emscripten.

sbc100 avatar sbc100 commented on May 30, 2024

What does that emscripten_get_heap_size.c line looks like in the broken source map?

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

{"version":3,"sources":["test.c","C:/Users/diete/emsdk/upstream/emscripten/system/lib/libc/emscripten_get_heap_size.c","C:/Users/diete/emsdk...

from emscripten.

sbc100 avatar sbc100 commented on May 30, 2024

That looks correct to me. Do you know where the bad path (myArea/myApp/C:/Users/myName/emsdk/upstream/emscripten) path in your original report comes from?

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

C:/Users/myName/emsdk/upstream/emscripten is the correct installation path on my computer. The map file has of course been generated by emsdk.
The issue may be that localhost can not manage any references across local drives. So localhost (or any other server) can only find the emsdk files if they are in the same "myArea" tree as the source files I think.

from emscripten.

sbc100 avatar sbc100 commented on May 30, 2024

I'm not sure what you mean by "localhost" here. Are you referring to the http server you are using to serve your source files? If its asked to serve C:/Users/myName/emsdk/upstream/emscripten what can't it do that? Is there some fundamental reason? Is there any other solution you can imagine other than fixing the server here?

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

sorry for the confusion.
For testing purposes I have Internet Information Server running on my computer. If I launch the project in a browser the URL will be http://localhost/myArea/myApp, because the default directory is set to D:\myArea.
emsdk produces the sourcemap with relative paths for my source files, which is correct. The paths to emsdk files can't be relative (and could never be unless emsdk is installed on the same drive), so it uses the local file path, which can't work.

So either it is a prerequisite to keep emsdk and all projects on the same drive, or another way must be found so that the browser can find the emsdk files. For local testing as in my use case the local file path may suffice if the browser is able to use it.

from emscripten.

sbc100 avatar sbc100 commented on May 30, 2024

so it uses the local file path, which can't work.

Why do you say it cannot work? Its seems like a limitation of the server "Internet Information Server"? Perhaps it is configurable or perhaps you could try a different server that does support absolute paths somehow?

It seems like either you need to find or configure as server that allows absolute paths, or you need to put emsdk in a place where it can be found using a relative path. I'm not sure this is something that can be fixed on the emscripten side.

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

Thanks for the suggestion, I will have a look at that.
Chrome turns the absolute path in the map into
file:myArea/myApp/C:/Users/diete/emsdk/upstream/emscripten
So perhaps the issue is there. I will examine this further.
Thanks for your attention!

from emscripten.

sbc100 avatar sbc100 commented on May 30, 2024

Thanks for the suggestion, I will have a look at that. Chrome turns the absolute path in the map into file:myArea/myApp/C:/Users/diete/emsdk/upstream/emscripten

Oh I see.. that does seem wrong. So in that case no request is actually being sent to the server? That seems pretty strange.

from emscripten.

dwz8 avatar dwz8 commented on May 30, 2024

I just ran the project in Firefox. It seems to sort out the absolute path correctly, however, when accessing the source file I see an error:
unsupported protocol for sourcemap request c:/Users/diete/emsdk/upstream/emscripten/system/lib/dlmalloc.c

from emscripten.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.