Monday, November 16, 2009

Google Waves is finally here

Google Waves is finally here!!! Frankly I'm loving it. It's a whole new way of communication. I have attached a screenshot. And it's simple to get an account, just visit http://wave.google.com Look for a request for an invitation section. But here is what I suggest for the devcore members. I would like us all to preview this thing, and test it, and I would like us to be privileged in being among the first people to use this great technology. Du you remember the days when GMAIL was released? Long before GTALK came. Do you remember how back then (back in 2003 or so), you could not apply for a Google account directly but you had to be invited by someone. Well, that same thing is happening. So far I've got about 4 invites left, I am hoping that if I invite four of you guys from devcore, then each one of you will have 8 invitations and you can invite 8 people of your own choice. Just remember to invite those people that are worth inviting. PS - I didnt invite my girlfriend coz she's not really into technology that much so it's a wasted invite, coz she'll probably wait until the whole world is using it to recognize that it's a good thing. It's just like facebook. I mean, who in 2004 knew about facebook. Who among you, by 2006 knew about facebook? It was only after the whole world became crazy about it that we opened our eyes to it. That includes twitter, and God knows some other things out there we don't know because we wait until the geeks tell us that it's great. Guess what? For once, let's be pioneers in this thing. I've checked it out and it looks very awesome. See below a screenshot of this amazing thing in action... For more visit http://wave.google.com

















In the screenshot, that was me, Lawrence Mateveke, and Victor Mudziviri communicating via waves.










Monday, August 31, 2009

Some Crazy Code Not out there, but here within

You won't believe this, but it's true.
I heard from somebody (won't mention his name), that somebody who is a follower on this blog (won't mention the name either) has been busy writing some piece of code, what I consider to be a a great work of code-art. The word is - this dude has written a crawler! You know that thingy don't you guys? That thing that goes around computer networks, crawling on every network computer and gathering information on that computer.

The unnamed source also disclosed that this fellow now has a database with over 9000 records of information on a certain country in a certain continent, all gathered with the 'crawler'.

What I want to know, is what language that crawler was written in? I presuppose it's written in JAVA or Python. And then I want to know the algorithm(s) behind this. That fellow is a genius if you ask me.

It appears after all, that while we were sleeping some great mind has been writing some excellent piece of code.

Or is it this fellow only? What is everybody else working on?

What crazy price of code have you written lately? I read on TKMUNZWA's blog sometime ago about how he wrote some crazy shell script on linux that monitors whether or not a headless computer is connected to the internet 24/7,. I wish to quote it here (the assumption is, if it's on a public blog, i won't be sued for plagiarism). He did it in 2 scripts. The first one below is called checkinternet.sh and the second one is called soundalarm.sh For more information visit http://munzwa.tk/blog/

#!/bin/sh
if eval "ping -c 1 google.com";then
# echo "connected to internet"
killall soundalarm.sh
else
# echo "not connected to internet"
/var/local/soundalarm


#!/bin/sh
while [ 1 ]
do
for F in 1000 1500 2000 2500 3000
do
beep -f $F -l $(($F/50))
done
#sleep 1
done


Some crazy yet very useful piece of code don't you think?

Anyways, before I name the culprit behind the 'crawler' I am giving you a chance to come forward and tell us all about this 'crawler'. Perhaps we might be inspired to come up with crazy code too.

Long live Code, and long live JAVA.

Friday, May 29, 2009

MyGeneration : A Tool you should try

Hey guys! You should try this tool. I find it very useful in many instances, for example you want to generate sql create, insert or alter scripts from a development database to a production database you can use the installed templates to do this in minutes. I often had to write custom sql to create my insert scripts and all that, but the tool works with just about anything. Try it out even the anti microsoft guys will find this useful especially the database templates.Enjoy


MyGeneration is an extremely flexible development tool written in Microsoft .NET. MyGeneration generates code from templates that can be written in C#, VB.NET, JScript, and VBScript. MyGeneration is great at generating ORM architectures or O/R Mapping files for architectures such as Gentle.NET, Opf3, NHibernate, and others. The meta-data from your database is made available to the templates through the MyMeta API. MyGeneration supports Microsoft SQL, Oracle, IBM DB2, MySQL, PostgreSQL, Microsoft Access, FireBird, Interbase, SQLite and VistaDB. MyGeneration can also generate code for non-Microsoft operating systems. MyGeneration installs with many sample templates that generate C# and VB.NET code, Stored Procedures, PHP, HTML and more. If you don't find what you need after installing MyGeneration, checkout our online template library. MyGeneration has a very unique feature that allows you to create your own Graphical User Interface and thereby provide a user interface for your template. Your templates can then capture data through a Windows Graphical interface and copy it to a data structure for use in the actual code generation. Each template has an optional User Interface code section. MyGeneration supports both projects files and a command line interface.

