Launch HN: CodeViz (YC S24) – Visual maps of your codebase in VS Code
Liam and Will from CodeViz are developing a VS Code extension that creates interactive diagrams, including call graphs and architecture diagrams, to help software engineers visualize and navigate complex code structures.
Liam and Will from CodeViz are developing a VS Code extension that creates interactive diagrams of codebases, ranging from system architecture to function call graphs. The extension is designed to help software engineers visualize complex code structures, addressing the challenge of navigating convoluted files. Their experience at Tesla highlighted the need for more intuitive representations of software, leading them to create a graph-based tool that generates diagrams directly within VS Code. The extension features two main views: a call graph that allows users to explore function references and an architecture diagram that provides a high-level overview of the codebase. CodeViz aims to assist developers in navigating difficult code, onboarding new team members, and understanding open-source projects. Currently, the basic features are free, with a paid tier for advanced tools. The team is actively seeking feedback to improve the extension, particularly in enhancing the call graph's usability.
- CodeViz is a VS Code extension for generating interactive codebase diagrams.
- It features a call graph and an architecture diagram to aid navigation and understanding.
- The extension is currently free with plans for a paid tier for advanced features.
- The developers are seeking user feedback to enhance the tool's functionality.
- CodeViz aims to simplify the process of working with complex code structures.
Related
We need visual programming. No, not like that
Visual programming environments struggle due to mismatched focus on syntax. Developers prefer visualizing state transitions and code aspects. Tools like Sourcetrail aid in understanding code complexity, suggesting more visualizations for improved software comprehension and optimization.
Where should visual programming go?
Visual programming enhances software development by integrating graphics with traditional code syntax. Advocates suggest using diagrams alongside code to improve understanding and maintain cleaner code, aiming for a harmonious coexistence of text and visuals. Luna explores a dual representation system where diagrams complement textual coding, similar to game engine scene management.
Where should visual programming go?
The article discusses the future of visual programming, advocating for its role in enhancing traditional coding through useful visual elements, while outlining four integration levels for diagrams and code.
Vitale: Live notebooks in VS Code for JavaScript/TypeScript, web development, a
Vitale is a new exploratory development tool for Visual Studio Code, enabling interactive notebooks for JavaScript and TypeScript projects, enhancing coding with live feedback, syntax checking, and real-time adjustments.
We need visual programming. No, not like that
Visual programming struggles to gain traction as it attempts to replace code syntax instead of focusing on developers' actual visualizations, such as state transitions and memory layouts, requiring better integration and usability.
- Many users express enthusiasm for the tool's potential to visualize complex code structures, with some stating they have been waiting for such a solution.
- Concerns about pricing are prevalent, with several commenters finding the subscription model too expensive compared to similar tools.
- Privacy and data security are significant issues, as users are wary of sending their codebases to external servers.
- Feedback on the tool's functionality includes requests for customization options and the ability to use local LLMs instead of relying on external APIs.
- Some users suggest improvements, such as incorporating more domain-specific terminology and enhancing the interactivity of visualizations.
I tried this with a bunch of small open-source repos and it works great! I imagine using LLM might be a hard no for some people/enterprises - any plans to use stand-alone licenses with small local models? It seems like for what LLM is doing here (if I understand it right, help label the modules in natural language and perhaps help organize them into this hierarchy/modules) you don't necessarily need a SoTA model, right?
Also, this could be coming from LLMs, but I see that the visualizations are more biased towards terminology used in web-dev? (for example, one of my robot related repo was organized into front-end, back-end, etc. with I guess is kinda right but not exactly lol). It would be nice to see an interactive visualization where I can iterate on the initial viz with information I know, e.g., I drag and drop a module or rename it and then you probably do another pass with this feedback and LLMs and update my overall visualization with more domain specific labels and partitions?
Edit: Exploring CodeViz on a few more repos, and it seems like you have a set of hardcoded labels for the highest hierarchy in the architecture diagram? (so far, I've only seen Users, Databases, Backend, Frontend, and Shared Components). I am guessing this is something passed on in the prompts? It'll be nice to allow user to define their own set of labels/partitions at one or more levels and then try to create an architecture visualization that fits into these labels/constraints (although I am guessing at some point you have to be wary of hallucinations?)
Tried it on the github.com/pulumi/pulumi codebase and I get 5 blocks and that's it. Seems nice but I'm not going to pay 20 bucks a month to view one layer deeper.
The examples in your youtube video look good. I'm curious how they're generated. "We were surprised to find that a small fraction of code can generate a very accurate representation of the system." is a surprising statement to me. It's not been my experience that the code can reveal an accurate representation of human-understandable architecture beyond the call graph. The backend system generated from OpenHands (in your video) also looks pretty different from their own architecture diagram in their README: https://github.com/All-Hands-AI/OpenHands/tree/main/openhand... . How do you reconcile what an LLM says an architecture looks like with what maintainers prescribe? Is there a way to give feedback to it? (similar to pthangeda's comment on customization)
I wish there was a way to point this at a repo to test its efficacy. Though I understand that that'd be prohibitively expensive to do for free on the landing page.
I'm also curious how you guys distinguish yourself from https://docs.codesee.io/docs/review-maps-for-visual-studio-c... . They tried this for a few years but shut down recently (https://www.linkedin.com/posts/shaneak_update-codesee-has-be...)
This is genius
- We are allowed to use our own API key to get your extension to talk directly with our LLM of choice. I understand you are using Claude right now, but we are on OpenAI & Copilot; since we already went through the hoops of "accepting that our codebase will be sent to an LLM", we are trying to control the level of exposure. OpenAI is already in, Claude isn't; and you definitely won't be so having our codebase go through your infra is a no go. Local LLM would be incredible, but it might be not technically achievable yet.
- The price is too steep. I get way more value out of Copilot than I get from CodeViz which is similarly priced. I understand you have LLM costs at the moment, but as the point above defends: it does not have to be that way. I would find it way more "fair" to have to insert my LLM API (even for the free version and/or trial, right now you are loosing money on that) and have a separate cost for the extension; possibly with a "lifelong for current version + 1 year of upgrade license". Let me pay the usage to the LLM monthly depending on my actual usage, and pay you to build a very nice prompt engineering system.
Happy to pay a one time fee and the ability to use my local LLM
It was fun to look at various sites front end architecture.
I started to do complexity analysis as well, because, why not. But I got busy with actual work.
I wonder if I can dig it back from somewhere.
On a different note: I’m wondering, do you have any function calling built in? Is there room for combining LLM output with LSP calls?
In those terms CodeViz will provide a form of simplified class diagrams and a function call mapping?
Will there be sequence diagrams in the future?
¹ https://www.uml.org/ ² It has fallen out of fashion, since many people found it too heavy, and a lot of people have hever heard of it.
After installing it, it doesn't even let you see the first thing without signing up for a trial period and even then doesn't mention a cost.
I understand you just launched it, but I look at the free trial and think "what else am I going to find out...", uninstalled for now but hope you find traction.
But the navigation? Not easy to understand how to use it. Any video for helping us out see what we can do and how we can do it ?
I have been forcing my bot to give me Mermaid diagrams, swim diagrams, markup tables of schemas, code, logic etc...
I like where you guys are going, but what I think would be really fun - would be a Node Based diagram logic, where the boxes that you show in the diagram are Code-geometry-Nodes - and could be connected with code blocks as such.
Watch @HarryBlends videos on Geometry Nodes in Blender for Inspiration:
https://www.youtube.com/@harryblends
https://www.youtube.com/watch?v=a-4oCHe-hDE
These are the best graphic/node based visuals for describing structured relationships in maths I've ever seen.
To give you some CyberPunk FutureVision of what your outpus could be like -- if it turned all the code nodes into atomic code legos and rather than drawing the diagram from the code - I can use the diagram to create the code.
--
WRT "...some code goes to anthropic..." while answering another, seems like you guys would do well to know these guys:
https://news.ycombinator.com/item?id=41381498
As well as these guys:
Related
We need visual programming. No, not like that
Visual programming environments struggle due to mismatched focus on syntax. Developers prefer visualizing state transitions and code aspects. Tools like Sourcetrail aid in understanding code complexity, suggesting more visualizations for improved software comprehension and optimization.
Where should visual programming go?
Visual programming enhances software development by integrating graphics with traditional code syntax. Advocates suggest using diagrams alongside code to improve understanding and maintain cleaner code, aiming for a harmonious coexistence of text and visuals. Luna explores a dual representation system where diagrams complement textual coding, similar to game engine scene management.
Where should visual programming go?
The article discusses the future of visual programming, advocating for its role in enhancing traditional coding through useful visual elements, while outlining four integration levels for diagrams and code.
Vitale: Live notebooks in VS Code for JavaScript/TypeScript, web development, a
Vitale is a new exploratory development tool for Visual Studio Code, enabling interactive notebooks for JavaScript and TypeScript projects, enhancing coding with live feedback, syntax checking, and real-time adjustments.
We need visual programming. No, not like that
Visual programming struggles to gain traction as it attempts to replace code syntax instead of focusing on developers' actual visualizations, such as state transitions and memory layouts, requiring better integration and usability.