173 comments

  • tracyhenry 5 days ago ago

    This has been a great idea for decades. I want Haystack to be successful just like many other attempts. The early execution seems promising. And I suspect there will be many challenges (e.g. when it's hard to figure out caller/callee,, inconsistent UX preferences across developers, etc). Kudos for taking this on!

    Btw I've always thought that this is even more powerful when the screen estate is more infinite than a 2D screen (like in a VR headset).

    • akshaysg 5 days ago ago

      I love the idea of a Haystack VR world! It's a shame that VR software is in a tenuous state due to the biological factors, but I believe it's the future "one day".

      • dangerlibrary 5 days ago ago

        "In a tenuous state due to the biological factors" is easily the funniest SV euphemism for "can't be used by humans."

        • IgorPartola 5 days ago ago

          It’s ok after they deliver the MVP there will be a wetware update.

        • akshaysg 5 days ago ago

          Who knows, one day it may be possible (hopefully without any dystopian updates to human biology)!

          • groby_b 4 days ago ago

            At this point, that seems dubious - your inner ear is going to go all inner ear on you, no matter what. Unless you get to turn that off, VR is not it.

            • cdchn 4 days ago ago

              I hope our code-editor-in-VR wouldn't involve flying around like hilarious depictions of "The Gibson" in bad sci-fi movies.

              • groby_b 4 days ago ago

                Doesn't matter. As long as you use VR to display a virtual 3D environment and you move within it, your inner ear will fight with your vision system if you're moving or not. If the visual system and the accelerometer don't agree, the positioning system throws an exception.

                And, for whatever reason, the human exception handler for that problem is firmly linked to the barf() subroutine ;)

                • cdchn 3 days ago ago

                  Like I said, as long as you're not flying around- moving within it, then your inner ear doesn't care. Turning your head doesn't count. I don't see a need in a code-in-VR system to move like that. And most VR games solve this my having your teleport instead of translate.

                  I think the barf routine is because when your brain senses your vestibular system not working it thinks "oops I must be poisoned" and tries to make you throw up.

        • cdchn 4 days ago ago

          "Fixing our eyeballs is just an engineering problem."

      • doctorhandshake 5 days ago ago

        Check out SoftSpace https://soft.space … not an IDE but similar idea for knowledge mapping

        • akshaysg 5 days ago ago

          This is actually really cool!

  • faramarz 5 days ago ago

    Very cool. I imagined my organizations entire codebase being mapped like this and across different frameworks and languages.

    I don’t know if I missed this in the video or if it’s not yet possible, but that’s a lot of manual work, so instead of connecting the nodes, give a simple bot to run in the repo folder to automate the visualization.

    It’s super cool and I’m adding to my watch list.

    If I were you, i’d target enterprise organizations or local municipalities IT groups who are going through or planning their digital transformations. They have a need for way-finding and sense making across legacy and new work.

    If you play your cards right, Salesforce will come knocking in under a year. I see a lot of compatibility with their vision and product offerings.

    • matsemann 5 days ago ago

      I like the concept so far in the video. I just want more, even bigger, more panes, all connected! If it's usable in such a state I don't know, but would be fun to try. Like a UML diagrams of the whole code base with thousands of arrows.

      Ane I can then tell my coworker that the file needing change is in the upper right corners somewhere.

      And git diffs being visual, can just zoom in on the changes here and there.

    • akshaysg 5 days ago ago

      It automatically adds connections as you traverse through files/symbols. Not super sure if this is what you mean, but we intend to serve the users "flows" based on queries in the natural language e.g. "what happens when you click the subscribe button from the mouse down all the way to the backend".

      • faramarz 5 days ago ago

        That’s awesome! Generally when I find tools that can improve our work culture and output velocity and quality, I try and get it on front of teams ahead of a an internal hackathon where the cost of on-boarding and prototyping is already factored in. This feels like a good candidate.

    • hansonkd 5 days ago ago

      that would be interesting if you could "link" across API calls to different services.

      • akshaysg 5 days ago ago

        Most likely we would either have to get the user to do this (we plan to add this as a feature) or use AI to understand when disconnected code (from the LSP standpoint) is indeed connected.

        This is a top user request though!

  • hyggetrold 5 days ago ago

    Does this project take any inspiration from Light Table?

    Potential feature request - take the visualization beyond 2D. Really complex systems are usually an intricate graph (polite way of saying ball of yarn) and just visualizing in the 2D plane doesn't seem to cut it in my experience.

    I would love to have something like concentric spheres of visualization - boundary services on the outer layer, core/domain services in the inner layer.

    • akshaysg 5 days ago ago

      A lot of people mentioned Light Table, but I didn't know about it until post-launch!

      It's interesting that you mention a more 3D view. We were ideating on this, but it's really hard to get right in a way that the user can understand. This is definitely part of our vision for the future though!

      EDIT: Deleted the bit about my speculation regarding Light Table since it's false.

      • eep_social 5 days ago ago

        For 3D I’d run a clustering algo across the graph and use the Z axis to background “far” clusters.

        I’m imagining a typical graph might end up looking a bit like this: https://upload.wikimedia.org/wikipedia/commons/thumb/8/81/07... in which case I’d want to have whatever cluster/file/method/object I’m focused on front and center with some visual cues like low-contrast and z-axis perspective that preserves edges to show the “far” clusters that interact with the focal point.

        edit to add: as per usual, naming the clusters automatically might be hard.

        • hyggetrold 5 days ago ago

          Interesting idea and curious - because when I look at that visualization, the first thing it reminds me of is gource.

          • eep_social 5 days ago ago

            I had not heard of Gource, and it looks like it’s building its graph based on directory layout rather than code semantics but yep that’s about where I would start!

      • hyggetrold 5 days ago ago

        Light Table was getting lift and traction but didn't make it. There was a ton of conversation on it back in the day on HN, including great presentations by the creator (who had been a PM on Visual Studio as MSFT!). Definitely check it out.

        There's definitely demand for this tool but it looks like it's hard to get it off the ground. Wishing you the best of luck!

        • throwaway4aday 4 days ago ago

          someone should revive it as a GUI debugger. doing so would narrow the scope which should cut down on complexity. let people use their own editors and IDEs for making code changes. the focus should be on inspecting state, seeing live updates, allowing you to smoothly change inputs and immediately see the output, plus the usual debugger features like stepping through the program.

    • nine_k 4 days ago ago

      Not just Light Table from 2010s, but also I would expect that the authors know about Oberon from late 1980s. It also features code on a boundless canvas.

  • closetkantian 5 days ago ago

    So this is a major side question, but is there a go-to open source infinite canvas? I'm building a card game and I need a multiplayer infinite canvas for it. I'd appreciate any recommendations.

    • akshaysg 5 days ago ago

      Does tldraw work for you? We use Pixi JS, which comes with graphics as well.

      • closetkantian 4 days ago ago

        I think the biggest pain point for me is that nothing I've found supports cards that can be "flipped" so that they are face up or face down. I'm not an advanced coder but maybe I'll try to whip something up.

        • closetkantian 4 days ago ago

          tldraw does look amazing though, thanks.

      • zharknado 5 days ago ago

        Ooh I see PixiJs can make content available to the screenreader for a11y. That’s always a big question mark for me when people start cramming a content tree into a canvas.

        • akshaysg 4 days ago ago

          Yes a11y is very important! I do think this creates an HTML element per sprite/graphic, but the slowdown should not be terrible.

      • kevsim 4 days ago ago

        Last I checked Miro also uses Pixi so that's another quality infinite canvas app.

    • Onavo 5 days ago ago
    • surrTurr 4 days ago ago
  • nicktikhonov 5 days ago ago

    I would try it if it was a VSCode extension. I'd like to use it, but I live inside cursor these days.

    • tmikaeld 4 days ago ago

      This seems to be a growing issue..

      • pranav7 4 days ago ago

        cursor + this would be massive!

  • belowm 5 days ago ago

    Why can't this be an extension? I love the idea and can perfectly imagine this inside a tab of the editor area. This would allow for multiple haystack tabs as well, so switching contexts would be seven easier. Having to install another IDE (even if it is based on vscode) is a bit of a bummer for me. None the less, keep it up!

    • btown 5 days ago ago

      VS Code extensions are pretty limited - you can override the renderer for an editor tab, but if you want multiple things within a custom interface to be treated as first-class editor tabs by the larger environment (and by the larger extension ecosystem), that's not really possible. Forks are a reasonable step as long as they don't fall behind!

      • slightwinder 4 days ago ago

        Do you really need a first-class-editor for working directly from the canvas? Wouldn't it be enough to use the canvas just for navigation and show a rendered picture of the code, but open a separate editor (maybe side by side?) for the real work?

        • btown 4 days ago ago

          My understanding is that Haystack's mission is to explore this design space more fully than others have before, so I think they're making the right decision to be audacious here!

    • akshaysg 5 days ago ago

      I understand the frustration here! As the other commenter noted, it's quite bit tougher to make Haystack as good in the form of an extension, but we do plan to eventually explore this path!

    • gruelsummer 4 days ago ago

      Since extensions are limited, a nice workaround imo would be to be able to turn canvas view on/off. I'm going to want to go between the canvas and the standard VSCode view, and so if I can do that within Haystack I don't need to have both installed.

  • jecel 5 days ago ago

    This reminds me of the "Kansas" environment in the Self programming language. Here is a video about it from Sun in 1995:

    https://www.youtube.com/watch?v=Ox5P7QyL774

    More interesting search features were added after this video was made.

  • theideaofcoffee 5 days ago ago

    Oh, this is great. And pretty much the process of what I do when I look at larger codebases, except not as clean and organized. I would normally have a half dozen terminals open into various source files at once trying to build the map in my head. Though it eventually clicks and happens, it's laborious, but it seems like something like this would help immensely. Now, the only thing left is to combine it with an ultrawide monitor.

  • ocean_moist 5 days ago ago

    This feels helpful as I have to hold less stuff in my mind, but the UI is way too mouse dependent right now. You guys should make some shortcuts and somehow make it “tiling” like a window manager (dwm), so you don’t have to manually resize windows.

    • akshaysg 5 days ago ago

      We actually do try to make the canvas as keyboard navigable as possible. There are a list of keyboard bindings in the "Keybindings and Help" button on the bottom right.

      In terms of manually resizing, we actually do try to tile in the viewport. May I know what's causing you to resize it so I can fix it?

      • graerg 5 days ago ago

        In this vein, do you know what the experience has been like for users that use the vim vscode plugin? I see that it's trivial to carry over extensions and whatnot, but is the experience still "good" trying to use both?

        • akshaysg 5 days ago ago

          I use the Vim VS Code plugin! It mostly works, but I'm not going to lie: there are a couple of bugs e.g. when you go to definition the Vim selection gets confused because in most cases you get placed into a symbol editor.

          I am happy to fix any bugs here. I am the only person I know who uses the Vim plugin in Haystack, so I haven't prioritized fixing the bugs I encounter.

      • ocean_moist 5 days ago ago

        Sorry, I was just going off the demo. Maybe demo the keybinds briefly.

        If you get a demo of someone editing stuff super quickly using only keybinds I think it would look pretty cool.

        Right now I don’t know if the value prop is strong enough for me to switch editors and remodel/relearn all my keybinds. This is like a 10-15% improvement not a 1.5x or 2x improvement.

        An extension would probably help onboard users.

  • simonmysun 4 days ago ago

    In my mind this a convenient approach for developers to map the code into a two dimensional space in a spread-out way. It is similar to method of loci[1] that the develpoper spacially elaborately encode the code snippets and their connections to strengthen the memory thus strengthen the comprehension. I boldly suggest considering ading an option for a background pattern which is not distracting but a little bit informative. I don't have a specific one in mind but consider if the background is a world map, users will remember the location they want to find faster and also locate themselves faster.

    Following this line of thought, I think allowing user to define tab border color or even to add different noise for each tab worth considering (noise fades with zoom level and distance to the view port center).

    https://en.wikipedia.org/wiki/Method_of_loci

    • akshaysg 4 days ago ago

      We plan to add a minimap to help users orient themselves.

      Also the idea of using subtle color differences or sounds is interesting to me. Will think about this!

  • WuxiFingerHold 4 days ago ago

    I have nothing intelligent to say, just that I somehow love this idea very much. Somehow visualizing complexity of any kind, helping understanding and refactoring it, is what I constantly have in the back of my mind. Probably a dream of my subconsciousness that is looking for a solution for the complexity (mainly) at my work life.

    • akshaysg 4 days ago ago

      Ironically this is what prompted me to leave my job and start Haystack! Whenever I looked at code in my IDE my brain was always shouting at me to re-imagine it in a way that made more sense and would involve less mechanical refactoring.

      Whenever you have this feeling of looking for a solution in your daily life, you may just have a startup idea on your hands!

  • azhenley 5 days ago ago

    Beware, canvas-based code editors (like Code Bubbles) have problems. A 1d carousel/ribbon performed better in some initial user studies:

    https://austinhenley.com/pubs/Henley2014CHI_Patchworks.pdf

    • akshaysg 5 days ago ago

      Thank you for the flag! Our intention is to try to "tile" the viewport so that it resembles this grid format (i.e. the carousel/ribbon), but we've found the canvas is still useful folks who want to go that extra mile to organize their editors.

    • etwigg 4 days ago ago

      I was always surprised that Code Bubbles got so little airtime...

  • threecheese 5 days ago ago

    This is great and I can’t wait to try it. I’ve been coding for a few decades, and have always been good at “keeping the program in my head”. However, in life I am very bad at this and have failed at just about everything that’s not programming, and based on a recent diagnosis I’ve learned a lot about ADHD, autism, and “visual learners” for whom abstract mental models are difficult to internalize without some visual anchor. Anyway, this has led me to use more visual tools - like Miro and Heptabase - and the lessened cognitive load is nothing less than stunning. I hope this model of human/machine interface is beneficial to everyone, and not just those who are broken, but coming from one of the latter I appreciate what you are doing here.

    • jahewson 5 days ago ago

      Diagrams can certainly be helpful but do be aware that “visual learners” is a myth that has been debunked for 15 years now:

      https://www.theatlantic.com/science/archive/2018/04/the-myth...

      • threecheese 5 days ago ago

        Interesting, thanks for the reference. The chance that my doctor’s info is out of date is definitely nonzero. I am however interested in why this nugget of info has been so life-changing, and so off I go to figure out if this is placebo or something else. Appreciate you not being a dick, but then again this isn’t reddit.

  • welder 4 days ago ago

    This is very cool and building for a future of 100% AI generated coding, but for some reason I don't feel the urge to use it right now. I think it's because using the mouse turns me off. I use Vim or Vscode with Vim keybindings so any workflow depending on a mouse won't work for me.

    • akshaysg 4 days ago ago

      You don't have to use a mouse! We try to make it as keyboard accessible as possible and do have a lot of keybindings (see the button on the bottom right for keybindings).

  • atomicnature 4 days ago ago

    Reminds me a bit of the old smalltalk GUI. It had this sort of "object editing" capability IIRC. Actually, smalltalk could connect different data types, such as code, images, videos, presentations, docs, etc into a cohesive whole. Not as polished as your demo of course , but that was the core idea.

  • Blaec 4 days ago ago

    Folks following this discussion might be interested in knowing about CoCalc's Whiteboard implementation. https://cocalc.com/features/whiteboard

    You can access cocalc.com via your web browser to use the Whiteboard. It's an infinite canvas where you can write using a pen and tablet (like an iPad), make sticky notes using LaTeX/Markdown (or Rich Text), and run Jupyter cells.

    The platform supports many kernels without the hassle of installation, including Python, R, Julia, Octave, SageMath, and more. You can also use custom kernel environments...

  • g19fanatic 5 days ago ago

    I've needed something this from the first days of learning to program. I've been able to recreate this (kinda) with vim panes and tabs in addition to tmux panes and sessions.

    I'll keep my code in a left pane in vim, <C-w v> to duplicate the buffer in a new pane and then use tags to goto a definition and if needed to go deeper, do it again. I don't usually kill this unless no longer needed and If i need to go down some other branch, will just <C-w v> then <C-w T> to start that pane in a new tab and do it again. Easily keeping the different contexts in different panes and tabs inside of vim. all managed by <C-w |> and <C-w => to make it easier to read... Tmux panes and sessions for entire project contexts so on and so forth.

    Having it graphical looks really really nice and I'd love to have something like this for presentations/debugging over zoom sessions.

  • xixixao 5 days ago ago

    Congrats on the launch. It is an “obvious” idea, in a good way. Agree that minimizing the effort in constructing the workspace will be key. I’d also love to try a sort-of 3D stack for caller/callee relationship, zooming in and out. The code really is a graph (not acyclic though), and I think visualizing it that way can be helpful.

    • akshaysg 5 days ago ago

      I'd love to learn more about what you're envisioning for the caller/callee relationship here! Do you mean recursively show callers/callees as you zoom out?

  • cdchn 4 days ago ago

    It looks like a cool feature to an existing IDE but trying to sell it and forking VSCode as your own editor to try to sell seems like an uphill battle. Best of luck to you though.

  • jacobsenscott 5 days ago ago

    Interesting - though it probably just soft of devolves to using hot keys (hopefully those exist) to jump between files after a few editors are open. Panning around with even half a dozen files open would get tedious.

    • akshaysg 5 days ago ago

      What I do personally is I try to keep all relevant code in my viewport and jump around using shortcuts (are hotkeys a gaming term? I used to say hotkeys all the time!). The visualization is still really helpful for me so that I can quickly orient myself with which functions/classes relate to each other.

    • cellularmitosis 4 days ago ago

      When working with infinite canvases, using a combination of zoom and pan makes jumping from one spot to another spot basically instant.

  • pcarbonn 4 days ago ago

    Thanks! I'll certainly give it a try. Not sure what the business model should be, though.

    You may want to take some inspiration from prezi.com. One could write prezi-like HS workspaces to document some particular workflows. You would want the possibility to add text to the canvas (outside of the code editors), and allow zooming in/out from editors. This could be a premium feature that large companies want to pay for.

    • pcarbonn 4 days ago ago

      In fact, one approach could be to sell a premium version with collaborative tools (such as sharing workspaces with colleagues).

      • akshaysg 4 days ago ago

        Yup this is our plan! Collaborative features + Gen AI features as part of premium version.

  • arvindrajnaidu 4 days ago ago

    Reminds me of a hackathon submission I did for a Neo4j Hackathon. I remember winning some money :)

    https://www.youtube.com/watch?v=RTsnSxyO6MY

    It will be great if you are able to run tests on the codebase and watch the entire graph light-up in different colors. This is much cooler way to depict test coverage and also identify the most heavily used part of the codebase.

  • Scribbd 4 days ago ago

    I often use `code` command in the cli for a bunch of tasks. Mostly to just open an instance of vscode in a dir I am at. Is there a plan for such a command like that for haystack-ide?

    Meanwhile, an alias is easily created for macOS: `alias needle="/Applications/Haystack\ Editor.app/Contents/MacOS/Electron"`

    • akshaysg 4 days ago ago

      Yeah I think we added this for Windows but neglected to do so for Mac. Will add a `haystack-editor` command!

      • Scribbd 4 days ago ago

        Thank you very kindly.

  • thesurlydev 4 days ago ago

    I like the idea but what would be next level would be to visualize a project and all its dependencies such as microservices, database, queue, etc.

    Has there been any studies that prove that this infinite canvas mode is more productive than using a traditional IDE with heavy use of keyboard shortcuts, etc.

  • williamstein 5 days ago ago

    Is most development of Haystack done using Haystack?

    • yatvij 5 days ago ago

      Yes! Both of us prefer Haystack to other IDEs; for me it feels a lot less "restricting" than VSCode. Developing in Haystack also helps us find issues early.

  • valianter 5 days ago ago

    I get that this is a completely new idea so adoption is going to be slow but I'm curious to see how your user interviews and user research is going. I'm a young dev but I'm not even sure if I would use this because the way I've learned to code is already so ingrained into the traditional IDE. Nevertheless, congrats on the launch!

    • yatvij 5 days ago ago

      Jake from Haystack here! Thanks for the interest. We've been doing a lot of user interviews with folks on our discord (and folks we know in real life) to understand issues in the onboarding process, find problems that make people churn off, etc with the long-term goal of increasing retention. A lot of our time lately has been spent on fixing these bugs and improving the new-user experience. As a result of this we found that retention on later launches got much better!

      • verdverm 5 days ago ago

        Have you done user research outside your fan base to show this experience is something developers want?

        Is it desirable enough to get them to switch IDEs?

    • akshaysg 5 days ago ago

      Yeah just to add onto what Jake said -- in our user interviews we found that folks, even those who are pretty used to old IDEs, do get the hang of Haystack pretty fast. However, developers are very idiosyncratic, so we frequently get pain points that are real problems but are also highly unique to each developer, which is interesting!

      • necovek 5 days ago ago

        Totally: I couldn't stop thinking about actually generalizing this to a workspace/desktop so I could apply similar principles with multi-windowed Emacs — a window manager that also connects windows ;)

        Looks really intriguing, but Emacs is really hard to leave behind.

        But I do believe this pattern applies to more things than just IDEs, and might even replace multi-workspace setup. Keep at it and hopefully you are successful and this pattern keeps evolving!

  • billconan 5 days ago ago

    I'm also building a canvas app these days. Thank you very much for sharing the code. I'm very curious to know your tricks to make the canvas efficient.

    for my project, I use virtualization/windowing to only draw what's visible. but mine doesn't draw complex widgets like a code editor.

    I will dig the code to find out.

  • wanderingmind 4 days ago ago

    Digression, but among two contributors there are over 100,000 commits and the year listed is only 2024. That's an insane amount of commits (about 200 per person per day). Did they use autocommits? Would love to learn the tooling and devprocess that was used.

    • akshaysg 4 days ago ago

      The majority of those commits are not ours! For the source-available version we squashed all our commits. This is a VS Code fork so the commits you're seeing are from the contributors of VS Code.

    • ReleaseCandidat 4 days ago ago

      I guess that's because it is a VS Code fork.

  • vouaobrasil 4 days ago ago

    Looks like it might also work for writing a book with lots of chapter/source files. Will give it a go.

    • akshaysg 4 days ago ago

      Oh interesting -- I never thought of it as a tool for writing a book! Maybe we should get George R. R. Martin to give it a spin haha.

  • slightwinder 4 days ago ago

    This looks like a very simple mindmap, but more annoying to use because of the big elements. Some automated positioning seems very necessary here. Additionally, what about proper mindmap/diagram-features and notes?

    If you take a look at https://obsidian.md/canvas you will see that they have things like colored groups and different element-types. And their community-extensions have many more improvements for the canvas. Just focusing on navigation seems wasted. A good focus on mixing code, documentation and notes might be a more worthy goal, I think.

    Anyway, as this is forked from VS Code, does this also support normal vscode-extensions and other features like workspaces? And does it receive updates from the original, or is it fixed to the initial forked VS Code-version?

    • akshaysg 4 days ago ago

      We do plan to add sticky notes and other diagramming features. We also try to position the editors in the viewport/canvas automatically, but would love feedback on that!

      It supports normal VS Code extensions and features. We do plan to update it to match any VS Code updates, especially security updates.

  • observationist 5 days ago ago

    Screenshots. Show - don't tell, especially if you're making claims about visualization!

    • akshaysg 5 days ago ago

      Do you mean in the GitHub repo? Happy to add more images/gifs to the repo! It's a fairly recent addition and the website does a much better job of showcasing the product!

  • 999900000999 5 days ago ago

    Very awesome!

    I want this for C# and Python! Are their any technical challenges there? I would love to use this with Unity.

    • akshaysg 5 days ago ago

      For C# unfortunately we're missing a lot of features because the VS Code ecosystem itself lacks them (I think this is due to them being unique to Visual Studio). In most cases, except grabbing incoming/outgoing calls, Haystack should just work.

      For Python, it should work just fine!

  • throwaway4aday 5 days ago ago

    Wow, great work and kudos for making the source available! I'll have to give this a try.

  • DenisM 4 days ago ago

    How would you defend your business if/when IntelliJ implements a similar concept?

    • akshaysg 4 days ago ago

      I think it would be great if other folks started building on the canvas for code. In terms of defensibility, the canvas experience is hard to get right and we believe it can't just be a second class citizen to the editor (i.e. a sidebar). That's not a very thorough answer but are just a few of my thoughts!

  • btown 5 days ago ago

    This is really, really cool!

    On the licensing side, though:

    > We’ve made the decision to make the editor source-available so that folks can make contributions and so that they can examine the code to make sure they can trust it.

    This is a very reasonable intent, and it absolutely makes sense to preserve your options to monetize, but Polyform Strict https://polyformproject.org/licenses/strict/1.0.0/ , which you link to from your readme, seems to be far stronger than this intent.

    The way I read that license, I cannot "make changes" even if I do not distribute those changes, not even changing a line of code on a version I'm running on my own computer, whether I'm using it for a commercial project or not. So contributors, it seems, would be limited to raising issues but not PRs? And it's unclear what applies as commercial use - if I'm using Haystack on a commercial codebase, and I encounter a bug that triggers on that codebase, and want to use the Haystack source code to understand what's going on to further my commercial purpose, would that be an unlicensed use of the source code?

    Now, make no mistake - this is in no ways worse than the prior status quo of Haystack being closed-source. And I think you as a company should focus on building, with the certainty and comfort that this license, if anything, does err on the side of being restrictive. But some users, given this license, will be uncomfortable referring to the repository at all. I'll be one of those, but will still be excited to experiment with Haystack as a binary distribution nonetheless!

    (Not a lawyer, this is not legal advice!)

    • akshaysg 5 days ago ago

      Hmm I'll take a look at other licenses to see if there's one that expresses our intent in clearer language.

      The intent is that you should be able to make PRs, examine the source code, but not distribute Haystack for commercial reasons.

      I believe the license should allow you make PRs and examine code (even in commercial settings), but I'll take a more in-depth look.

      Thank you for raising this to my attention!

  • gavmor 5 days ago ago

    > Haystack takes care of the tedious confusing parts of coding

    Tedious, yes, but confusing? Yikes!

    My job as a coder is to resolve ambiguity favorably. Every day, I strive to leave the world less confusing than I found it. I would no more rely on an IDE to "take care" of confusion than I would outsource my firm's core competencies.

    But the main conceit is cool, and I'm sure the dependency graph is helpful. I'm just picking nits with marketing copy. Can't wait to check it out! (Although my first instinct is to check for a canvas plugin for VScode).

    Edit: I should say that I think this UI paradigm will fundamentally improve coder understanding by exploiting our visual cortex and "sixth sense" of proprioception, at least as far as I understand it via Supersizing the Mind (Andy Clark, 2008).

    • hathawsh 5 days ago ago

      I strive for the same thing, but every time surprising new requirements arrive, there's a good chance that the elegant architecture my team created is in conflict with the design we now want. At that point, there is a three step process:

      1. Design the new architecture.

      2. Gain a full understanding of the existing architecture and all of its trade-offs.

      3. Design a way to convert the old architecture into the new architecture.

      This happens surprisingly often and it's quite unavoidable. In the past, I tried to avoid redesigning by building things that could be expanded in every conceivable way, but I discovered that over-engineering actually makes it harder to redesign. YAGNI wins!

      I've been thinking for a while that a canvas-type editor might help a lot in the process of redesigning. It should help by taking better advantage of spatial memory.

    • akshaysg 5 days ago ago

      Hmm I think someone else has voiced a similar opinion on the wording here, and I actually do agree with you.

      What was meant by this statement is really just taking care of plumbing and the visualization of how code relates to one another.

      To give you a very basic/silly example of plumbing, if I add a parameter in a function used in 100s of places, doing the manual work to figure out what edits I need to make to those callers is pretty annoying and in most cases mechanical.

      If you're lucky, you can do a grep + replace (or just use a default param), but in most cases I find it requires more manual intervention than that.

      • gavmor 5 days ago ago

        Adding a parameter to the function signature, and then passing an additional value at each call site is done... automatically in Haystack? Impossible!

        Edit: And "to figure out what edits I need to make" is done by any ol' compiler, no?

        • akshaysg 5 days ago ago

          Not yet -- it's our vision to automate stuff like that!

          > Edit: And "to figure out what edits I need to make" is done by any ol' compiler, no?

          Kinda? There are cases where you have to drill data down into the callstack (i.e. pass data from above). There are folks who have gone down this path before: https://www.jetbrains.com/help/resharper/Refactorings__Chang... but we intend to automate it even more and show it to the user in an organized way for them to handle large-scale "refactors".

  • nisten 4 days ago ago

    looking at the package.json infestation of this thing makes me want to just go plain vim WITHOUT any plugins.

    Ok, what's that , you want AI sir, guess what b:tch, you can :split out a :terminal window and run a llama-cli conversation right inside vim too. Ctrl + w N and you even get line numbers from whatever contraption of code you got out of that 7b coder model.

  • waingake 5 days ago ago

    Is there a way to move the canvas via mac track pad which works the same way the middle mouse button does? I.e. always drags even if I'm looking at an editor

    • nodelessness 5 days ago ago

      Press ctrl while panning with trackpad. Creates tiny artifacts but works.

      • akshaysg 5 days ago ago

        This is to zoom correct? You can also pinch/unpinch!

    • waingake 5 days ago ago

      Holding down option seems to do what I want here

      • akshaysg 5 days ago ago

        Ope sorry for the late reply but OPT/ALT is the intended way for you to do this.

  • sohzm 5 days ago ago

    hey love the concept (though Im not sure if its for me).

    btw you should add a (small) gif or video in the github readme cuz that makes it really clear of what exactly its about.

    • akshaysg 5 days ago ago

      Good idea. Will add!

  • joshdavham 5 days ago ago

    > we're going to eventually monetize

    How do you plan on monetizing?

    • akshaysg 5 days ago ago

      Collaborative and generative AI features. E.g. sharing Haystack workspaces, searching your codebase in the natural language, making edits to multiple files, etc.

      • rrr_oh_man 5 days ago ago

        > Monetization

        All right

        > Collaborative

        OH! YES!

        > and generative AI features

        Oh no.

        • akshaysg 5 days ago ago

          Since it's opt-in, the generative AI features won't ever bug you unless you want to use them!

  • bofadeez 3 days ago ago

    VirusTotal detects malware on windows version "Bkav Pro W32.AIDetectMalware" (alert)

    • yatvij 3 days ago ago

      This seems to be a common false-positive. We just signed it with GlobalSign and re-uploaded it to the site; this appears to have fixed VirusTotal's Bkav Pro W32.AIDetectMalware check.

  • bhy 5 days ago ago

    This looks quite useful! However could Haystack be made an VSCode extension instead of a fork? So I could use this in Cursor, which is also a VSCode fork.

    • candiddevmike 5 days ago ago

      So many YC folks are forking VSCode for various reasons that mostly revolve around "can't monetize extensions, want to own the platform".

      I don't think any of them will be successful, IMO. You want to be an extension because getting software approved is _hard_ at bigcos, it's much easier to trojan horse on an existing tool.

      • jitl 5 days ago ago

        I think Cursor is already looking successful. Most VS Code people I know (including myself) have switched over. I love the idea of Haystack (I was a fan of Light Table back in the day) but if I have to pick between a better UI and an assistant who perform most simple code transforms by English language request, saving hour(s) per day, I’m picking the assistant.

        • akshaysg 5 days ago ago

          Yeah the productivity optimization here makes sense. We intend to add generative AI features unique to the canvas UI as well to ensure our users don't lose productivity.

          I am curious what features you like about Cursor the most? For me it's the CMD/CTRL+K -- I've had mixed experiences with the chat window and Composer.

          • jitl 5 days ago ago

            Cmd-K and tab complete with or without writing some guiding comments

      • akshaysg 5 days ago ago

        I could be wrong but I don't believe it's difficult to monetize an extension.

        The reason I think there has been an explosion of VS Code forks (e.g. Supermaven, a very successful extension) is that being an extension in VS Code is limiting insofar as what you're able to change in terms of the UI and UX.

        You are right about the difficulty of getting into big companies. However, we developed a standalone editor because it's easier to build on top of, and we eventually want to build a very portable browser-based editor that utilizes the canvas view for pull requests, arbitrary code, etc.

        • chairmansteve 5 days ago ago

          Bigcos not that hard to get into. It's just an entirely different process. You would need to hire someone with that kind of experience.

      • williamcotton 5 days ago ago

        I could be wrong but one of the main reasons to fork VS Code is because extensions have a limited UI.

        This was at least the motivation for Positron, AFAIK.

    • akshaysg 5 days ago ago

      We're going to make a "Haystack-lite" extension in the future! I understand the pain here. We chose to go with a VS-code fork so we could maximize the canvas features. I am curious if you would find the "canvas" view distracting when it's on a sidebar as opposed to the main editor?

      • bhy 5 days ago ago

        Thinking about it, a sidebar "canvas" could be more useful comparing to the main editor to me:

        * when reading code, I found I jump back and forth the call stack quite often, a visualization of this could help with this navigation, especially with some properly designed shortcut keys.

        * I mostly code on MacBook so screen real estate is precious. The canvas as main editor looks like waste a lot of screen space. But the canvas in a sidebar do not have this issue.

        • akshaysg 5 days ago ago

          1. You can hop back and forth using the "backward/forward" buttons in the top bar, similar to VS Code. Not sure if I misunderstood here. 2. That's fair. You can "pin" editors on the canvas, which allows you to fullscreen editors.

        • fragmede 5 days ago ago

          I think part of what makes this work is that ultrawidescreen monitors aren't as impossibly expensive as they once were, so screen real estate can be spent and your spacial reasoning can take over. It might just not work well on a laptop screen.

  • Nidhug 4 days ago ago

    This seems great! Wondering how it handles files being used in a lot of places (I am thinking hundred of usages) ?

  • drawnwren 5 days ago ago

    Is this just a pretty picture of the AST that I"m already navigating with go-to definition, fuzzy search, and harpoon in 2024?

    • akshaysg 5 days ago ago

      Harpoon is kind of like a bookmarking tool right? I think the value prop is that you have to do less manual window management, can see connections between code better, and can context switch between tasks.

      Reposting this from another comment: For our users, Haystack has been helpful to understand how code works together, from simple React components to legacy C codebases that are a decade or older. I think the value prop shines when you're trying to understand how multiple pieces of code together, and this will become more useful as folks increasingly lean on AI tools to modify/create/delete multiple files.

  • ElFitz 5 days ago ago

    Oh. That would be fun on the Vision Pro.

    Don’t know wether or not it would be productive, that remains to be seen, but it certainly would be fun.

  • ivanjermakov 5 days ago ago

    Interesting, for me this is exactly the opposite of efficient code navigation.

    LSP + keyboard-driven interface is miles ahead in terms of efficiency and speed.

    I respect the effort of breaking into less researched lands though. Congrats on the launch, I'm sure some will find this tool useful.

    • akshaysg 5 days ago ago

      This is fair! Not sure if you're a VS Code user, but our goal is to maintain a parity between the keyboard experience in VS Code and the keyboard experience in Haystack. All the keyboard shortcuts in VS Code still live in Haystack.

      If you're a Vim user then this is an entirely different story haha.

    • scrozier 5 days ago ago

      To give you (Haystack authors) another datapoint, I'm a +1 to this comment. I can't think of a time when a canvas UI solved a problem I had. Usually it made navigation more difficult.

      But also agree that it's great that you're innovating in this space! Good luck!

    • necovek 5 days ago ago

      I actually like keyboard-driven interface + spatial layout, I just don't have a large enough monitor (I've been hoping for 40"+ 8k monitors for years). But having multiple files open that smartly refocus and rearrange as you ESC-. (Emacs shortcut to jump to implementation of a thing under cursor) would be wonderful: if smart "arrows" are drawn between file boxes, that'd be sweet as well.

      The hard bit is making that to be "smart" and not annoying with things moving that you still need.

  • haolez 5 days ago ago

    If this is supposed to be a next step from text files, what would be the previous step? Forth blocks? :)

  • t-writescode 4 days ago ago

    So where does paying for it come in? This needs to make money in some way, right?

  • cedws 4 days ago ago

    Reminds me of Ted Nelson’s Xanadu. Was that an inspiration at all?

  • TheBengaluruGuy 4 days ago ago

    interesting -- i recently another startup trying to play around in this area https://metz.sh/

  • chirau 5 days ago ago

    Is this a YC backed company?

    • akshaysg 5 days ago ago

      Yes (all launch HNs are YC-backed)

  • bitbasher 5 days ago ago

    A gulpfile... has been while since I've seen one of those.

    • akshaysg 5 days ago ago

      Yeah VS Code is built on top of some older frameworks and ideas unfortunately.

  • MaggieL 4 days ago ago

    Looks interesting, but the license is a show-stopper for me. I can't expose my employer to that kind of risk. I poured a lot of time and effort into learning Akka and has to throw it all away.

    • akshaysg 4 days ago ago

      Sorry I missed this comment! We're going to move to a license that has less confusing language. You should definitely be able to use Haystack at work!

  • aappleby 5 days ago ago

    What happens when I have 10,000 or so editors open at once?

    • aappleby 5 days ago ago

      Proof of concept of mine from years ago - every file from the Linux kernel open in a browser window at once

      https://github.com/aappleby/wideboard

    • akshaysg 5 days ago ago

      I've actually never tried this (it'll probably take awhile to get to this point). Feel free to try it out and report back the results -- I'm curious as well!

  • calderwoodra 5 days ago ago

    If you structure your directories sensibly, you can get the same effect/value prop in every IDE and dev env.

    Or is there a deeper experience/knowledge that gets unlocked coding in this paradigm?

    • akshaysg 5 days ago ago

      Not sure if I completely grasp what you're saying, but you're saying that if you plan the codebase well then dependencies between files/bits of code are more easily followed?

      For our users, Haystack has been helpful to understand how code works together, from simple React components to legacy C codebases that are a decade or older. I think the value prop shines when you're trying to understand how multiple pieces of code together, and this will become more useful as folks increasingly lean on AI tools to modify/create/delete multiple files.

  • fogx 4 days ago ago

    seems like a neat idea, but how does this 10x my dev performance?

  • jderick 5 days ago ago

    It doesn't make sense unless zooming out shows some higher level representation of the code.

    • akshaysg 5 days ago ago

      We certainly intend to add semantic zoom levels, but for now I think zooming out is just helpful in navigating the canvas when you have multiple connected components on the canvas at once and need to pan to an area in the canvas.

  • Tepix 5 days ago ago

    Did you really have to pick the same name as the Haystack open source AI framework? https://haystack.deepset.ai/ https://github.com/deepset-ai/haystack

    It's a very active project and it's confusing to have two projects with the same name. Besides, I don't understand why you'd give a "2D digital whiteboard that automatically draws connections between code as you navigate and edit files" the name haystack.

    • akshaysg 5 days ago ago

      This is an unfortunate name collision, but in our defense the concept of a "needle in a haystack" is hardly unique and I believe a code editor is different enough from the AI framework that it's OK.

      The idea is that a codebase is much like a haystack and finding the relevant portions of it for a task or specific flow would be equivalent to finding needles.

  • rrr_oh_man 5 days ago ago

    This is so. fucking. sexy.

    Wow.

    Thank you for sharing your work.

    Please don't go down the GenAI bullshit bingo VC route.

  • ksksksko 5 days ago ago

    Winsnw