130 pointsby andreabergia8 hours ago17 comments
  • tclancy4 hours ago
    This is an interesting approach. I think, in a way, it mirrors what I do. Having contracted for much of my career, I’ve had to get up to speed on a number of codebases quickly. When I have a choice of how to do this, I find a recently closed issue and try to write a unit test for it. If nothing else, you learn where the tests live, assuming they exist, and how much of a safety net you have if you start hacking away at things. Once I know how to add tests and run them (which is a really good way to deal with the codebase setup problem mentioned in the article because a lot of onboarding docs only get you to the codebase running without all the plumbing you need), I feel like I can get by without a full understanding of the code as I can throw in a couple of tests to prove what I want to get to and then hope the tests or CI or hooks prevent me from doing A Bad Thing. Not perfect and it varies depending on on how well the project is built and maintained, but if I can break things easily, people are probably used to things breaking and then I have an avenue to my first meaningful contribution. Making things break less.
  • its-kostya2 hours ago
    I am quite skeptical and reserved when it comes to AI, particularly as it relates to impacts of the next generation of engineers. But using AI to learn a code base has been life-changing. Using a crutch to feel your way around. Then ditching the crutch when things are familiar, like using a map until you learn the road yourself.
  • hyperific3 hours ago
    • esafak12 minutes ago
      Not very useful, is it?
  • Quiark4 hours ago
    Do you guys remember the smalltalk toolkit posted here a while ago which their creators made specifically for help understanding new codebases?
  • hks04 hours ago
    I always thought to do this visualization in 3d and maybe with VR. Not sure how useful or pleasing experience it would be. Kudos to the author of the project to get this done!
    • avaer4 hours ago
      I got Minority Report vibes.

      This kind of approach might be what (finally) unlocks visual programming?

      I feel like most good programmers are like good chess players. They don't need to see the board (code). But for inputting the code transformation into the system this might be a good programmer's chessboard.

      Though to make it work concretely for arbitrary codebases I feel like a coding agent behind the scenes is 100% required.

      • mathgeek4 hours ago
        > I feel like most good programmers are like good chess players.

        A specific type or area of developers, I'd say. There are many types and not all of them require understanding sizeable code bases to do their work well.

        • soulofmischief3 hours ago
          Understanding your large codebase is a few prompts away. You can ask a model to trace through and provide reports on the project's design, architectural and implementation. From there, you can drill in with followups.

          Done right, you may not know specific lines or chunks of code by heart, but much like a tuned-in company CEO, you have eyes and ears on the ground and retain global oversight and insight of the project itself. For specifics, you can learn what you need as you need it. If that means knowing how every single module works, that's just a conversation with your agent.

  • Charon775 hours ago
    In reverse engineering we often use Graph View to see execution flow as well. Glad to see it being used elsewhere
    • touristtam4 hours ago
      Do you automate that? If so what tooling do you use?
      • Pay084 hours ago
        IDA does it by default, for example.
  • FailMore6 hours ago
    The building of the visualiser was less interesting to me than the result and your conclusion. I agree that finding new ways to ingest the structure and logic of software would be very useful, and I like your solution. Is there a way to test it out?
  • esafak3 hours ago
    A use case that interests me is dynamic visualization for debugging, when there are interacting systems.
    • esafak8 minutes ago
      To flesh this out, let me see the volume of calls and data from one place to another. Help diagnose back-pressure, drops, rejections, and any other irregularities.

      Think of an on-caller who wants to quickly pinpoint a problem. Visualization could help one understand the nature of the problem before reading the code. Then you could select a part of the visualization and ask the computer to tell you what that part does, if there are any recent changes to it, etc.

  • luxurytent5 hours ago
    This may be where AI coding tools unlock us. Being able to build tooling against novel concepts that change how we approach reading and writing code. I like it!
  • 5 hours ago
    undefined
  • hxugufjfjf6 hours ago
    Cool project! Would you be willing to share the source code?
  • satheeshds4 hours ago
    - But I'll admit, this isn't precisely how I would do it today

    How would you do it today?

    • onionisafruit3 hours ago
      I thought that was curious. He says this isn’t how he would do it today then goes on to do it today (or presumably the same day he wrote that he wouldn’t do it this way today).
  • TonyStr5 hours ago
    You are so lucky to have git history and issues to work from!
  • artzev_an hour ago
    [dead]
  • indiekitai4 hours ago
    [dead]
  • nimbus-hn-test3 hours ago
    [dead]
  • nimbus-hn-test3 hours ago
    [dead]