Monday, April 20, 2009

Oracle to buy Sun Microsystems

http://www.sun.com/third-party/global/oracle/index.jsp

SANTA CLARA, Calif., April 20, 2009 -- Sun Microsystems (NASDAQ: JAVA) and Oracle Corporation (NASDAQ: ORCL) announced today they have entered into a definitive agreement under which Oracle will acquire Sun common stock for $9.50 per share in cash. The transaction is valued at approximately $7.4 billion, or $5.6 billion net of Sun's cash and debt.

Guys? What's happening in this world of IT?
I mean seriously, these acquisitions are changing a lot of things.

First it was Sun buying MySQL, now Oracle is buying Sun. 
Makes me wonder, what does the future hold for MySQL? I mean, would Oracle trade continuity of MySQL over enhancement of Oracle DBMS?

I suppose, Bill Gates, and a few others understand what most developers don't. 
I mean, don't you get it? It's all about money. It's all about how to make more money. How that money is made, whether it involves crippling some geek, it doesn't matter.

Tuesday, February 24, 2009

Don't Eat A Person Who Is Working... LOL!!

Five cannibals (Man eaters) get appointed as programmers in an IT company.
During the welcoming ceremony the boss says: "You're all part of our team
now. You can earn good money here, and you can go to the company canteen
for something to eat. So don't trouble the other employees". The cannibals
promise not to trouble the other employees.

Four weeks later the boss returns and says: "You're all working very
hard, and I'm very satisfied with all of you. One of our developers has
disappeared however. Do any of you know what happened to her?" The
cannibals disown all knowledge of the missing developer. After the boss
has left, the leader of the cannibals says to the others: "Which of you
idiots ate the developer?"

One of the cannibals raises his hand hesitantly, to which the leader of
the cannibals says: "You FOOL! For four weeks we've been eating team
leaders, managers, and project managers and no-one has noticed anything,
and now YOU ate one developer and it got noticed. So hereafter please
don't eat a person who is working."

Programming Sucks! Or At Least, It Ought To

Shamelessly ripped from TheDailyWTF article written by Alex Papadimoulis

Programming is not fun. It’s boring, it’s tedious, and it’s certainly not challenging. And no matter how much you stretch it, programming is most definitely not sexy.

I know what you’re thinking. Anyone who says that – let alone blogs it – should immediately be stripped of his software development license, have his keyboard taken away, and be permitted to only use only to CP/M on 8" floppies with a 1200 baud modem.

Obviously, a lot of us – me included – enjoy writing code. But should we?

Why do we write code?

Software development is a unique profession in that we can use our skills both on the job and for our hobby. And unlike accountants, who generally don’t rush home to balance the family budget, many of us actually do tinker with code for fun.

But for the sake of this article, let’s only consider the non-hobbyist developer, and the work that he does. In fact, let’s narrow this down even further, and consider only developers of “boring” software. And by “boring”, I mean bills of lading processing, corporate fleet usage tracking, expense report creating, etc., all for internal use with lots and lots of company-specific requirements. So, to reiterate, if you don’t create “boring” software for a living, then this article doesn’t fully apply.

While the line between “boring” and “sexy” software can be blurred at times, sexy software represents the type of things that we use on a regular, day-to-day basis: SVN, Google Maps, Visual Studio, Firefox, etc. In fact, as software developers, we rarely have to use boring software ourselves.

From a development perspective, however, the percentages are flipped. Only a select few get paid to develop “sexy” software, whereas most of us are stuck developing the boring stuff.

Basics of Boring Software

There’s a term for this type of boring software: information systems. And while the purpose of an information system changes from company to company, as do the specific requirements, they all are essentially the same. There’s a database that models the real world, rules to define how the data may be changed, an interface to the database, and lots of different reports.

The formal process of creating these information systems was first created in the sixties and hasn’t changed much since the seventies (Modern Structured Analysis is surprisingly still modern). Essentially, you analyze the problem, map the dataflow, structure the dataflow, create the database, and create programs that interface with the database.

