TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

You Are Not Paid to Write Code

328 pointsby tylertreatover 8 years ago

48 comments

simula67over 8 years ago
My working theory about this is that the industry is driven by resume-driven development. Recruiters filter resumes with a keyword based search : &#x27;Do you have React experience ?&#x27;, &#x27;What about docker ?&#x27;, &#x27;Do you do Ruby on Rails ?&#x27;. If you cannot show experience in the current hotness, your chances in the job market diminishes. So people pick up the new hotness and implement their next solution with that technology whether or not it is the right tool for the job. If we fix the job market, this problem might automatically disappear.<p>Another solution could be encouraging personal projects. Many companies over-work their employees to the point that they cannot do anything in their spare time. Give employees free time and encourage them to play with new technology in their personal projects. The curious ones will have an outlet to channel their energies and you will get a rock solid stack. Also, they will be knowledgeable to take you forward when a problem that requires their newfound knowledge arises in your organization.
评论 #12976205 未加载
评论 #12976421 未加载
评论 #12977892 未加载
评论 #12976810 未加载
评论 #12976726 未加载
评论 #12975890 未加载
评论 #12980282 未加载
sebringjover 8 years ago
I&#x27;m coming from learning all about toothpicks and glue, then seeing every problem solved as building things with toothpicks and glue. It was quick and fun at first but my creations were brittle and sometimes were dangerous even. Gradually I became aware of ductape, saws, plywood, nails, hammers, steel, etc, then pre-fabricated parts. Eventually, I ended up buying some from vendors even that had compatible standards so I could make things quicker piecing them together. In the end, just having to try to come up with things that were already made seemed stupid and a waste of my time but unfortunately, that idea only seems to make sense to people that have gone through the same.<p>But it ain&#x27;t all bad, see. I hear some young folks are coming up with brand new types of toothpicks and glue, hell some of em&#x27; I hear put themselves together.
评论 #12977728 未加载
alkonautover 8 years ago
Not sure what the articles point is? That you shouldn&#x27;t write an application if you can use an off the shelf tool? Who does that?<p>I&#x27;m paid to write code because someone wanted an application. I don&#x27;t think I could tell the customers who buy our application that they should learn some bash or excel and solve their business problems?<p>I assume under some rare circumstances a developer isn&#x27;t faced with writing an app (site, CAD program, OS, ...) but instead to solve some business problem internal to a business - <i>then</i> you have the option of not writing code.
评论 #12976461 未加载
评论 #12976179 未加载
评论 #12977114 未加载
评论 #12978216 未加载
white-flameover 8 years ago
The major problem of bringing in external technologies is that they take over your architecture, not that they might introduce bugs.<p>There is no catch-all architecture, so there is guaranteed to be some impedance mismatch between the expectations of your project, and the provisions of the 3rd party tool. Heaven help you if you need the facilities of multiple architectures, and try to marshal and connect disparate datatypes and calling&#x2F;threading assumptions together.<p>As programmers, we work with general purpose programming languages. Many project-specific problems are not difficult to solve in a custom manner, given somebody with enough experience and hindsight to know how to write such a forward-looking thing robustly. It is a serious consideration whether or not to defer your architecture to generic external sources that were not written with your unique needs in mind. And even if you do, it is by far a best practice to ensure that such things live behind an application-specific abstraction separating out your project-specific code from entangling 3rd party code, allowing you to perform the inevitable migration to a different platform later.
评论 #12976211 未加载
binalpatelover 8 years ago
This is employer-centric in my opinion - sure you&#x27;re not paid to write code, and sure you can reuse existing code base in new and exciting ways.<p>But - there&#x27;s also value in learning new things, in new skills, in new toolsets. Maybe it&#x27;s not best for the employer, but for you the employee it can help quite a bit.<p>There&#x27;s a fine balance - ideally your employer encourages you to learn things on the job, and to try new things that may not necessarily make it to production, but improve your skillset overall.
评论 #12977801 未加载
评论 #12977419 未加载
agentultraover 8 years ago
&gt; In fact, code is a nasty byproduct of being a software engineer.<p>This is the core of the matter.<p>This is something Dijkstra, Edward Cohen, Jayadev Misra, and others in and around the formal methods camp have been saying for decades. It is more worthwhile to solve the problem than to guess your program into existence and patch the errors later. To dismiss them is to say you do not appreciate the true difficulty of programming and designing systems.<p>In practice I don&#x27;t write formal proofs for every line of code -- how exhausting! But I do often write high-level specifications in tandem with the software I&#x27;m using to implement it and often one informs the other to the true nature of the problem I&#x27;m trying to solve. And I find that as I improve in different logics and predicate calculus I can find and spot the design errors in the structures formed by code that you don&#x27;t see if all you&#x27;re doing is trying to &quot;solve the puzzle.&quot;<p>The whole approach to guessing your program and patching the bugs later is far too addictive. It saddens me when otherwise good programmers fall into this trap. It creates work for oneself but it keeps you from solving the real problem at hand!<p>Nice article. Not sure about the allure of &quot;Taco Bell,&quot; but the spirit is in the right place.
评论 #12977924 未加载
DanielBMarkhamover 8 years ago
Every now and then we&#x27;ll see an HN thread that asks something like: what do you know now that you wish you would have known when you started programming?<p>This. This is the thing that took the longest to sink in and had the biggest impact. There were a lot of cool languages, tools, platforms, and systems along the way, and I was stoked picking up each one and coding -- but after decades of that, I realized I was focusing on the wrong thing.<p>I think the thing that convinced me was when I got to start watching lots of technology teams in the wild across multiple organizations. So many times I would see conversations and tons of problem-solving effort being spent on the tools to solve the problem instead of the problem itself.<p>A couple of years ago I was teaching tech practices to a team that was deploying on iOS, Droid, and the web. After we went over TDD, ATDD, and the CI&#x2F;CD pipeline, I emphasized how crucial it was not to silo. When I finished, a young developer took me aside.<p>&quot;You don&#x27;t understand. We have coders here who just want to do Java. They want to be the best Java programmers they possibly can be.&quot;<p>I told him that he didn&#x27;t understand. Nobody gave a rat&#x27;s ass about people wanting to program Java. They cared about whether the team had both the people and technical skills to solve a problem they have. It would be as if a carpenter refused to work on a cabinet because it wouldn&#x27;t involve using his favorite hammer. You&#x27;re focusing on the wrong thing.<p>Sadly, once you get this, the industry is all too happy to punish you for it. That&#x27;s because the resume&#x2F;interview&#x2F;recruitment world is interested in buzzwords and coolkids tech, not actually whether or not you can make things people want. This means sadly, in a way, if you continue growing, it&#x27;s entirely possible to &quot;grow out of&quot; programming.
评论 #12976621 未加载
scotty79over 8 years ago
Actually I&#x27;m paid to do this: <a href="http:&#x2F;&#x2F;devhumor.com&#x2F;content&#x2F;uploads&#x2F;images&#x2F;November2016&#x2F;modern-software-development-animation.gif" rel="nofollow">http:&#x2F;&#x2F;devhumor.com&#x2F;content&#x2F;uploads&#x2F;images&#x2F;November2016&#x2F;mode...</a><p>Writing code is just the only way to do the above since all attempts at making it less text file driven have failed so far.
charlieflowersover 8 years ago
This is a good article, and the quote in the middle is absolutely amazing -- it belongs up there with some of the most insightful quotes about software ever (and it was not even directly about software).<p>I sum the quote up as, &quot;Systems are sentient beings like the One True Ring, and they will absorb you. Soon, though you believe you are thinking freely, you will actually be merely a part of the System, thinking what it wants you to think.&quot; So true!<p>But ... Taco Bell programming <i>still creates a new system</i>. That&#x27;s a flaw in the article&#x27;s premise.<p>If you solve a problem by stringing together 11 tools, then yes, you should get some benefits from reusing preexisting tools. But now, you have a system with some rube goldberg characteristics, plus you&#x27;ve written a bunch of &quot;glue code&quot; (which is &quot;new code&quot;) in the process.<p>Those systems can often turn out to be more complex.
Const-meover 8 years ago
That only applies to web dev and to a subset of user-mode PC, server and mobile software. While I understand that represents the majority of the software being developed, that article is IMO an incorrect generalization.<p>Some of us do CAD&#x2F;CAM&#x2F;CAE, the proven tools either don’t exist, or are targeted towards companies like Boeing and GM and cost a fortune.<p>Some of us work on console games. The environment is pretty close to the bare metal&#x2F;hypervisor, and typically, there’re significant costs involved in integrating any third-party stuff.<p>Some of us program embedded firmware. Only recently the hardware became fast enough to reuse those proven tools ported from PC, you can’t use those on a PIC16, just not enough resources.<p>That’s just what I personally did&#x2F;doing over my 16 years in the industry. I’m sure there’re other fields where the proposed approach is inapplicable for various reasons.
aswertyover 8 years ago
It&#x27;s pretty amusing when you have to keep repeating to a client that the off-the-shelf tool is better, cheaper, and is immediately available to them. Yet they still argue for the development of a new system. So I don&#x27;t think this push towards custom builds only comes from the developers side of things.<p>And another thing worth pointing out is: most employers hire you to write code. That&#x27;s the job spec. So don&#x27;t be surprised that that&#x27;s what we end up doing.
评论 #12976731 未加载
logicalleeover 8 years ago
Wake me up the next time a 5-line shell script in Bash that uses only standard tools and runs off of any default Debian sells with a license cost of $20 (only) -- you know, for the 5 lines, not anything else -- and anyone pays it.<p>Doesn&#x27;t matter what it does. It is literally impossible to sell even $20 worth of the solution the person advocates. Go ahead: link me to anywhere in the web selling a 5-line bash file without anything else. I&#x27;m waiting.<p>You can do a lot in 5 lines, too. lalalala. waiting. While I wait I think I&#x27;ll make some money coding something people actually pay for. &#x2F;s<p>Seriously though, while the author&#x27;s point might stand in many sys admin and even systems integration roles - most of the software world actually pays for deliverables: the clearest example of which is consumers doing so. People would rather spend 20 hours cursing, and then give up, rather than pay for a systems integration script that generalizes and solves their problem. It&#x27;s what the market <i>demands</i>. This article really would make sense if it came from the person paying -- but it doesn&#x27;t. nobody who is paying actually says the words the article chose for the title. Yes, you are paid to code.
评论 #12978371 未加载
评论 #12978052 未加载
alrsover 8 years ago
I was paid pretty well yesterday to judiciously delete a lot of code, and I had a blast.
评论 #12976547 未加载
bluetwoover 8 years ago
I don&#x27;t know about you, but I&#x27;m paid to solve problems.
评论 #12975031 未加载
评论 #12975418 未加载
评论 #12975455 未加载
golergkaover 8 years ago
You know these occasioanl threads about engineer burnouts we see and post on HN? Well, I actually feel that when you are &quot;burned out&quot; and don&#x27;t feel like writing complex systems is &quot;fun&quot; anymore, you actually become a better engineer - exactly for the reason described in this post.
评论 #12976251 未加载
libeclipseover 8 years ago
I can&#x27;t emphasise how true this is. I&#x27;ve written tonnes of temporary scripts that parse some files or rename some directories, and then later discovered that I could have done it with a single UNIX command.<p>I&#x27;m not employed as a professional software developer, so I still don&#x27;t actually use the helpful UNIX commands. Takes all the fun out of it. :P
评论 #12975701 未加载
hpaavolaover 8 years ago
If you see yourself as a software developer instead of problem solver, you tend to solve all your problems by writing code. In many cases problems can be solved by adjusting processes, improving culture, education or just by learning to use the current tools in more efficient ways.
评论 #12977621 未加载
评论 #12977185 未加载
评论 #12976208 未加载
weegoover 8 years ago
I&#x27;m paid to turn a business requirement into software. I create products. Coding is an unfortunately complex step in that process.
评论 #12975995 未加载
评论 #12976069 未加载
lolcover 8 years ago
Good read. Reminded me of &quot;Why I Strive to be a 0.1x Engineer&quot;<p><a href="http:&#x2F;&#x2F;benjiweber.co.uk&#x2F;blog&#x2F;2016&#x2F;01&#x2F;25&#x2F;why-i-strive-to-be-a-0-1x-engineer&#x2F;" rel="nofollow">http:&#x2F;&#x2F;benjiweber.co.uk&#x2F;blog&#x2F;2016&#x2F;01&#x2F;25&#x2F;why-i-strive-to-be-a...</a>
mynegationover 8 years ago
It is all about efficiency.<p>Can you dig a canal with a tried and true shovel? Yes, you can, but you will need a lot of time and many shovels.<p>Can you cook up bioinformatics analysis in Shell and Awk. Yes, you can, but you if you want a large scale analysis to be done in a reasonable amount of time, you roll up your sleeves and reach for compiled languages, distributed systems and so on.<p>There are downsides in introducing new systems, but it should be weighed against the upside of suitability and efficiency.
评论 #12979114 未加载
评论 #12978810 未加载
评论 #12979153 未加载
Illotusover 8 years ago
I sorta get the idea of the article. Working smart etc. However the incentives in organizations run often counter to that. Gluing together existing pieces to do some grunt work is rarely good for your career. Building new glorious systems is much more likely to do that.<p>Also for orgs that do the developing for other orgs it isn&#x27;t really optimal to offer the quick and efficient solutions unless competitors are doing the same.
Paul_Sover 8 years ago
In my current job I get paid for writing emails, reports and filling out forms. Programming is just something I sneak in when no one&#x27;s watching.<p>The company I work for is super successful so there must be something to it.
khedoros1over 8 years ago
I&#x27;m paid to keep software systems up and resolve issues. Sometimes this means adding, removing, or modifying code. A lot of the time, it just means clicking the right buttons at the right time. Really, I&#x27;m paid to know which of those actions is appropriate in various circumstances, and to get it done when it needs to be.
评论 #12975607 未加载
JoeAltmaierover 8 years ago
Advice for the 99%. Some of us do embedded, where you need an actual driver or app. Can&#x27;t dispatch interrupts in bash.
didibusover 8 years ago
I fail to see the point of the article. What&#x27;s the proposed alternative? To become an admin?<p>I also doubt most people write software from scratch. We use a well proven language, ide, compiler and deployment tool. We use existing libraries, frameworks, databases, caches and services.<p>Why doesn&#x27;t that count as Taco bell programming? When&#x27;s the last time you wrote code for all these things instead of just assembling all of it together?<p>This article is forgetting the lesson learned, highly configurable generic software that doesn&#x27;t need a code change to adapt has actually failed us, and is the source of failure. That&#x27;s why Domain Driven Design was born. Write simple software that target a single domain only. Write one of those for every domain. Do not try to use the same software with multiple tweaks and config hacks for all your domains.
评论 #12979815 未加载
cerrelioover 8 years ago
My current team suffers from disgust of Taco Bell programming. I love it, and I push hard to use it for the projects I lead. I&#x27;ve even had other leads scoff at my use of Python because &quot;the GIL will throttle your application!&quot; Possibly, but I understand the performance requirements of my systems and GIL is the last thing I&#x27;m worrying about. I&#x27;m not going to write my own programming language, or use one that doesn&#x27;t have a good ecosystem, because an existing language is deficient in some negligible aspect.<p>Engineers who build things from scratch do not understand a very profound fact about software engineering: a computer performs menial, repetitive tasks so you don&#x27;t have to. Be lazy and use someone else&#x27;s solution.<p>When I was 14 I remember writing bubble sort from scratch dozens of times, as well as input scrubbing methods and binary search trees. I didn&#x27;t know about the concept of libraries. Granted the internet (sourceforge, github, etc) wasn&#x27;t around and I was writing everything in BASIC or Pascal. By the time I graduated high school I understood that writing code was painful.<p>Consequently, it&#x27;s sometimes alarming that most systems I build rely on thousands of lines of code that I didn&#x27;t write and rarely ever inspect. But I have to trust other developers in order to get my work done in a reasonable amount of time. I don&#x27;t even consider myself a good programmer, mostly because I hate writing code. Nevertheless I do deliver useful, valuable systems. I know my problem has already been solved by someone else. I like being lazy. It&#x27;s my best quality.<p>This isn&#x27;t addressed in the article, but avoidance of Taco Bell programming is a symptom of a disease. The disease is ignorance; mostly in managers who are out of touch with the technical landscape in which their teams work. Any time I hear of a team building their own tools or doing significant amounts of de-novo work, I try to limit my dependencies on that team. You&#x27;re never going to ship that shit, buddy, but I solemnly admire you for trying.
sundvorover 8 years ago
&quot;You may not be paid to write code, but when being hired we&#x27;re going to throw every convoluted or esoteric brain scratching coding test at you for you to pass, which you&#x27;ll then never have to do again. Until you apply for your next job, that is.&quot;
ensiferumover 8 years ago
The Basic premise is true. Every line of code that you write is a liability. Best line of code is the one that you don&#x27;t write. So the corollary is that the less code you use to solve your problem the better.
评论 #12979170 未加载
titzerover 8 years ago
FTA:<p>&gt; Gall’s Fundamental Theorem of Systems is that new systems mean new problems. I think the same can safely be said of code—more code, more problems. <i>Do it without a new system if you can.</i><p>I agree with the basic idea here, yes. But I would have to disagree strongly with the last part.<p>The problem with <i>Do it without a new system if you can</i> is that we need judgment to decide when to make a new system and when not. Sometimes just writing a small piece from scratch instead of using (and repurposing!) a poorly-matched prior system is a hell of a lot simpler.
评论 #12976667 未加载
caffodianover 8 years ago
This is a great post. I think the &quot;paid to write code&quot; is often a byproduct of environment - whether it&#x27;s poor engineering leadership, bad productivity measurement, etc.
bryanrasmussenover 8 years ago
no, but job adverts are written asking for people to write code and often take tests to show they can write code.<p>Resumes and interviews seem to be heavily focused on if yu can write code. And there will be lots of talk about how much code you have written in the past.<p>which I guess is what the article is really railing against - but what it comes down to is in theory you&#x27;re not paid to write code, in practice you are.
ImTalkingover 8 years ago
Agreed. I have always felt that technical people approach their jobs from the wrong side. They cram every technical acronym on the CV in the hope that something will stick. They don&#x27;t understand business. Business wants value. The CV should concentrate on the value created in your past. If it doesn&#x27;t get past the recruiters then the job wasn&#x27;t meant for you anyway. Most techies are programmers who happen to make money at coding, whereas you should be a businessperson who programs; with the difference in attitudes being night&#x2F;day.<p>Some time ago, I went for a architect role at a telco which was the largest Progress shop in the southern hemisphere. The interviewer asked if I knew Progress and I said &quot;No but that is only knowledge&quot; and talked about successful projects and later found out I was hired because of that sentence. But I knew 15 languages at the time so what&#x27;s another language, and sure enough, 3 months later I was reviewing Progress code. You have to convince them to hire you because of your perceived value. I have interviewed a lot and it always cracks-me-up when I ask if they know some technical thing and the job-seeker goes &quot;No, but I&#x27;ve heard of it&quot; meaning they are unwilling to admit that they don&#x27;t know one of the million of technical languages&#x2F;platforms&#x2F;etc. We aren&#x27;t Leonardo daVinci, who was probably the last person on Earth to know pretty much everything. It&#x27;s OK to say No. So say No and explain why that doesn&#x27;t matter.<p>Regarding the tools we use, I agree again. I have used the same DBMS for 15 years. I know it, I feel safe using it, I know what it likes and dislikes. The majority of all my coding is in stored procedures in the DBMS and I don&#x27;t really care what the front-end is, whether it&#x27;s C or some new-fangled hot platform. The lower level your coding the better. Find something that works at a low level and stick with it.
ap22213over 8 years ago
Meta question: do software developers typically enjoy these types of officious, bossy article that state what is and what must &#x2F; must not be done?<p>The tone of these types of posts always make me chuckle. And, I see similar types of articles on here often. When I read these, I feel like Dad is mad at me for being a bad programmer.
评论 #12977152 未加载
评论 #12976403 未加载
评论 #12976976 未加载
mobiuscogover 8 years ago
And people wonder why software quality is going downhill.<p>Of course a Software engineer is paid to write code - if they&#x27;re not, you probably want a different person.<p>Maybe we need a new job title: &quot;Business Value Expander&quot;<p>Requirements: Glue together everything else that&#x27;s already been written by other people, and make the business rich.<p>What could possibly go wrong.
评论 #12976289 未加载
评论 #12976718 未加载
评论 #12976302 未加载
评论 #12978189 未加载
jonkiddyover 8 years ago
I&#x27;m paid to kill jobs. I meet with a group of internal customers to ask&#x2F;watch&#x2F;learn what they do. Then automate the business tasks so that one person can do the job of the entire group more effectively than before. Then provide pretty charts to the managers as they &quot;downsize&quot; their groups.
carapaceover 8 years ago
&quot;Somebody else has had this problem.&quot;<p>(I&#x27;m gearing up to build a big distributed &quot;fabric&quot; and reading the SaltStack docs; it&#x27;s a weird feeling of mixed happiness and disappointment as I discover all the problems they&#x27;ve already solved for me.)
tudorwover 8 years ago
love this, much of my client handling is explaining why they don&#x27;t want what they thought they wanted, how simpler is easier for them and their users, how functionality driven by need is more powerful than grand all inclusive visions and how as I am seeking a long term relationship, we are here to adapt to change, not to implement a &#x27;final solution&#x27;. At the end they more often than not appreciate the honesty and I get the work, when I do the work I&#x27;m not questioned on decisions as often as the trust is there. It&#x27;s a win win scenario.
llodaover 8 years ago
I was in the UK a few months ago for a meeting and they had a plate of sorts in the room with a list of company guidelines. One of them was ‘Everybody sells’.<p>It seems obvious but I&#x27;d never seen it put so starkly.
评论 #12976229 未加载
iLemmingover 8 years ago
Yes, we are paid to write code. The final goal is to create a product, and solve problems, yes. However, as a coder you should think about the code, you have to breath the code, you need to feel the code. Quality of the code should become your obsession. Succinct, nice, readable and reasonable code is more likely to lead to a better product. On the other hand - failing, shitty software, often is a downright result of badly written code.
Ericson2314over 8 years ago
Yes code reuse is important, but most of our current abstractions suck. It&#x27;s good to rewrite old junk so you never need to rewrite it again.
cdevsover 8 years ago
I think I have the opposite issue at my current job as the person in charge wants to put every site, every db, every cron job ,every filesystem on one server and then wonder why we have a io problem...<p>1 instance on aws...sure hope our availability zone stays up next year.
评论 #12977976 未加载
ChuckMcMover 8 years ago
I agree with the insight, the one that says you are trying to solve problems, not write code. But I don&#x27;t think we&#x27;re just mixing the same 8 ingredients.
slantaclausover 8 years ago
It would be nice if he provided a list of unix tools deemed essential knowledge to any programmer. Anyone care to provide a list of their own essentials?
评论 #12977092 未加载
clifanaticover 8 years ago
&gt; You are not paid to write code<p>Well, actually yes, yes I am. You can make a compelling case that this shouldn&#x27;t be the case, or that they people paying me are shooting themselves in the foot running things the way they&#x27;re running things, but the fact remains that in today&#x27;s daily standup&#x2F;weekly status report&#x2F;what have you done for me lately &quot;agile&quot; corporate environment, I am absolutely paid to write code and if I don&#x27;t write code, they&#x27;ll stop paying me.
评论 #12978583 未加载
评论 #12978917 未加载
评论 #12978266 未加载
评论 #12978426 未加载
评论 #12979223 未加载
评论 #12979162 未加载
japanese_donaldover 8 years ago
&quot;We’re not paid to write code, we’re paid to add value (or reduce cost) to the business&quot;<p>I&#x27;m curious to know how many companies Brian has worked for as a software engineer. The majority of the places where I&#x27;ve worked just want you to code. They don&#x27;t really care about adding value and just want the job done as quickly as possible so customers aren&#x27;t upset (usually because the sales team promised a feature that should take 2 months in 2 weeks).<p>It&#x27;s the main reason I quit and started my own company. I was tired of getting into battles with management over the well-being of their own code base and I was tried of being forced to write terrible and hacky code.
评论 #12980462 未加载
sickbeardover 8 years ago
I&#x27;m pretty sure I am paid to write code that solves problems the business needs. What&#x27;s this you&#x27;re not paid to write code meta bullshit?
otabdeveloper1over 8 years ago
&gt; a million other people have probably done the same thing<p>If this were true than 99% of software wouldn&#x27;t be such crap.
评论 #12978512 未加载
gaiusover 8 years ago
Bill Gates said measuring software progress by lines of code is like measuring progress on designing a new aircraft by weight