• aport@programming.dev
    link
    fedilink
    arrow-up
    60
    arrow-down
    19
    ·
    1 year ago

    Alternatively you can use and support a true community-driven editing environment dedicated to preserving your freedom, like vim/neovim or emacs.

    • I_like_cats@lemmy.one
      link
      fedilink
      arrow-up
      64
      arrow-down
      5
      ·
      1 year ago

      But that’s something new to learn and configure. I just want to code why should I spend my time learning another text editor when vscodium is fine

      • Potatos_are_not_friends@lemmy.world
        link
        fedilink
        arrow-up
        59
        arrow-down
        2
        ·
        1 year ago

        Careful. You’re in a linux-heavy audience. They’re the kinda people who would spend a few weeks setting up systems to use it for a few minutes.

        • U de Recife@literature.cafe
          link
          fedilink
          arrow-up
          8
          arrow-down
          1
          ·
          edit-2
          1 year ago

          That’s simply outrageous!!! As soon as I finish tinkering with my system, I’ll prepare a proper reply…

          On a more serious note though. Don’t overlook the role of procrastination in the endless tinkering many put on their boxes. I’m speaking from experience.

          • No1@aussie.zone
            link
            fedilink
            arrow-up
            9
            ·
            edit-2
            1 year ago

            Well, it’s because after using the system for only a few minutes, I realise it’s not quite right, and I’ll have to spend a few weeks to set it up again!

        • Synthead@lemmy.world
          link
          fedilink
          arrow-up
          6
          arrow-down
          1
          ·
          1 year ago

          I’m a full-time Vim and Linux user when writing code. I agree with the statement that “simply switching” editors is very naive. I’m my personal opinion, you should decide on an editor that makes sense to you and learn to be very good at it. If VS Code is that answer, then great. Not everything points to Vim or Emacs.

      • nonearther@lemmy.ml
        link
        fedilink
        English
        arrow-up
        15
        ·
        1 year ago

        Who doesn’t want to go through learning of text editor and pain of configuring instead of actually coding?

      • shotgun_crab@lemmy.world
        link
        fedilink
        English
        arrow-up
        6
        ·
        1 year ago

        That’s fine too. Use whatever does the job for you, but give alternatives a try if you ever have the time.

      • exu@feditown.com
        link
        fedilink
        English
        arrow-up
        4
        ·
        1 year ago

        Well, if you learned emacs, you could do everything in it and won’t have to change ever again! /s kinda

      • sugar_in_your_tea
        link
        fedilink
        arrow-up
        3
        arrow-down
        3
        ·
        edit-2
        1 year ago

        Same reason why a carpenter should learn to properly use hand tools, or a teacher should keep up on literature. In other words, master your tools. It doesn’t matter which tool you use, provided you can use it to its full potential.

        I occasionally use VSCode, but I mostly use ViM because that’s my tool of choice.

        For another reason, if your ever in the situation where you need to work on something on a remote server or an unfamiliar machine, knowing ViM means you can at least be somewhat productive when you don’t have your normal tools available.

        • I_like_cats@lemmy.one
          link
          fedilink
          arrow-up
          1
          ·
          1 year ago

          I know vim. I’m using vscodium with a vim plugin. I was coding in pure vim for half a year because my Laptop with 4 gigs of RAM couldn’t handle vscode. I just don’t want to configure vim so it does all the stuff VScodium does for me

          • sugar_in_your_tea
            link
            fedilink
            arrow-up
            1
            ·
            1 year ago

            That’s fine, use what works best. I think there’s value in getting at least the basics working, such as syntax highlighting and linting in case you want or need to use it again.

            The question was why one should learn to use something like ViM or emacs, not why anything else is a poor option. Master your tools, regardless of what they are.

    • baseless_discourse@mander.xyz
      link
      fedilink
      arrow-up
      15
      ·
      edit-2
      1 year ago

      I would love to use emacs, unfortunately coding in TypeScript is much more pleasant to me than coding in elisp or lua.

      Not to say Typescript is a good experience either, I always feel like fighting the language than actually coding. Just saying they are better than elisp or lua.

      Also I find vscode has better mouse interaction, but maybe emacs got better with time.

      • sugar_in_your_tea
        link
        fedilink
        arrow-up
        2
        arrow-down
        2
        ·
        edit-2
        1 year ago

        Are you talking about configuring the editor? Ideally, that’s not a common task, so it really shouldn’t matter much if it uses TypeScript, elisp, vimscript, or lua.

        And if you’re primarily using the mouse, you’re missing most of the point of editors, especially emacs and ViM. The real power of those editors comes from keyboard shortcuts and combos, not from plugins and menus.

        • baseless_discourse@mander.xyz
          link
          fedilink
          arrow-up
          5
          ·
          edit-2
          1 year ago

          Yes, ideally a editor would work without any configuration, but unfortunately I haven’t met any emacs user with sub 200 line dot files.

          I personally cannot remember more than 20 hotkeys to save my life.

          Also I find the most time-consuming part of my work is actually thinking, not clicking around with a mouse. so I don’t really need to spend month to remember all the hotkey just to save 2 seconds clicking. In fact, slow down and click couple buttons to commit gives me a bit to rest and enjoy the moment when I have finished a task…

          • sugar_in_your_tea
            link
            fedilink
            arrow-up
            4
            ·
            edit-2
            1 year ago

            It’s not about optimizing code entry, but optimizing reading code, since you read code a lot more than you write it.

            I’m not super familiar with emacs, I’m a vim person, but here are a few examples of mouse vs keyboard navigation.

            Search for text in a file:

            Mouse:

            1. select the text
            2. click “find in page”
            3. click “next”

            Shortcut:

            1. Ctrl + F
            2. Click “next”

            Vim:

            1. Type * on the word you want
            2. Type n for next, N for previous

            Find matching brace/bracket/parenthesis:

            Mouse:

            1. Click on brace
            2. Scroll until you find the match

            Shortcut: not sure

            Vim:

            1. Type %

            Navigate to the top/bottom of the file:

            Mouse: scroll or click the sidebar

            Shortcut: not sure

            Vim: gg for the top of file, G for the bottom

            Go to a specific line:

            I.e. If from output from a script, like a test failure.

            Mouse: scroll or if you have a plugin, click on the red part (i.e. test or lint failure)

            Shortcut: in VSCode, Ctrl + click on file name

            Vim: <number>G or :<number>

            And so on. Vim is optimized for code navigation, a mouse is optimized for intuitive navigation (but slower), and shortcuts kinda fill in the gaps.

            If you just want to get up and running quickly, something like VSCode is a good option. That’s what I did when I decided to help my team out with some FE TypeScript code, when I normally use something else. I actually installed a vim plugin for VSCode to get the best of both worlds.

            But if you really want a fluid code navigation and editing experience, master something like ViM or emacs.

            Oh, and I didn’t mention one of the most powerful things in both ViM end emacs: macros. I use them a ton when manipulating text, such as converting JSON to a class/struct, or doing repetitive syntax changes that are just out of reach of a regex.

            • PrometheusG@lemmy.one
              link
              fedilink
              arrow-up
              3
              ·
              1 year ago

              Proper VS Code shortcuts for the above cases…

              Find next: Ctrl-f, F4

              Find matching brace: Ctrl-]

              Navigate to Top or Bottom: Ctrl-Home Ctrl-End

              I think it’s the same number of keys pressed as vim in every case.

              • sugar_in_your_tea
                link
                fedilink
                arrow-up
                1
                ·
                1 year ago

                Probably, and we could go back and forth based on features. My main point was that using the keyboard is generally more efficient than using the mouse, especially since my hand is already there.

                So for software you use every day, master it. Master the keyboard shortcuts, learn how to customize things, etc. Maybe VSCode has an option for macros, IDK (I’ve used them with the ViM mode, so that’s at least one option). Using the mouse should be a fallback, not the first option.

            • baseless_discourse@mander.xyz
              link
              fedilink
              arrow-up
              1
              ·
              1 year ago

              You raise a valid point. Personally, I used to read and write a lot of code, but I no longer do that. I still maintain a open source project, but my job no longer involves writing code that runs.

              IIRC, the most useful functionality I used to use are:

              • peak/goto definitions,
              • mouse over to peak doc and type signature,
              • find usage in project,
              • refractor the name/signature of a function,
              • real time linting and quick fix.

              I am quite curious on why go to beginning or end of the file useful? Also I am not sure that the basic find/replace is more useful than find usage/refactor.

              • sugar_in_your_tea
                link
                fedilink
                arrow-up
                2
                ·
                1 year ago

                peak/goto definition

                Plugins are available for most popular languages. I rarely need to see the type of a value, and if I want to see the signature of a function, I usually want to go to the implementation as well.

                find usage

                I just use grep. I’m already in a terminal, so I have all of those features available. Since I use tmux, I just switch over to another pane and run my search there. For changing the name of a function (which is very rare), I just use sed or do the change manually with vim $(grep ...) if it’s more than just a name change (usually I’m changing the signature too).

                real time linting

                I use a plugin for that, and it works really well.

                beginning or end of file useful

                Beginning of file: look for an import/constant

                End of file: add new function, or a shortcut to the last brace to jump to the start of the class/function. I try to keep files small and single-purpose, so it’s usually what I want (jump to end and match braces).

                And yeah, I occasionally miss context-aware search/refactor, but again, it’s so rare that it’s not a big deal. I save far more time with macros than I lose doing manual renames. If I know I’ll be doing a lot of that (and usually it comes in bursts), I have VSCode installed as well. But I don’t launch it very often.

                My whole workflow is very command-line oriented, so using a GUI tool just gets in the way for me.

                  • sugar_in_your_tea
                    link
                    fedilink
                    arrow-up
                    2
                    ·
                    1 year ago

                    Yup, use what works. Most of my coworkers use VSCode, and I’m the oddball with ViM (though I have VSCode installed w/ ViM extension).

                    Whatever you use, master it. I recommend learning some CLI editor in case you end up needing one.