We’ve gone from thin-client green screen terminals to thick-client PC applications. Then we went to the thin-client web and, with platforms like Windows Presentation Foundation, we’ll be back to thick-client in no time. But either way, the systems do all the same thing: data in, data out.

Developing information systems hasn’t changed much, either. Whether you’re using Visual Basic 3.0 or XHTML, the concepts are pretty much the same: the database needs to be exposed to the user in user-friendly terms. The code required to do this is, and always has been, fairly tedious:

txtFirstName.DisplayWidth = 30;
txtFirstName.MaxCharLength = 50;
SetTextBoxValidator(txtFirstName, Validations.LettersOnly);
txtFirstName.Enabled = securityContext.CanEdit;
txtFirstName.Value = customerRecord.FirstName;

That’s five lines of code just to set some UI properties. Multiply that for every field, for every entity, and then by 1.5, just because some fields have to be accessible in two different places. Now add in all the code required to validate and save data from the UI. If my math serves me right, that adds up to a crapton of tedious, boring code.

The Developer’s Dilemma.

“Tedious” and “boring” are two words that don’t sit well with developers. We’re an analytical bunch and oftentimes come with a computer science degree. And we’re much more capable than tying a front-end and a back-end together using line after line of code. Perhaps we could even use our skills and capabilities to make our job easier.

And therein lies the rub. As Michael A. Jackson said in his 1975 Principles of Program Design, “Programmers… often take refuge in an understandable, but disastrous, inclination towards complexity and ingenuity in their work. Forbidden to design anything larger than a program, they respond by making that program intricate enough to challenge their professional skill.”

This thirty-five year-old observation is confirmed day-in and day-out here on TDWTF. Some of the most egregious code and stories written here stem from the developer’s desire for cleverness. Carrying out these desires is neither malicious nor devious, but merely instinctual.

When I wrote about Soft Coding, I presented a snippet of business code to illustrate what the majority of code should look like: i.e., very specific code to implement very specific business requirements. It’s pretty boring:

private void attachSupplementalDocuments()
{
if (stateCode == "AZ" || stateCode == "TX") {
//SR008-04X/I are always required in these states
attachDocument("SR008-04X");
attachDocument("SR008-04XI");
}
if (ledgerAmnt >= 500000) {
//Ledger of 500K or more requires AUTHLDG-1A
attachDocument("AUTHLDG-1A");
}
if (coInsuredCount >= 5 && orgStatusCode != "CORP") {
//Non-CORP orgs with 5 or more co-ins require AUTHCNS-1A
attachDocument("AUTHCNS-1A");
}
}

In the numerous responses to the article, some people offered some rather humorous feedback, demonstrating ways that the code could be “complexified”. These examples were, sadly, fairly representative of what I’ve actually come across in response to simple business requirements.

Others offered some serious refactoring suggestions involving all sorts of design patterns, interfaces, supplementers, and a whole lot of classes. Naturally, all without ever seeing the module that the hypothetical code resided in, let alone a broad understanding of the overall system and its requirements.

And then there was this one guy, James Taylor, who basically called me an idiot for suggesting that developers get their hands dirty with business rules. Apparently, we should all be building whiz-bang expert systems with fancy UIs that let the end user do all of the dirty work.

Of course, those of us ground in reality understand that such expert systems exist only in the land of pixie dust, unicorns, and lossless compression of random data. But there’s another reality that many of us have yet to accept: application development sucks, and no amount of XML or design patterns will change this.

Just Suck It Up.

It’s not easy to reconcile the fact that the software we write each and every day is, for all intents and purposes, mind-numbingly boring. Magazine subscription management. Medical billing reports. Realty inventory management. This is not the type of software that changes the world. In fact, it probably won’t even put a smile on someone’s face. Its sole purpose is to add to the bottom line by making other workers be more productive.

As unexciting as it may be, it’s our job to do work *exclusively* to benefit our employer, not for own personal satisfaction. That’s just what it means to be a professional.

I’m sure that many aspiring lawyers would jump at the chance for an exciting jury trial, but would just as quickly give it up if it was in his client’s best interest to settle. While architects dream of opportunities like Fallingwater, if the design calls for a large warehouse with loading docks, then that’s all the blueprints will reflect. And if our employer needs software to manage voucher payments, then they should get exactly that, not a “plug-in based system with extensible, run-time parsed UI templates,” or whatever else we tricked ourselves in believing was necessary.

Rethinking Software Development.

As frustrating as it can be to work with the uninspired, sloppy developer, the contrary – the inspired-yet-misguided one – is several magnitudes worse. A few bugs and painful-to-maintain code pale in comparison to the disastrous results an improperly motivated developer can deliver.

