Human Who Codes Newsletter - Leadership Roles


​

Thoughts on Leadership Roles

As you progress in your software engineering career, your leadership skills become increasingly important. Even if you never transition to a management position, you are still likely to find yourself leading others whether that be formally through a role as tech lead or informally as a senior member of your team or company. While there are many different types of leadership there are five primary roles that you'll play.

Teacher. You'll directly instruct someone else on what they need to do. In this role, you are guiding people, step-by-step, to learn new skills and concepts. This might involve teaching a class, giving a talk, writing a blog post or book, or even pair programming with someone to help them through a difficult task. Teacher hold the hands of their students to help develop.

Mentor. You'll indirectly help someone with what they need to do by engaging with them. In this role, there's less hand holding than in the teacher role and you instead help by giving advice. You might share stories of your own experiences or connect them with resources or people who can help. Mentoring is a hands-off role where you act as a sounding board and resource to help point people in the right direction but don't get directly involved in the work.

Coach. You'll directly help someone by asking them to think deeply about the task. Where teachers will give you the next step, coaches instead challenge you to discover the next step with their guidance. Coaches don't give step-by-step instructions, instead, they ask questions to help change thinking. Coaches inspire action through discussion with the end goal of developing certain skills in their coachee. (By the way, I offer coaching.)

Supervisor. You'll oversee the work that someone else is doing to validate that it is done correctly and on time. While this role traditionally falls to a manager, there are certainly times when tech leads are required to supervise their teammates. Supervising means pointing out when expectations are not being met and holding people accountable for meeting them. Practically speaking, this most often happens for tech leads during code reviews, where it's your job to ensure that the quality of the code is up to company standards.

Sponsor. You'll indirectly help someone develop by providing them with opportunities they might not otherwise receive. Sponsoring inside of a company often looks like recommending someone for certain positions or roles, or ensuring someone gets a certain type of work that will help them develop the necessary skills. Oftentimes, the person you're helping won't know that you've sponsored them. Being a sponsor is about opening doors so someone else can walk through, setting up to succeed.

You won't play all roles to everyone in your career, and you might play several of these roles inside of conversation with someone. For today, just keep in mind that there are many different types of leadership, and therefore, many different ways for you to help your teammates grow. Understanding and using these roles will help you continue to progress in your own career while benefiting others as well.

​

Key Takeaways

  • There are five leadership roles you can adopt: teacher, mentor, coach, supervisor, and sponsor.
  • Each role is appropriate in different situations and you will likely move between roles frequently, sometimes even within the same conversation.
  • Tech leads have the opportunity to practice all of these roles even without direct reports.

Further Reading

πŸ“š You're the Leader, Now What? by Dr. Richard Winters

If you enjoyed the discussion about the different leadership roles, then you'll probably like this book, which contains a whole chapter on this topic. This is a book on leadership in general and not technical leadership specifically, but it is definitely applicable to software engineers (and anyone else).

πŸ“š Multipliers by Liz Wiseman

Another general purpose book, this one explains how to be a multiplier, which means that you help other people succeed. I've written before about the importance of being a multiplier as a tech lead and staff engineer, and this book has a much longer discussion about how you can grow in your career by helping others grow.

Want more book recommendations for software engineers? Check out my reading list for a complete list of what I consider must-read books.


β™₯️ Sponsor me on GitHub. Over the last two months, GitHub eliminated PayPal donations and as a result my sponsorships decreased by over 80%. If you enjoy the free content and code that I provide, please sponsor me on GitHub.


Stuff I've Enjoyed This Month

🎬 Where do types go? Not here by Matt Pocock
I've been experimenting more with writing JavaScript projects with TypeScript type definitions, and at first I was confused as to where I should put those type definitions. This video explains succinctly how to provide types for your JavaScript project.

🎬 How Google remapped the world by Wall Street Journal
I've always been interested in Google maps and how it works, but never really spent much time looking into it. This short video explains where Google maps came from and how it keeps accurate and up-to-date.

πŸ“ How to load HTML from another page with vanilla JavaScript by Chris Ferdinandi
Getting back to basics, this post explains how to use vanilla JavaScript to pull in HTML from another page and display it in a dialog. As someone who is a big believer in understanding the fundamentals of the web platform, I'm always happy to see tutorials like this that help people understand the browser primitives that underlay what the UI frameworks are doing.

πŸ“ Prerender pages in Chrome for instant navigation by Barry Pollard
Back in the day, Chrome had a feature that would allow you to prerender pages for faster navigation. That original approach had some problems so it was removed only to return now in a better-thought-out version that will soon allow you prerender your pages again. This post explains the differences from the original approach and how to try it today.

πŸ“š The Staff Engineer's Path by Tanya Reilly
There are so few books about the role of staff engineer that I had to pick this one up when I saw it. While a bit long-winded and abstract at times, I found that there were still some useful nuggets of information throughout, such as being mindful about your social capital and credibility. I think Will Larson's Staff Engineer is a better overall book about the role but this one certainly has its moments.


What I'm Working On

🏠 Real Estate: My latest BRRRR property is still awaiting repair for the hail damage. I finally found a construction company who are willing to work with the insurance company on the needed repairs. I'm hoping that I'll see some progress in the next week. Follow my Instagram for photos.

πŸ“ Blog: I wrote a three-part series called Managing your interrupt rate as a tech lead. The goal of the series is to help tech leads regain control of their schedule but minimizing interruptions. Tech leads are often pulled in a lot of different directions, and this series is here to help. You can read each part here:

πŸ’» ESLint: I've been working primarily on the language plugins project, with the latest pull request aiming to move more JavaScript-specific functionality out of the core. The overall goal is to have a language-agnostic core that will allow ESLint to easily lint languages other than JavaScript.

Human Who Codes Newsletter

A once-per-month newsletter discussing topics important to senior-level software engineers, with a particular focus on frontend technology and leadership.

Read more from Human Who Codes Newsletter

Thoughts on Rates of Change One of the first things I realized about working in codebases is that different parts of the codebase change at different rates. There are some files that are touched very frequently while others can go months, or even years, without being touched. This fascinated me, partly because it reminded me of my closet (why do I even still have those jean shorts?), and partly because people seemed to put such little thought into optimizing their projects to reflect this...

Thoughts on Node.js, Deno, and Bun If you started working in the tech industry after 2005, what’s going on now may seem like a shock. Large tech companies continue to lay people off despite record profits. Smaller tech companies are also laying people off, and in some cases, having β€œquiet layoffs,” where they find other ways to reduce headcount, including offering employees three months of salary to voluntarily leave the job. As a result, there are more software engineers looking for jobs in...

Thoughts on Node.js, Deno, and Bun For well over a decade, if you wanted to run JavaScript on the server, your only choice was Node.js. It has been battle-hardened by some of the most demanding companies in the world, many of whom paid employees to help maintain or contribute to the project. Then in 2018, Node.js creator Ryan Dahl announced Deno, a new server-side JavaScript runtime that was intended to fix a lot of the problems of Node.js. Fast forward to 2023, and Bun was released as...