So, earlier I had said that I wasn't really interested in going to the W3C Web of Services Workshop. It ended up that someone else couldn't go, and since I was curious to hear reactions to some of the stuff being presented on day 2, I decided to go ahead and go.
I'm glad I went. There was a lot of good and interesting discussion. I don't think any of the world's problems were solved and I don't think anybody changed their minds about Web Services - although there did seem to be a lot of agreement that REST is good and worth investing time in.
One of the recurring topics was the uniform interface - it seems some people get it and others don't. It always seem to end up in an argument about dispatching - either you do it at the operation level or you do it at the message type level. If I define operations, they're strongly typed and I know exactly what kind of data I'll be getting. If I only have one operation that has to handle different kinds of data, then how do I know what to do with the data - I have to write a big if-statement to figure out how to handle the data. How is that an improvement? Arent you just pushing the dispatching to a different place?
And that's the wrong thing to focus on. I stumbled on this as I was trying to explain to my very dyed-in-the-wool WS-* coworker why the uniform interface is useful. I finally made progress with the following.
Imagine I have a printer with an embedded web server. The printer makes available a web service with associated WSDL that define an operation called getPrinterStatus, and that operation returns an xml document of a type we'll just call DeviceInfo. If I'm writing a client to retrieve the printer's status, I pull in the WSDL generate the stub code and fill in the business logic. Now I can monitor the status of the printer.
Now imagine that some time later, I purchase a copy machine. This copier also has an embedded web server and makes available a web service. The web service has a number of operations, but one of them is getDeviceInfo, and that operation also happens to return an xml document that has the same format as what the printer returns - DeviceInfo.
If I now want my printer monitor client to also be able to monitor my copier, I have to modify the client's code - I have to pull in the copier's WSDL, generate the stubs for its operations and then I can get the DeviceInfo document for the copier.
Now back up and imagine that each of those devices had used HTTP GET in a RESTful way. Because my printer monitor client knows how to handle documents of type DeviceInfo, all I have to do is tell it what the appropriate URI is for each of my devices - I don't have to change any software. Now, instead of only being able to interact with my printer, my client software can interact with any resource that produces DeviceInfo documents in response to a HTTP GET. For free.
I could hear the light bulb click on.
28 February 2007
06 February 2007
Hot vs Cold
Every winter, there are people who say they'd rather be too hot than too cold. And every summer, there are people who say they'd rather be too cold than too hot. And I'm pretty sure that some of those people say different things depending on the season.
Right now, I know I'd rather be too hot than too cold. Problem is, I'm concerned that I might have a seasonal opinion - but I really can't remember what I thought when it was actually hot out. I'm pretty certain I face this same dilemma every year, and probably twice a year (but I can't remember for sure).
So this year, I'm going to do something about it - I'm writing down my winter-time position on the hot vs cold debate: I prefer heat to cold.
Now, I just have to remember to check back when it's really hot out.
Right now, I know I'd rather be too hot than too cold. Problem is, I'm concerned that I might have a seasonal opinion - but I really can't remember what I thought when it was actually hot out. I'm pretty certain I face this same dilemma every year, and probably twice a year (but I can't remember for sure).
So this year, I'm going to do something about it - I'm writing down my winter-time position on the hot vs cold debate: I prefer heat to cold.
Now, I just have to remember to check back when it's really hot out.
28 January 2007
Catching Up
So much for practicing writing - well, at least not here. I have, however, been doing quite a bit of writing at work lately, some of which is the basis for this position paper for the W3C Workshop on Web of Services for Enterprise Computing. If I'm lucky, maybe I'll finally get to meet fellow RESTafarian Mark Baker who's also presenting something.
Although I contributed to the position paper (somewhat unwittingly), at this point I'm not sure I'm looking forward to going to the workshop. In fact, if you'd asked me before our paper was submitted whether I was interested in attending such a workshop, my response would have been something along the lines of "why would I want to work to improve something (WS-*) that I'd prefer to see fade away?"
The project I'm on now is a research-oriented project for a military customer where we're looking at SOA, ESBs and Web Services (among other things). In a nutshell, we're supposed to help our customer figure out whether or not this SOA stuff and its corresponding technologies (which in their eyes is WS-*) will actually work and be useful for their purposes. The downside is that I'm working with stuff that I don't really believe in (the WS-* part, not the SOA part). The upside is that I have the opportunity to point out the failings as I see them (and the customer actually seems willing to listen).
Our team pretty much covers the spectrum from WS-* on one end to REST on the other (that's me), so we occasionally have some spirited debates.
For the last few months, we've been looking at service discovery, trying to really focus in on what service discovery is and why you might need it. You see, the military is in the midst of an effort to get themselves some SOA goodness and they're cranking out the architectural guidelines and building themselves some infrastructure to support all these new services that'll be part of their SOA. One piece of that infrastructure is discovery.
Apparently, there's some debate as to what discovery is. If you ask one group (apparently the majority), they claim it means content discovery - being able to discover information (i.e., search) - and that if you squint the right way, services are just information sources whose output can be treated as content. However, there's another group that believes there's a fundamental distinction between services and content and that the two require different approaches for discovery.
So we've been looking at service discovery and asking lots of questions - like what's the difference between design-time and run-time discovery, and is there really a need for such a thing? It's been kind of frustrating, because any time we talk to people about it, they either just point to UDDI, or they start talking about all the cools things you could do if you could discover arbitrary services at runtime. Unfortunately, there are never any real details as to how any of this would actually work. And worse, when we ask for real-world scenarios where this would be useful, we either get more hand-waving, or something that would require a whole lot more AI than the industry's currently able to muster.
We've managed to make some progress - to the point where I've managed to formulate a somewhat coherent picture of service discovery in my head; and over the last month, I've tried to put some of it on paper. Mind you, none of it's earth-shattering; just a healthy dose of reasoning about the needs of design-time discovery and run-time discovery and some thoughts about the sort of environment in which run-time discovery would actually make sense.
One conclusion we've drawn is that (assuming run-time discovery is actually a useful thing), what's currently out there in terms of tools, technologies, and specifications probably isn't sufficient - especially not in the military world. Problem is, at this point, I have no idea what would be needed. My esteemed colleague (author of our position paper, and solidly in the WS-* camp) has decided this gap should be addressed by the W3C - and thus the position paper. Me - I'm not so sure. I'm not even convinced there's a real need for run-time discovery - at least not as an infrastructure service.
Thus, my conundrum - I may have make a case for something I'm not even sure is a problem, and I have to do it at a workshop that I'd otherwise have no interest in. Oh well, if I do go, at least I'll finally get to meet a bunch of cool people - like Mark, Noah and Dave - whose writings I've followed in such august places as the W3C TAG mailing list or the REST-discuss group.
(Let's see if I can do another one of these without waiting another two years.)
Although I contributed to the position paper (somewhat unwittingly), at this point I'm not sure I'm looking forward to going to the workshop. In fact, if you'd asked me before our paper was submitted whether I was interested in attending such a workshop, my response would have been something along the lines of "why would I want to work to improve something (WS-*) that I'd prefer to see fade away?"
The project I'm on now is a research-oriented project for a military customer where we're looking at SOA, ESBs and Web Services (among other things). In a nutshell, we're supposed to help our customer figure out whether or not this SOA stuff and its corresponding technologies (which in their eyes is WS-*) will actually work and be useful for their purposes. The downside is that I'm working with stuff that I don't really believe in (the WS-* part, not the SOA part). The upside is that I have the opportunity to point out the failings as I see them (and the customer actually seems willing to listen).
Our team pretty much covers the spectrum from WS-* on one end to REST on the other (that's me), so we occasionally have some spirited debates.
For the last few months, we've been looking at service discovery, trying to really focus in on what service discovery is and why you might need it. You see, the military is in the midst of an effort to get themselves some SOA goodness and they're cranking out the architectural guidelines and building themselves some infrastructure to support all these new services that'll be part of their SOA. One piece of that infrastructure is discovery.
Apparently, there's some debate as to what discovery is. If you ask one group (apparently the majority), they claim it means content discovery - being able to discover information (i.e., search) - and that if you squint the right way, services are just information sources whose output can be treated as content. However, there's another group that believes there's a fundamental distinction between services and content and that the two require different approaches for discovery.
So we've been looking at service discovery and asking lots of questions - like what's the difference between design-time and run-time discovery, and is there really a need for such a thing? It's been kind of frustrating, because any time we talk to people about it, they either just point to UDDI, or they start talking about all the cools things you could do if you could discover arbitrary services at runtime. Unfortunately, there are never any real details as to how any of this would actually work. And worse, when we ask for real-world scenarios where this would be useful, we either get more hand-waving, or something that would require a whole lot more AI than the industry's currently able to muster.
We've managed to make some progress - to the point where I've managed to formulate a somewhat coherent picture of service discovery in my head; and over the last month, I've tried to put some of it on paper. Mind you, none of it's earth-shattering; just a healthy dose of reasoning about the needs of design-time discovery and run-time discovery and some thoughts about the sort of environment in which run-time discovery would actually make sense.
One conclusion we've drawn is that (assuming run-time discovery is actually a useful thing), what's currently out there in terms of tools, technologies, and specifications probably isn't sufficient - especially not in the military world. Problem is, at this point, I have no idea what would be needed. My esteemed colleague (author of our position paper, and solidly in the WS-* camp) has decided this gap should be addressed by the W3C - and thus the position paper. Me - I'm not so sure. I'm not even convinced there's a real need for run-time discovery - at least not as an infrastructure service.
Thus, my conundrum - I may have make a case for something I'm not even sure is a problem, and I have to do it at a workshop that I'd otherwise have no interest in. Oh well, if I do go, at least I'll finally get to meet a bunch of cool people - like Mark, Noah and Dave - whose writings I've followed in such august places as the W3C TAG mailing list or the REST-discuss group.
(Let's see if I can do another one of these without waiting another two years.)
20 April 2005
Respresentational State
I was just reading a page on RESTWiki about HowSoapComparesToRest. Despite the title, about half the page is devoted to a discussion of what the State in REpresentational State Transfer is.
Reading through that discussion and seeing people trying to get a handle on what resource's state is transferred when you do a POST to certain kinds of resources or the fact that you might transfer the state of a resource that has no name, I suddenly had the thought that its not so important to know what state is -- its what it's not that's important. In fact, its really not so much about the state at all -- its about the representation. In a RESTful system, (in a very general sense) you dont move objects (resources) around, you move facsimiles (representations) of those objects (resources) around.
Why is this important? I'm not sure I know at this point. I just know that after several years of thinking and reading about REST, this is the first time I've thought about it this way.
Reading through that discussion and seeing people trying to get a handle on what resource's state is transferred when you do a POST to certain kinds of resources or the fact that you might transfer the state of a resource that has no name, I suddenly had the thought that its not so important to know what state is -- its what it's not that's important. In fact, its really not so much about the state at all -- its about the representation. In a RESTful system, (in a very general sense) you dont move objects (resources) around, you move facsimiles (representations) of those objects (resources) around.
Why is this important? I'm not sure I know at this point. I just know that after several years of thinking and reading about REST, this is the first time I've thought about it this way.
04 April 2005
REST v WS-*: Compare and contrast
I've been spending a lot of time looking for information that compares and/or contrasts WS-* with REST. As I go, I've been accumulating links here and there, saving them in various places (bookmarks in my browser, on the desktop, and at bloglines), but this weekend, I decided that it was about time I got with the program and availed myself of the services offered at del.icio.us. Once I'd gotten an account set up and had moved over all my bookmarks I had lying around in varoius places, I spent a good deal of time Sunday perusing a few email threads over on the ws-arch mail archives and a few more over in the xml-dev archives.
As I find things that appear to be of the REST vs. WS-* ilk, I'll add them to the restvsoap tag that I set up on del.icio.us. I'm hoping that at least a few other people notice the tag and are able to add some useful pointers as well. I'll try to limit myself to using the restvsoap tag only for things that have useful comparisons rather than just being flame-fests; hopefully others will do the same.
As I find things that appear to be of the REST vs. WS-* ilk, I'll add them to the restvsoap tag that I set up on del.icio.us. I'm hoping that at least a few other people notice the tag and are able to add some useful pointers as well. I'll try to limit myself to using the restvsoap tag only for things that have useful comparisons rather than just being flame-fests; hopefully others will do the same.
28 March 2005
Parallel Universe
I've reached the chapter that talks about WS-Addressing and the WS-Resource Framework (chapter 8 in Building Web Services with Java). Apart from having a hard time getting my ahead around the authors' concepts of stateful and stateless resources, I couldn't help but feel like I was traveling through a parallel universe. I was left with the impression that the whole WS-Resource framework is an attempt to duplicate what we already have in the existing web - but crammed inside of the WS-* world and using none of the existing mechanics already available. It's as if their charter was to reinvent the web without using any of the existing technologies - and to make sure it doesnt interoperate with the existing web.
I've also noticed that as I've been reading I keep finding myself wishing that some of the things in WS-* could be extracted and applied to a more RESTful environment. In particular, I keep wondering whether having something like WSDL would be useful.
Let's say that I have a real estate 'application' that deals with real estate listings. A listing resource has state that includes things like an address, a listing agent, a homeowner, a description, a listing status and a unique identifier. In order for client software to effectively use my 'application', I need to be able to define how the client can interact with resources of this type (e.g., listing resources). It seems to me that in order to construct a client that can interact with a particular type of resource, I need to know the following things:
I'm pretty sure that the first and last items are reasonable things to want. Its the middle one that I'm not so sure of. I can't help but think that I'm effectively trying to define new operations that can be performed on a resource, and that would seem to violate the constrained interface.
I did look at RDF Forms, but I'm not sure whether that's what I want or not. It seems like something is missing, but maybe I'm just making it more complicated than it needs to be
I've also noticed that as I've been reading I keep finding myself wishing that some of the things in WS-* could be extracted and applied to a more RESTful environment. In particular, I keep wondering whether having something like WSDL would be useful.
Let's say that I have a real estate 'application' that deals with real estate listings. A listing resource has state that includes things like an address, a listing agent, a homeowner, a description, a listing status and a unique identifier. In order for client software to effectively use my 'application', I need to be able to define how the client can interact with resources of this type (e.g., listing resources). It seems to me that in order to construct a client that can interact with a particular type of resource, I need to know the following things:
- the resource's state or data model; i.e., what elements make up a listing resource's state (I guess this would essentially be a type definition)
- a list of valid transformations that can be applied to a listing resource; i.e., what parts of the resource's state can I change, and how do I go about effecting those changes
- a definition of valid values for the various parts of the resource's state (maybe this is really part of the data model)
I'm pretty sure that the first and last items are reasonable things to want. Its the middle one that I'm not so sure of. I can't help but think that I'm effectively trying to define new operations that can be performed on a resource, and that would seem to violate the constrained interface.
I did look at RDF Forms, but I'm not sure whether that's what I want or not. It seems like something is missing, but maybe I'm just making it more complicated than it needs to be
25 March 2005
SOAP Transport Independence
More thoughts while reading...
I keep thinking about SOAP's use of HTTP as a transport protocol and the fact that SOAP is supposed to be transport independent so you can make use of existing protocols like SMTP or FTP or whatever. I gues my question at this point is why?
Why would I want to use SMTP instead of HTTP? What does that buy me? OK, so I dont need a web server to service requests - I can just float stuff through email. But now I need to write some new sort of server that can poll the service's 'inbox' and process the messages that it finds there. So not only do I still need some sort of server, but now I've got to write my own when I could have just used already existing and readily available web server software.
As to the question of why HTTP is the preferred protocol, I suppose I can see why that's the case. There's already lots of well tested HTTP client and server software out there, so its real easy to use. And just about everybody lets HTTP through the firewall. But isn't that really just a port number? I could run any protocol on port 80 and it would still make it through just about as many firewalls.
Well, back to reading. Maybe the answers will eventually become clear to me, but it just feels like the whole protocol independence thing and the use of HTTP has made things much more complicated than they need to be.
I keep thinking about SOAP's use of HTTP as a transport protocol and the fact that SOAP is supposed to be transport independent so you can make use of existing protocols like SMTP or FTP or whatever. I gues my question at this point is why?
Why would I want to use SMTP instead of HTTP? What does that buy me? OK, so I dont need a web server to service requests - I can just float stuff through email. But now I need to write some new sort of server that can poll the service's 'inbox' and process the messages that it finds there. So not only do I still need some sort of server, but now I've got to write my own when I could have just used already existing and readily available web server software.
As to the question of why HTTP is the preferred protocol, I suppose I can see why that's the case. There's already lots of well tested HTTP client and server software out there, so its real easy to use. And just about everybody lets HTTP through the firewall. But isn't that really just a port number? I could run any protocol on port 80 and it would still make it through just about as many firewalls.
Well, back to reading. Maybe the answers will eventually become clear to me, but it just feels like the whole protocol independence thing and the use of HTTP has made things much more complicated than they need to be.
SOAP. SOAP. What is SOAP?
Since I've got some free time on my hands (while I look for a new job), I decided it'd be a good idea to get caught up on current technology - and first up is SOAP/SOA/WS-*, etc.
I've actually used SOAP and Axis on a couple of projects now, but only in a sort of peripheral manner. In fact, in both cases, the presence of a web service interface was more related to marketing than actual customer demand (you know - "let's put a web service interface on so we can say our product supports SOAP"). And since the web services part wasn't part of the core architecture, I've never spent much time really investigating and trying to understand the why's and wherefore's of SOAP and Web Services.
So, last week, I went out and picked up the dead tree version of Building Web Services with Java. (I had hoped to find something on O'Reilly's Safari Bookshelf since I do have a subscription, but it seemed like everything there was at least two years old.)
Berfore I go on, I should point out that I've been a pretty strong believer in the REST architectural style and, over the past three or four years, I've made a pretty concerted effort to adhere to those principles in the solutions I've designed and built. I'm very much aware that there's a sort of SOAP/WS-* vs REST mentality out there right now, but I really dont know enough about SOAP and WS-* to know where I might fall in that debate. At this point, from what I've read so far I have what you might call a healthy skepticism for SOAP and WS-*.
So far, and for the most part, I like the book. Despite the fact that the authors seem to think Web Services are the greatest thing since sliced bread, they do manage to take you through all the pieces that are involved - XML, SOAP, Web Services - and they bring up just enough of the issues that Web Services are trying to address to make you think a little bit. There are a few sidebars that compare to REST and WS-*, but they're pretty superficial and it seems like they're only there to make the presentation look balanced.
So far, there haven't been any surprises. I've either heard of or have actually used most of the technologies they've covered - XML and XML Schema, SOAP, WSDL, UDDI, Axis, etc. However, I can't help but to keep asking myself "What happened to the web in Web Services?"
Two things strike me. One is that, despite the use of URIs for just about everything that needs a name, almost none of them actually identify a resource that's on the web. The only thing that even comes close is the service endpoint, and that's barely on the web since all of the useful stuff is hidden behind the service.
The other thing that bugs me is the use of HTTP is a transport protocol. Other than the fact that HTTP flows freely through firewalls, what's the point? Only one verb, POST, is ever used (although I do see that you can now do certain operations using GET as well). I keep asking myself why they didn't just come up with the SOAP Message Transfer Protocol. Well, OK, the acronym for that might cause just a little confusion, but still. Maybe I just need to read more and I'll understand.
(In case you're wondering, the title is a reference to a bit from a Sponge Bob Squarepants episode.)
I've actually used SOAP and Axis on a couple of projects now, but only in a sort of peripheral manner. In fact, in both cases, the presence of a web service interface was more related to marketing than actual customer demand (you know - "let's put a web service interface on so we can say our product supports SOAP"). And since the web services part wasn't part of the core architecture, I've never spent much time really investigating and trying to understand the why's and wherefore's of SOAP and Web Services.
So, last week, I went out and picked up the dead tree version of Building Web Services with Java. (I had hoped to find something on O'Reilly's Safari Bookshelf since I do have a subscription, but it seemed like everything there was at least two years old.)
Berfore I go on, I should point out that I've been a pretty strong believer in the REST architectural style and, over the past three or four years, I've made a pretty concerted effort to adhere to those principles in the solutions I've designed and built. I'm very much aware that there's a sort of SOAP/WS-* vs REST mentality out there right now, but I really dont know enough about SOAP and WS-* to know where I might fall in that debate. At this point, from what I've read so far I have what you might call a healthy skepticism for SOAP and WS-*.
So far, and for the most part, I like the book. Despite the fact that the authors seem to think Web Services are the greatest thing since sliced bread, they do manage to take you through all the pieces that are involved - XML, SOAP, Web Services - and they bring up just enough of the issues that Web Services are trying to address to make you think a little bit. There are a few sidebars that compare to REST and WS-*, but they're pretty superficial and it seems like they're only there to make the presentation look balanced.
So far, there haven't been any surprises. I've either heard of or have actually used most of the technologies they've covered - XML and XML Schema, SOAP, WSDL, UDDI, Axis, etc. However, I can't help but to keep asking myself "What happened to the web in Web Services?"
Two things strike me. One is that, despite the use of URIs for just about everything that needs a name, almost none of them actually identify a resource that's on the web. The only thing that even comes close is the service endpoint, and that's barely on the web since all of the useful stuff is hidden behind the service.
The other thing that bugs me is the use of HTTP is a transport protocol. Other than the fact that HTTP flows freely through firewalls, what's the point? Only one verb, POST, is ever used (although I do see that you can now do certain operations using GET as well). I keep asking myself why they didn't just come up with the SOAP Message Transfer Protocol. Well, OK, the acronym for that might cause just a little confusion, but still. Maybe I just need to read more and I'll understand.
(In case you're wondering, the title is a reference to a bit from a Sponge Bob Squarepants episode.)
22 March 2005
Hello
So, I've finally set up my own blog. (Cue sound of crickets chirping.)
I've been thinking about doing this for a while, but I've never really been motivated enough to actually do anything. I've come real close a number of times over the past few months, but each time I've been thwarted by my inability to come up with a name that I like (seems I struggle with naming even outside the software world). So today, in an effort to avoid doing something else that I really should be doing, I managed to come up with a name and finally get myself my very own blog.
Why
So why am I doing this? I'm not completely sure. I've thought of any number of reasons why I should do a blog, but in the end, I think there are only two that really matter.
Writing Practice
I've never been very happy with my writing skills. For one thing, my mastery of grammar and punctuation leaves more than a little to be desired - I really wish I'd paid much more attention in my high school English classes. But that's minor stuff. What really bugs me is the fact that I always seem to have so much trouble getting the thoughts in my head into words on the screen. It's not that I sit and stare at the screen with writer's block - I can generate plenty of words. The problem is coming up with the right words and getting them in the right order so that when someone else reads what I've written, they have half of chance of understanding what I'm trying to say.
I suppose I could take a writing class - and I might well do that eventually, but it seems like the simpler thing to do is to just start writing more. Practice makes perfect and all that.
Seeing What Happens
Beyond the writing practice, the only other reason for doing this blog is to see what happens. I dont necessarily think I have a whole lot to say. I don't consider myself exceptionally smart, nor do I think I'm a deep thinker. And I'm certainly not an expert on anything in particular (I'm more a jack-of-all-trades kind of guy). But that doesnt seem to stop most people. And I'm not going to let it stop me either.
Maybe, if I'm really lucky, I'll manage to start a conversation or two of my own and actually get some feedback. Maybe I'll find out that I'm pretty normal and that my approach to doing software fits in with the way most other people do it. Or, maybe I'll find out that I'm way out in left field making mountains out of molehills and my writing really does suck as bad as I think it does. Either way is fine by me - at least I've learned something.
I've been thinking about doing this for a while, but I've never really been motivated enough to actually do anything. I've come real close a number of times over the past few months, but each time I've been thwarted by my inability to come up with a name that I like (seems I struggle with naming even outside the software world). So today, in an effort to avoid doing something else that I really should be doing, I managed to come up with a name and finally get myself my very own blog.
Why
So why am I doing this? I'm not completely sure. I've thought of any number of reasons why I should do a blog, but in the end, I think there are only two that really matter.
Writing Practice
I've never been very happy with my writing skills. For one thing, my mastery of grammar and punctuation leaves more than a little to be desired - I really wish I'd paid much more attention in my high school English classes. But that's minor stuff. What really bugs me is the fact that I always seem to have so much trouble getting the thoughts in my head into words on the screen. It's not that I sit and stare at the screen with writer's block - I can generate plenty of words. The problem is coming up with the right words and getting them in the right order so that when someone else reads what I've written, they have half of chance of understanding what I'm trying to say.
I suppose I could take a writing class - and I might well do that eventually, but it seems like the simpler thing to do is to just start writing more. Practice makes perfect and all that.
Seeing What Happens
Beyond the writing practice, the only other reason for doing this blog is to see what happens. I dont necessarily think I have a whole lot to say. I don't consider myself exceptionally smart, nor do I think I'm a deep thinker. And I'm certainly not an expert on anything in particular (I'm more a jack-of-all-trades kind of guy). But that doesnt seem to stop most people. And I'm not going to let it stop me either.
Maybe, if I'm really lucky, I'll manage to start a conversation or two of my own and actually get some feedback. Maybe I'll find out that I'm pretty normal and that my approach to doing software fits in with the way most other people do it. Or, maybe I'll find out that I'm way out in left field making mountains out of molehills and my writing really does suck as bad as I think it does. Either way is fine by me - at least I've learned something.
Subscribe to:
Posts (Atom)