Everything from the platform (“let’s try out Ruby!”) to the architecture (“can’t just have two tiers”) to the techniques used in the code itself (“we need an aspect-oriented framework”) can be – and often are – influenced more by the desire to learn the technology than to serve the actual business need. Pick the wrong platform or invent the wrong technique, and the project is inevitably doomed.

Having doomed more than one project as a result of my desire to challenge myself, I’ve come to learn that there are some essential rules that must be followed when developing business information systems.

1. Learn the Business. It’s preposterous to believe that you don’t need to understand the business in order to develop software for the business. Without understanding what their actual needs are, it’s impossible to give stakeholders what they actually need. That’s right: when they say they want a “new database for every day”, they don’t actually mean a new database for every day.

2. Serve the Business. Every tradesman wants to use the latest, greatest, and most powerful tools, but rarely are they appropriate for the job. Likewise, there’s hardly ever a business case to immediately upgrade all platforms/libraries/languages. That 10-year old “Classic ASP” code hasn’t gotten worn out, just much less fun to maintain.

3. Learn Off The Job. Self-improvement is a tenet of every profession, but the place to do that is “off the job,” i.e. not while developing information systems1. Instead, learn by creating applications for yourself, your team, or perhaps even some open source project.

4. Code mostly Business. If the overwhelming majority of your hand-written code isn’t domain-specific and doesn’t relate to the application’s purpose, then you’re using the wrong tools. If you truly believe that the system needs a custom logging framework, then externalize it and get a buy-in from the stakeholder.

5. Tedium is Inescapable. No O/R-mapper or code-generator can ever solve the fact that records, fields, validators, etc. need to be defined, by hand, in at least two places (front- and back-end). A UI generated from the database is just as bad as the database that’s generated from the UI.

6. Find Satisfaction Elsewhere. If your only satisfaction comes from writing complex code, then you’ll never be a good and satisfied applications developer. Personally, I’m happy to know that I helped increased productivity for the end-user and/or created new opportunity for the organization.

... and, if all else fails...

7. Get Another Job. Maybe you’ve reached your value apex. Or maybe you’re just sick this type of development altogether. Either way, there are plenty of programming opportunities out there that don’t involve boring, information systems. Of course, the competition is much fiercer since the Paula Bean-types seem to only fly under Corporate IT's radar.

At the end of the day, the best programmers are not the ones who create the most beautifully-elegant, exceedingly-innovative code. The true rockstars can deliver software before deadlines, under budget, and that does exactly what the business needs. And those are the type we should all strive to be.

UPDATE: 1 To clarify, “off the job” does not mean that you should’t learn at work. Learning is important, but don’t do so while developing an information system for the stakeholder (“on the job”). Save that for your own or your team’s internal projects.

Monday, February 23, 2009

Be careful

You've Gotta Love CodeSqueeze!!!
Here's Another Article I picked up...

I have been going through a lot of self reflection as of late, and as you can imagine there are a number of things that haunt my current psyche.

One of these such things is coming to the realization of just how special I thought I was as a college graduate. After all, I had shed the skin of the cocky teenager and had a true grasp of who I was and what I was capable of. I had degrees. I worked at Microsoft. Martin Fowler look out - there’s a new guy in town…

Although I can say (with little ego) that I did have a lot going for me, and I had accomplished a lot - I knew little to nothing about the real world.

You see, college never allowed me to learn through failure. As Alan Watts below puts it, I was placed in this “nursery society” where I was allowed to believe that real life was about pretending, having fun, and no matter what things will be alright.

Translating that into software development, I never had to write programs that lasted more than the next weekly project. As a result, my solutions were short sited, problematic, and all-round crap. But I didn’t need to care, as long as the teacher did not find that one little bug I swept under the rug or care about code maintainability or the fact that there were no tests - after all, it’s always a sunny day in Disneyland.

In a sense, college wired my habits to approach solutions wrong. I went to college to grow into an adult, and came out an over confident child.

Recent graduates and veteran developers alike take heed - we all have a lot to learn about our profession and even more about ourselves. Never allow your confidence to block your ability to learn from the mistakes of yourself and others. After all, we all graduated from the University of Mickey.

