Do you keep them in your IDE, or elsewhere? Do you have an app for that? Are they easily shared?

I realized I have no system at all but could use one to make it easier to find code I’ve written and might need again some day.

By snippets, I am referring to any chunk of code / text in any format or language, of any length.

Thanks!

EDIT A DAY LATER: Thanks you all! Reading all these ideas, I got inspired to create my own little web app. Wish me luck… :)

  • Zeth0s@lemmy.world
    link
    fedilink
    arrow-up
    67
    arrow-down
    3
    ·
    1 year ago

    I create proper libraries. I don’t do snippets because they make code dirty, redundant and difficult to read on the long run.

    I actively discourage people in my team to use snippets copy and pasted everywhere themselves. If it’s reusable code, it should be usable by everyone and well tested

    • Tekhne@sh.itjust.works
      link
      fedilink
      arrow-up
      4
      ·
      1 year ago

      The only case I use snippets for is for debug code that I use often. Sometimes there are things I find myself doing a lot for debugging that don’t have any reason to be in code (e.g. nicely formatting certain objects for debug purposes)

      • xmunk@sh.itjust.works
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        Write a function or macro so you can reuse them. The project I work on has dozens of debug assisting code paths. Here are two examples: normally when talking to the db you’ll call run($sql, $boundVariables) on a handle. Alternatively you can call debug($sql, $boundVariables) to have the handle run the query normally then rerun the query prefixed with EXPLAIN (blah,blah) to get the execution plan. We also have assembleEmulatedQuery($sql, $boundVariables) which will manually replace all the binding tokens in the SQL with their values, do some string escaping and return a big honking string that you can dump into the database… that last one is useful for performance tuning since it can be used to easily capture expensive query forms. Also - assembleEmulatedQuery will throw an exception on our production environment because it’s unsafe due to the potential of SQL Injection.

        Build debugging functions and add tests over them - future you will thank you!

  • Lysergid@lemmy.ml
    link
    fedilink
    arrow-up
    23
    ·
    1 year ago

    Please, can you give an example of such code snippets? I’m wondering what people consider reusable in different projects.

      • xmunk@sh.itjust.works
        link
        fedilink
        arrow-up
        1
        arrow-down
        7
        ·
        1 year ago

        If a library or framework requires boilerplate code it’s a bad library or a bad framework.

        • lysdexic@programming.dev
          link
          fedilink
          English
          arrow-up
          6
          arrow-down
          1
          ·
          1 year ago

          If a library or framework requires boilerplate code it’s a bad library or a bad framework.

          I think this take is uneducated and can only come from a place of inexperience. There’s plenty of usecases that naturally lead to boilerplate code, such as initialization/termination, setting up/tearing down, configuration, etc. This is not a code smell, it’s just the natural reflection of having to integrate third-party code into your projects.

          • shnizmuffin@lemmy.inbutts.lol
            link
            fedilink
            English
            arrow-up
            2
            ·
            1 year ago

            Yes, in my experience, boilerplate typically comes into play when you’re using two libraries that don’t know about one another, or have no business touching each other’s concerns. (Using Alpine’s x-cloak with Tailwind comes to mind.)

            That and every single *-pipelines.yaml CI/CD config I’ve ever written.

          • xmunk@sh.itjust.works
            link
            fedilink
            arrow-up
            1
            ·
            1 year ago

            It depends how much boilerplate you need - there’s obviously some stuff that needs to be the same all over but if there’s significant amounts of code you constantly need to replicate that’s when it’s a code smell for me. I probably could’ve been more precise in my initial statement.

    • derpgon@programming.dev
      link
      fedilink
      arrow-up
      4
      ·
      1 year ago

      In PHP, a lot. Unit test are boilerplate 90% of the time, getters and setters (although they can be done via Generate), ORM classes with your default shebang (autoincrement ID), and I could go on and on.

      I dislike snippets for code like “key this array by some logic” - this should be reusable via a dedicated helper or service.

      • xmunk@sh.itjust.works
        link
        fedilink
        arrow-up
        2
        arrow-down
        2
        ·
        edit-2
        1 year ago

        Getters/setters can also be done automatically by __get, __set or __call it’s even possible to write a base class or trait that does this automatically.

        I am a PHP guru, if you’ve ever got questions I’m happy to help.

        • derpgon@programming.dev
          link
          fedilink
          arrow-up
          1
          ·
          1 year ago

          Sadly that’s against best practices, it does not work with IDE autocomplete, and neither with PHPStan / PHPCS. You also don’t get coverage from PHPUnit. And renaming a property does not rename the usage across the whole project. __get and __set should not be heavily used, and the project shouldn’t be based on them.

          Some libraries, like Eloquent, uses them well, but you still need to annotate your class with @property if you want to stay sane.

    • otl@lemmy.srcbeat.com
      link
      fedilink
      English
      arrow-up
      3
      arrow-down
      3
      ·
      1 year ago

      Let’s say a function, about 20 lines. Something too small to warrant an external dependency but tricky enough that you don’t want to keep rewriting it.

      I have things like a function to read through a file of newline delimited text of key-value pairs separated by whitespace. It skips comments (lines beginning with “#”), and returns the pairs. I’m happy to do a little copying instead of having a little dependency.

    • perishthethought@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 year ago

      It’s got to be here somewhere… (Search for way too long…) Dang, I guess I’ll just write it again from scratch

      Yeah, this is what I am looking to avoid.

  • varsock@programming.dev
    link
    fedilink
    arrow-up
    11
    arrow-down
    1
    ·
    1 year ago

    I would appretiate if someone could explain the practical utility of snippets because it just dawned on me how useful they might be.

    • coloredgrayscale@programming.dev
      link
      fedilink
      arrow-up
      9
      arrow-down
      1
      ·
      edit-2
      1 year ago

      Easy access to small snippets of code you often need, but putting them in their own library would be crazy.

      • Opening a file / db connection
      • parsing xml/json/… ,
      • template for unit tests,
      • import and initialization of framework at work.

      Depending on the IDE snippets can also move parts of the code around: (intellij live templates)

      • variable.notnull -> if (variable != null) {… }
      • “text %s”.format -> String.format(“text %s”,…)
    • perishthethought@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      Think about how you write code. Is it all new, or are there functions / API calls / whatever that you might re-use from time to time?

      If that’s possible, think about how you go find that code now. Wouldn’t it be cool if you could type a short bit like, “funcA” and boom! your IDE filled in the whole function? Or, worst case, you flip over to another tool, find the snippet you want, copy and paste it into your work.

      That’s what I am thinking about, at least. I’m just not sure how I want to get there yet.

      • crimsonpoodle@pawb.social
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        You could just write a little terminal utility that puts the string literal of the snippet in your copy buffer with a little search and db for finding the right one and storing new ones— might have to have some weird cases for cross platform tho

    • Luvon@beehaw.org
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      If you are unfortunate enough to code in a language where the “designers” thought EVERYTHING should be multi command structures in an English like syntax……

      Then you basically need them to autocomplete how to correctly write everything 😅

      I use Abap at work from sap. Its special.

      They have over 3000 key word structures. It’s ridiculous.

    • perishthethought@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      Thanks. I am thinking about whether a self-hosted service is overkill for this, for my purposes. I kept my question broad in order to find out if most people just keep their snippets on their own PC or what.

      I will check this out and I’m also looking at Snibox.

  • brewbart@feddit.de
    link
    fedilink
    arrow-up
    8
    ·
    1 year ago

    I would recommend looking into personal knowledge management. I manage mine in Obsidian and treat snippets like permanent notes

    • Spazsquatch@lemmy.studio
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      Maybe not something you intended, but your phrasing has me curious if Obsidian has some sort of temporary note? I can imagine some use cases.

      • brewbart@feddit.de
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        Temporary note in terms of auto delete after a time? Although the manual Zettelkasten workflow intends you to delete your temporary notes by hand, it is pretty easy to automate this in Obsidian. Personally I have some actions for meeting minutes and notes on people to be moved to designated folders, but the same principle could be applied to create an action to delete any note older than X days

        • Spazsquatch@lemmy.studio
          link
          fedilink
          arrow-up
          1
          ·
          1 year ago

          Yeah, that’s what I was thinking, and you are right that automation wouldn’t be hard… although if I’m setting up that automation I’ll fail to commit to the deletion and just move the files to an archive folder. 😳

          I only adopted Obsidian recently and only because I liked the idea of the data being stored as plain text files. I really haven’t adopted any system, just replaced Apple Notes.

    • perishthethought@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 year ago

      Hmmm, I am using Logseq for that kind of note rn, but don’t really like the way it handles code. I assume that’s a markdown problem, not a Logseq one, but I should look again.

      • brewbart@feddit.de
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        Well, Obsidian does have a bazillion plugins that make handling all kinds of content easier. I’m pretty satisfied with the out of the box experience though

      • nichos@programming.dev
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        I’m using logseq for snippets too. I find it to be adequate. 3 ticks and the language will get you monospace and syntax highlighting:

        cd $HOME
        ls
        
  • Veraxus@kbin.social
    link
    fedilink
    arrow-up
    6
    ·
    edit-2
    1 year ago

    Jetbrains IDEs have “Live Templates” that I use extensively.

    For little notes and snippets (especially CLI snippets) I use an app called Stashpad, which I LOVE.

  • shiveyarbles@beehaw.org
    link
    fedilink
    arrow-up
    4
    ·
    1 year ago

    I have like a zillion notepad++ tabs. Every once in a while I’ll go through the tabs to see if I want to save the snippets.

    • perishthethought@lemm.eeOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 year ago

      That’s where I am now. I keep seeing snippets tools and so I asked here. Now that you’ve seen these replies, what do you think?

      I assume the answer is very specific to the coding you do & your workflow. There’s no single right answer.

  • terrehbyte@ani.social
    link
    fedilink
    English
    arrow-up
    2
    ·
    1 year ago

    I’ve only used code snippets in VS Code which can store them in user settings for synchronization. They can also e stored in project settings, which can be optionally synchronized via source control.

    I tend not to need them in larger projects where a lot of codegen is available or macros, so I haven’t thought about a solution for things like VS or manual syncing.