For the true significance of Disneyland is that it reflects our notions of children - what they are, what is good for them, and what will please them. Children are a special class of human beings which came into existence with the industrial revolution, at which time we began to invent a closed world for them, a nursery society, wherein their participation in adult life could be delayed increasingly - to keep them off the labor market. Children are, in fact, small adults who want to take part in the adult world as quickly as possible, and to learn by doing. But in the closed nursery society they are supposed to learn by pretending, for which insult to their feelings and intelligence they are propitiated with toys and hypnotized with baby talk. They are thus beguiled into the fantasy of that happy, carefree childhood with its long sunny days through which one may go on “playing” - in the peculiar sense of not working - for always and always. - Alan Watts, Does It Matter?: Essays on Man’s Relation to Materiality

Tuesday, January 13, 2009

When a developer looks for another job.. LOL!!

Something I picked on www.codesqueeze.com . 

Very very helpful

In this fast paced and economically burdened society, it is only natural for the majority of us to ask ourselves how can we fortify our careers. Do we solidify our current positions? Or should we diversify our experience and resume?

A number of people have asked me this question lately all with the same concerns - they feel their current skill set does not provide them with all the job opportunities they need in order to feel comfortable.

The truth is it is completely possible to land a job without knowing anything at all about the technology or domain for which you are applying for. The only thing you need to prove is your ability to quickly learn and adapt (however, I hope that it is obvious that the less you know the more convincing you will have to be).

Many people are fearful of even applying for positions where they do not meet (or exceed) the requirements of the job description. Pffft I say.

Remember in Star Wars how C-3PO talked himself into the graces of Uncle Owen?

Uncle Owen: You, I suppose you’re programmed for etiquette and protocol.
C-3PO: Protocol? Why, it’s my primary function, sir. I am well-versed in all the customs–
Uncle Owen: I have no need for a protocol droid.
C-3PO: Of course you haven’t, sir. Not in an environment such as this. That is why I have been programmed in–
Uncle Owen: What I really need is a droid who understands the binary language of moisture vaporators.
C-3PO: Vaporators? Sir, my first job was programing binary load lifters very similar to your vaporators in most respects.”
Uncle Owen: Can you speak Bocce?
C-3PO: Of course I can, sir. It’s like a second language to me. I’m a–
Uncle Owen: yeah, alright. Shut up. I’ll take this one.
C-3PO: Shutting up, sir.

There are three simple rules to remember. Master these and you will never be scared of unemployment again.

1. You will never fit the job description 100%

Don’t even get me started on this topic because for some stupid reason employers ask for job skills that even most astronauts don’t possess. Getting hung up in the fact that you don’t fully qualify all the skills is the first stumbling block.

Even if you aren’t their picture perfect candidate, you might be the best for the job out of everyone that applied.

2. Find and flaunt parallel skills

C-3PO didn’t know binary vaporators, but he did know binary load lifters. Don’t know Java? The last 4 years of C# just might be enough to prove you understand it enough.

You would be amazed at how many parallel skills you can draw with what skills are being asked. Really ask yourself, are they asking for an Exchange Server expert or are they asking if I am a capable email administrator that can handle an Exchange server?

3. Shut up

When they decide they like you - shut up. Don’t give up any more information than you need to as it will only hurt you. Just like C-3PO, you might find yourself getting jettisoned if you ramble on.


It is always better to gain new experience and skills; however, do not worry about lacking the knowledge of everything the universe has to offer. Proving that you know how to learn, unlearn, and relearn is the greatest thing you can offer an employer.

Monday, January 5, 2009

Now is the time for action..

Compliments of the new season guys. I trust tese takapinda nemufaro nenyasha.

I have been thinking (for a long time now) why we havent put a name for ourselves when we are such good developers. I know we are all busy with work items but i believe this is the year big things should happen in our programming lives, unless i am an optimists. (Optimist: glass is half full ; Persimist: glass is half empty).

To start with i would want to pose a question to everyone on this forum. What did we do last year that was not part of your work? I know some got married, congrats, but when it comes to programming, did we archieve anything or we are letting those Java/PhP/Postgres skills rot in the back of our mind. It pains me to realise all those bright ideas and dreams i once envied at College have suddenly gone to the bin!

To cut my story short i will challenge you guys to come up with something for this year and the future. I am not thinking of something commercial but, if possible lets take it up. I am sure almost everyone has something at his work place that they wish could be automated to save a lot of effort and time. I know within this forum we have people who know java/php/asp/c#/vb/j#/jsp/python and almost all databases. So i am saying guys lets come up with a sort of a "Open Source" Project(s). This is our time and lets make use of it.

Let me hear what others think.