itNews

MS realizes that Longhorn is too long

April 13, 2004 8:47:41.517

MS is cutting back features to speed up Longhorn's initial release. That's not a big surprise - the dates had been slipping as far as 2008, and that was going to create an opening:

Microsoft won't ship an interim version of Windows, retail or otherwise, before Longhorn according to email seen by Business Week. The memos from a week ago suggest that Microsoft is jettisoning features from Longhorn in order to meet the ship date of the first half of 2006.

I addressed this general problem here, and it seems that someone at MS at least understands that the release cycle was getting absurdly long. Now that need to hand the cluestick over to the Whidbey team :)

 Share Tweet This

humor

Passed along without comment

April 13, 2004 9:31:10.520

 Share Tweet This

general

Diet tip of the day: worms

April 13, 2004 16:05:12.755

Worms can keep you healthy, according to new research. That's interesting...

 Share Tweet This

StS

Clean Slate at StS 2004

April 13, 2004 16:18:09.196

Research on development technology continues in the general Smalltalk space - register for StS 2004 to learn more about Slate - a still in development research project:

Clean Slate: Smalltalk and its Progress
presentation
Brian Rice: Logos Research and Development
Wednesday 2:45:00 pm to 3:30:00 pm

Abstract: An introduction and progress report for the Slate programming language and environment is provided, with the design rationale and examples of the benefits already gained from it. Several new sub-systems and features will be introduced and demonstrated, include the subjective programming facilities, graphics / interface architecture, general libraries, and the design of the implementation. Since Slate is similar in spirit to Squeak, comparisons will also be drawn between them in particular.

Bio: Brian Rice is a long-time member and contributor to the open-source Smalltalk and Lisp communities. He has been conducting informal research into language and system design for several years, and recently started developing the Slate language to channel these activities into a venture.

See you in Seattle!

 Share Tweet This

development

Where's that Productivity hiding?

April 14, 2004 8:32:35.098

Ben Galbraith points to an interesting Wall Street Journal story on a new software co-op, and asks the question: "How long will corporate America put up with the high prices and low quality of the software industry? A handful of major corporations have "enough is enough" and have banded together to form their own "software co-op". What impact will this have on our industry?". That leads to my own question - how long will corporations continue to listen to the utter morons who give software recommendations as if they were electing a prom queen? I mean seriously, this data isn't new. If corporations want better results, they have to widen their view and look beyond the supposed mainstream....

 Share Tweet This

rss

bits is bits

April 14, 2004 8:43:10.909

Danny Ayers notices that the CNet folks have done something amazing - on a page labelled as a set of RSS links, they have a link to a so called feed in a whole new format. Not RSS 2.0 with namespaced elements. Not RSS 1.0 with namespaced elements. Not Atom with namespaced elements. It's a whole new format, labelled as if it's RSS! Yeah, that's a way to deliver content in a clear fashion.

 Share Tweet This

development

What's that browser up to?

April 14, 2004 8:49:41.331

Ryan Lowe makes an excellent point on browsers that most of us forget - a lot:

The bottom line for me is this: web browsers are meant to show pages of text, not host elaborate client-side applications. Sure, forms are build into browsers and they are OK but there's a fine line of interactivity there. Accessibility concerns remind us how far we are actually straying from the main browser idea. If you have to wonder if your web site is accessible, it's probably not designed right for everyone else either.

Amen to that. If you end up in a swirl of JavaScript to fix something, you probably went down the wrong path quite awhile ago...

 Share Tweet This

development

The .NET guys demand bad code...

April 14, 2004 9:13:42.436

Eric Gunnerson highlights a mis-feature of the MS development suite that he's apparently proud of:

So, for Whidbey, we allow the user to mark a class as static, which means that it's sealed, has no constructor, and the compiler will give you an error if you write an instance method.

Someone ask this guy to spell "Object". Go ahead, spot him the first six letters...

Update: I have to pass on this comment I received in email:

I read this as a Java guy taking a feature of the Java language (the ability to mark a class as "final") and taking it a step further. Yeah, it's like a guy standing near the edge of a cliff and taking a step toward the cliff, but it's a step nonetheless. A step they haven't thought through very much. What the hell is the purpose of a class like this? You can't write an instance method? Sounds like something the gang at Smalltalk Solutions would come up with after hours at the bar, as a joke.

 Share Tweet This

StS

More embedded Smalltalk at StS

April 14, 2004 9:29:16.648

Register today for StS 2004 so you can see how Smalltalk is being used to guide an underwater bot

Smalltalk in an Autonomous Underwater Vehicle
presentation
Jon Hylands: EDS
Wednesday 2:45:00 pm to 3:30:00 pm

Abstract: Autonomous underwater vehicles (AUVs) are an emerging technology that are ideally suited for exploring underwater environments, in places where it may be too costly or dangerous for manned submersibles or remotely operated vehicles (ROVs) to operate. The software required to successfully pilot an AUV must be very robust, capable of complex behaviors, and also be easy to maintain and extend. Smalltalk fits the bill on all of these requirements. This demo will show MicroSeeker, a simple hobby-level autonomous underwater vehicle built by the presenter, with the high-level embedded "brain" of the system running in Squeak Smalltalk on a PDA.

Bio: Jon Hylands has been doing Smalltalk programming since 1987. Jon's main interests include sailing, hobby robotics, autonomous submersibles, and making Smalltalk work on embedded devices.

See you in Seattle!

 Share Tweet This

humor

UML fever

April 14, 2004 15:58:01.774

This is funny, but there's a lot of truth in it as well - UML is not a silver bullet, nor is MDA - but a lot of people think they are. This is the best bit:

42 fever. As opposed to the celebrated "42" being the answer to any question about life or the universe, as suggested in Douglas Adams's The Hitchhiker's Guide to the Galaxy, those afflicted with 42 fever argue that "UML" is actually the correct answer. The classical symptom of those afflicted with 42 fever in the sphere of software engineering is to have an a priori delusion that UML is the solution for all software-engineering problems. Research has shown that the delusion in victims of 42 fever can be significantly reduced by secretly playing subliminal messages in their work areas emphasizing that UML's creators did not intend for it to be the answer to all of software engineering's dilemmas

 Share Tweet This

development

Everyone re-invents Smalltalk

April 15, 2004 8:34:05.747

Ted Neward points to an article he mostly disagrees with - but stumbles into yet another re-invention of something Smalltalk got to a long time ago:

Why do we distribute applications across multiple systems today? Is it because we like managing multiple systems? No! It's for scalability. We exploit the fact that tiers of a multi-tier app have different processing loads and scalability methods. Typically, we scale the web/app tier by throwing more servers at the farm while we scale the data tier with bigger servers. However, as Moore's law increases the performance of these machines, the need to scale becomes reduced, From my experience, many smaller apps could easily run a single machine today (esp. when you consider the increased efficiency of eliminating the network and process hops). Moore's law will continue increase the headroom these machines provide and expand the definition of "smaller apps". If you can run the app on a single hardware node, there'd be little reason not to run as much of it as you can inside the database, other than "we might want to scale this out someday".

I wonder if these guys have ever heard of Gemstone/S?

 Share Tweet This

smalltalk

Smalltalk News in Germany

April 15, 2004 9:06:37.257

There's some good media news about Smalltalk in Germany:

Smalltalk and VisualWorks covered in a German computing magazine

"c't magazin fuer computer technik" is one of the best-known and most-read magazines for computer and software freaks in Germany. The current issue #8 of April 5, 2004 shows a double coverage for Smalltalk respectively Cincom Smalltalk:

The article "Einfach abheben" ("Take off simply") written by Hajo Schulz and Joachim Tuchel (p. 234 - 239) is the first part of an introduction into object-oriented programming with Smalltalk. As an overview the authors present a comprehensible comparison between Smalltalk and other programming languages. Based on Cincom Smalltalk's VisualWorks the authors explain 'step by step" how to use VisualWorks and create small examples ('hallo World" and "turtle new") for a first start.

"Programmiererfutter" ("Fodder for programmers") by Hajo Schulz (p. 126 - 128) recommends Cincom Smalltalk's VisualWorks as one of three tools for a professional software development. VisualWorks 7.2. non-commercial is part of the CD delivered with the magazine. The article helps for the first usage of VisualWorks - how to start with the CD, where to save the software on the desktop etc. It is a very good "how to use" instruction for VisualWorks beginners - excellent to start with given you understand German.

The magazine's web site: www.ctmagazin.de - Soft-Link 0408126 and Soft-Link 0408234

Report on Cincom Smalltalk Evening at OOP 2004
OBJEKTspektrum, the most important OO magazine in Germanic Europe, published in his latest issue, # 2 March/April 2004 p. 19, a report on the Cincom Smalltalk evening which was organized by Cincom and Georg Heeg eK during OOP 2004 in January in Munich and which was a great success.

 Share Tweet This

BottomFeeder

Updated Bf in Dev

April 15, 2004 19:05:20.912

I've posted a new BottomFeeder update to the dev stream - along with a new TwoFlower. You need both; you'll have some issues if you only grab one. What's new? Well, Holger has done some nice work with Twoflower, and I've been working to turn all the strings into UserMessages (so that the app can be localized). Bugs? I'm sure there are plenty (this is a dev update!) Please let me know

 Share Tweet This

smalltalk

New Seaside for Squeak

April 15, 2004 21:06:05.493

Chris Double points to the announcement of a new version of Seaside for Squeak. There's also a new VW version in the public Store, but I believe that one is a trifle older...

 Share Tweet This

itNews

Why Sun Settled

April 15, 2004 21:08:29.401

This is why Sun settled - they are losing money hand over fist, with few prospects of improvement....

 Share Tweet This

development

Re: Old Is New Is Old Again

April 16, 2004 8:30:10.681

Sean Malloy notices that the software world takes 1 step forward and 2 steps back on a continuous basis. He's not wrong :)

 Share Tweet This

smalltalk

Discovering Smalltalk

April 16, 2004 9:06:16.710

Ted Neward takes a look at Smalltalk, and likes what he sees - with a few questions:

And suddenly I wonder, Is this the source of all that XP goodness that the Smalltalk community gushes on about? If we had the ability to "load" a JVM or CLI instance into a frozen image, and ship that, say as a 24-48 MB "image" file, think about the possibilities--less startup time (I would think, since this could be a more or less memory-mapped image), plus I could conceivably give my customer an ability to "freeze" an image if a bug hits, and email or FTP the image with the bug in it to me for diagnostics. No more having to recreate the problem! It's all right there, for me to load, inspect variables, and so on.

The worry comes here:

Then again, there's security questions--what stops an attacker from mangling an image and injecting some rotten stuff? Is the image format well-known and easily subversible? If I started using Smalltalk as a back-end HTTP-processing agent, is there weird buffer-overruns or command-injections that could corrupt the image somehow?

There's no way to do a buffer overrun - in .NET speak, Smalltalk is a managed environment - immune to that kind of thing. As to command insertion - you can't load code from a remote location unless the server is set up to do that sort of thing. I have this server set up to load code from a known (server side) directory for patching, but I have to have permissions to place code there in the first place - and the directory is not in the web directory side of things, so it's inaccessible from there.

More generally, and image is just byte code - it's somewhat like a big JAR file, but with the ability to extend and override any code you want/need to. I do live updates whenever I have new code - without taking down the server. The nifty thing is this: If I load in a new version of a class, all the existing instances get updated - i.e., if I added/removed an attribute (instance variable), then all the instances added/removed it as well. That's what makes live updates feasible. The site that hosts this server is running VisualWorks (part of Cincom Smalltalk), and the only attacks I've suffered have been the kinds that all bloggers suffer - comment and referer spam :)

Now one more thing - as to bugs? There have been a few times I've had to debug the server - in which case I've started it up with a GUI, using X over ssh. And then I've debugged the actual problem in the live server as it was handling load. If I wanted to do that with less fuss, I could set up the remote debugging tools that use Opentalk - which I intend to do, when I get a few spare minutes :).

 Share Tweet This

development

DotNet - bad for your skills...

April 16, 2004 10:04:34.717

Apparently, DotNet actively rots your brain - just look at this post:

I'm sitting here at work building an application using TDD (which by itself is another post, and may be coming later), and every time I start a new class for another piece of the puzzle, I'm hating on how I have put the keyword "sealed" class in my declaration. Now, this isn't a major issue, but it can be if you plan on releasing an API for customers to build against. What's my issue? Well, I'm wondering if the "sealed" and "notinheritable" keywords should be applied by default in Whidbey.

He calls this "good design". Uh huh. Assuming that you know everything and that the end users of your code know nothing, I suppose it is. If you assume some level of intelligence in the end users of your code, it's just bad. I'm starting to think that "sealed" and "final" do more harm than static typing - they encourage closed end systems that cannot be extended without heroic efforts on the part of end developers. Run, don't walk, from any code developed by people who think this way...

 Share Tweet This

smalltalk

Re: Suckage Begets Suckage

April 16, 2004 10:07:04.795

Patrick Logan considers how things could have gone

If Sun had gone with Smalltalk rather than Java, where would they be now?

If Microsoft had gone with Smalltalk instead of C#, or way back in the 1990's when they could have forged something with Digitalk instead of their long and winding DCOM fiasco

To sleep, perchance to dream.... :)

 Share Tweet This

StS

Structured Drawing editors in Smalltalk

April 16, 2004 10:39:25.784

Register today so you can hear all about drawing editors in Squeak. Ned Konz has been doing research and implementation; check it out:

Building structured drawing editors using Connectors and Squeak
presentation
Ned Konz: Viewpoints Research
Wednesday 4:00:00 pm to 4:45:00 pm

Abstract: Connectors is an open-source framework for building structured drawing editors using Squeak Smalltalk. The rich component library provided with Connectors makes it easy to customize shapes and connectors, in many cases without writing any code.

This presentation will introduce Connectors and describe how Connectors can be used to quickly construct a Squeak application for editing and visualizing structured data. It will demonstrate the entire process of developing a simple Connectors application, including customizing connectors, connection policy, shapes, toolbars, flaps, and worlds.

Integration with the Genie gesture recognition system and the eToy tile scripting system will also be described.

Bio: Ned Konz has been a Squeaker since 1997, and has contributed a number of enhancements and fixes to the Squeak effort. He is also one of the six "Squeak Guides" who lead the open-source Squeak development effort. He has been working as an independent consultant since late 1999, at the end of a 7000km bicycle trip around the US west. His consulting work includes embedded system development as well as Squeak development.

About six months ago, Alan Kay invited him to join his team at Viewpoints Research, and Ned is now working with a number of projects including end-user computing, eToys, simulation, and other user interfaces.

See you in Seattle!

 Share Tweet This

BottomFeeder

Internationalized BottomFeeder

April 16, 2004 12:34:10.861

I've finished the job of replacing strings with UserMessages in BottomFeeder - now I need help. I've uploaded the message catalog (English) here. I've got a volunteer working on a German translation; anyone else have the time and/or inclination to help?

 Share Tweet This

news

Re: Cars targeted along stretch of interstate

April 16, 2004 16:38:21.176

We had the snipers, and now this. I guess this is better than that nutter who was shooting at cars in Ohio, but not by a lot. I drive that stretch of highway quite frequently, as it turns out...

 Share Tweet This

management

It's not just UML...

April 17, 2004 9:40:10.480

Ted Neward points to the UML Fever article - making a fine point:

Oh, how I remember former bosses and employers demanding UML models of code that was already written, "for documentation purposes", even though every developer on the project knew that the models would be (a) incorrect, (b) too high-level or too low-level to be useful, and (c) would almost immediately fall out of line with the code itself with the next feature request. (This was in the era of the very first two-way round-tripping tools, and they all--without exception--sucked.)

That pretty much sums up any technology fad - Java in the 90's being a particularly good example. For some reason, people in this industry continue to believe in silver bullets, regardless of how many werewolves pop up that are immune to them....

 Share Tweet This

development

Culture clash?

April 17, 2004 10:21:59.272

Ted disagrees with my take on final classes:

It was in my days as a C programmer that I came to realize that the fundamental difference between Smalltalk and C was that in Smalltalk, all reusability derives from inheritance. You want to reuse some code, you inherit from it, plain and simple. Even working through the Cincom Smalltalk manuals, I see that message over and over again. This is not true outside of Smalltalk.Inheritance creates a dependency on the base class type within all derived types, and if for some reason something in the base class type needs to change, every class below it feels the change, potentially breaking what happens.

First off, I'd say that most Smalltakers are somewhat leery of deep inheritance hierarchies now. With dynamic typing, polymorphism makes it easy to create ad-hoc interface matching without having to share a base class. In fact, that makes it easy to avoid the whole "fragile base class" problem entirely (even though it's less of a problem for Smalltalk than it is for static languages). I meet plenty of people who disagree with me on this point - the guy who gave the API talk at ot2004, for instance - I spoke to him briefly on the subject. I'm just not convinced. I know too many Smalltalkers who also know .NET and Java - all of them dislike "final", and all of whom talk about the nasty work-arounds they have to create to deal with the problem (typically, lots of helper classes). I tend to think that anything requiring that level of work-around is probably a bad idea.

Sure, this is a culture clash - but I still think it's a bad idea as well :) I think we'll have to agree to disagree for now

 Share Tweet This

development

Women in Software?

April 17, 2004 18:49:27.841

After writing this last week, I stumbled on misbehaving.net talking about a programmer gathering - and explaining pretty clearly why so many women stay away from the field...

 Share Tweet This

development

Sealed, Unsealed

April 17, 2004 23:17:05.581

Ted Neward argues in favor of sealed classes:

Look at it this way: take a simple example, that of overriding a method. What can you do in the base class to ensure that a future derivative doesn't somehow break your class' contract? Should derivatives call the base class method? And *when* should they make that call? At the start of their override? The end? Somewhere in the middle? What about synchronization concerns? Type compatibility? Are you really fully prepared to ensure that the Liskov Substitution Principle is honored in all its forms? From my experience, not many developers even know what Liskov is, much less what it's supposed to be doing for you.

Here's the simple answer: Why do I care? If another developer picks up my code, and wants to extend it by subclassing, it's not my problem - it's his. I'm going to make the assumption that said developer either

  • Knows what he is doing
  • Doesn't know, and will learn from his mistake

To my mind, stating that classes should be sealed is like saying that you should protect your kids from each and every mistake they might make someday. It might make you feel better, but it does positive harm to the people involved. Let other developers make their own decisions - making them for them is no favor.

 Share Tweet This

general

Getting girls into tech

April 18, 2004 8:59:02.940

I guess I've posted on this subject a bunch the last few days - maybe having a ten year old daughter is inspiring me :) Anyhow, Julia Lerman points to a Girl Scouts affiliated site that is trying to encourage girls interested in the field to stick with it. I have less than no idea whether this sort of thing helps or not, but I'll point my daughter to it and see what happens....

 Share Tweet This

itNews

Drinking the kool-aid

April 18, 2004 10:03:32.936

MaryFran Johnson believes the press releases from the Sun/MS deal. I would have thought a ComputerWorld editor would be more perceptive, but I guess not:

No question about it, this one belongs to you. IT customers were the driving force, the ultimate bottom line, the wake-up-to-reality call behind the historic Sun-Microsoft accord announced the morning of April 2

.

Uh, no MaryFran - customers had less than nothing to do with this deal. It hinged on a number of things, one of which she touches on later in the editorial:

  • Sun's increasingly weak and desperate position in the marketplace
  • MS' desire to get rid of a distracting lawsuit
  • Both companies desire to hurt the IBM/Linux push

That last one is something both companies agree on - and from the look of it, they agree on this more than they dislike each other. This is touched on later in the editorial:

Both companies are worried about the rise of Linux and the ever-present threat of IBM's enterprise dominance. Sun has suffered through years of financial setbacks and faces yet another quarterly loss and an upcoming layoff of 3,300 employees. Microsoft has spent tens of millions of dollars in courtroom battles over antitrust issues, and its stinging defeat last month by the European Commission moved its legal troubles as a monopolist onto the world stage

Funny that she puts that in the penultimate paragraph of the editorial - it's the key point of the deal - and the only reason it's happening. MS wanted to get rid of the suit, and Sun is weak - but neither was enough to drive this deal. What drove it was those two things combined with their joint belief that IBM and Linux are the bigger threat. The key thing to watch over the next few months is just how much Sun starts downplaying/cutting all the desktop initiatives they have been pushing - and how far they start distancing themselves from open source. This post from James Gosling could be considered an "opening salvo" in that positioning:

GPL software is not "free": it comes with a license that has a strong political agenda. Like GPL software, the Java platform is "free" in many senses: you don't have to pay anything for the runtime or developers kit and you can get the sources for everything. Unlike GPLd software, the Java sources don't come with a viral infection clause that requires you to apply the GPL to your own code. But the sources for the JDK do come with a license that has a different catch: redistribution requires compatibility testing.

Don't get too caught up in the "it's all because of what customers have been telling us hype - this is all about the three points I mentioned earlier. Sure, there's potential customer benefit here, but that's a secondary concern at best

 Share Tweet This

StS

Advanced VisualAge ST at StS 2004

April 18, 2004 10:57:50.839

VAST developers should run to Eric Clayberg's talk on advanced VAST programming at StS 2004 - Register today!

Advanced VisualAge Programming
presentation
Eric Clayberg: Instantiations
Wednesday 4:00:00 pm to 5:30:00 pm

Abstract: Eric Clayberg, Sr. Vice President of Product Development for Instantiations, Inc., was Executive Vice President of Objectshare Systems, Inc. and Vice President of Development for ParcPlace-Digitalk, Inc. He is the primary author and architect of over a dozen commercial Smalltalk add-on products including the popular VA Assist Enterprise and WindowBuilder Pro product lines. He has a BS from MIT and an MBA from Harvard.

Bio: This presentation will cover several advanced VisualAge Smalltalk topics including advanced GUI techniques, complex configuration management and development tool (browser) enhancements. Some of the specific topics to be covered include: callbacks & event handlers, attachments, hiding source, complex subapp configurations, version renaming, etc.

Topics will include:

  • Advanced GUI Techniques
    • Widget Callbacks & Event Handlers
    • Using Pointer Motion
    • Using Timers & Delays
    • Determining Key State
    • Attachments
    • Morphing
  • Complex Configuration Management
    • Hiding Source
    • SubApp Configurations
    • Version Renaming
    • Locating Dependent Configs
  • Development Tool (Browser) Enhancements
    • Extension API
    • Subclassing TextSelectionManager
    • Hooking KeyPress in Text Widgets
    • Enhanced Text Menu

See you in Seattle!

 Share Tweet This

general

On the net, no one knows if you are dead...

April 18, 2004 11:16:26.086

Check this out:

Join Vladimir Horowitz's mailing list to stay up-to-date on all the latest news, tour info, contest announcements, and more!

Tour info... Horowitz died in 1989, so if he goes back on tour, it'll certainly be news...

 Share Tweet This

BottomFeeder

Related links in Bf

April 18, 2004 16:02:29.354

I've just added (but not yet deployed) a new feature in Bottomfeeder - a "related links" view. Once you subscribe to a number of feeds, you'll find that many items refer to other items you've already got. Sometimes, it would be nice to view those items as a chain of related postings - which is what this view does. After evert update cycle, the link cache is updated so that you'll have accurate results. After a little more testing, I'll push it out to the development stream.

 Share Tweet This

development

Chris Double explains it all

April 18, 2004 20:06:26.811

Or at least, why sealed is a bad idea:

Another example, I like the way Common Lisp enables you to access variables not exported by a package. It requires you to access them in a different way to normal but you can still do it. There are simply times when you need to dive into the implementation of things that the originally designer thought you should be prevented from seeing. Having a way of doing this is invaluable when trying to do things 'outside of the box'.

IMHO, developers who seal classes to "protect" other developers are merely putting irritating walls in their way - and worse, they think it's helpful! Don't assume that you know how others will use your code. You don't. Period.

 Share Tweet This

marketing

Outsourcing in the PR gig?

April 19, 2004 9:23:02.275

PR News thinks that PR people should worry about outsourcing:

First of all, true PR and media work requires long-term relationships with media members. A level of trust, rapport and understanding needs to be established to receive proper recognition and media placements. True, but what rule states that you have to be in the same geographic arena as the media? Why wouldn't someone in India be able to form a relationship with media? If they don't have them now, they can partner with a US firm or an independent US consultant for help (and let me tell you, there are lots of very senior PR people floating around looking for work) and eventually transition it all over

Hmm. Let's take this question: "Why wouldn't someone in India be able to form a relationship with media?" - there's a simple answer: the 12 time zone difference. Think about it - we sleep while they're awake and vice-versa. Over the long haul (the time it takes to establish a relationship) - how many people are going to be willing to work that far off cut? Not many, I'd guess. This is a simple, but quite large obstacle...

 Share Tweet This

StS

Squeak update at StS 2004

April 19, 2004 9:53:51.886

Interested in what's going on in Squeak with respect to tools? Then register today and go to Colin Putney's tool talk:

Squeak Tools
presentation
Colin Putney: independent consultant
Wednesday 4:45:00 pm to 5:30:00 pm

Abstract: Squeak has come a long way in the last couple of years, and armed with improved tools and infrastructure, the community is progressing more rapidly than ever. This presentation will examine the new breed of Squeak development tools - PackageInfo, SqueakMap, Monticello, OmniBrowser and SqueakSource - and the technical and social issues that shape them. We'll also have a look under the hood with Monticello and OmniBrowser, a development environment well suited for the curious intersection of traditional Smalltalk philosophy and the new culture of OpenSource software.

Bio: Colin Putney is an independent consultant with a background in media, information systems and project management. He has worked in print media, television, the travel industry and international conservation. He was first introduced to Smalltalk several years ago and has never looked back.

See you in Seattle!

 Share Tweet This

development

Stunned by dynamicism

April 19, 2004 17:09:16.750

Found this in Planet Lisp - a fascinating look at a Java guy's first interaction with a dynamic language:

The interpreter immediately is waiting for you to tell it to do something, so I entered at the prompt:

>
>> (  10 2)
>
>and it gave me:
>12
>

Wow! I know this does not seem like much, but from the Java world where I come from, to get a Java program to add two numbers together would have taken a public static void main(String args) (etc) with the correct classpath settings, a class file, a compilation, and an execute.

Heh. I enjoy showing jsp developers "self halt." in an SSP page, myself :)

 Share Tweet This

StS

StS 2004 schedule changes

April 19, 2004 17:42:43.183

There are a few tweaks to the schedule for StS 2004:

Smalltalk Soutions is less then two weeks away! The show this year looks like it will be one of the best ever. Fantastic keynotes, outstanding presenters, and the best programming language there is. What more could you ask for?

For those of you local to the Seattle area or if you just happen to be in town for a day, we have added a one day pass for the conference. The one day conference pass is $200 USD and gives you full access to that days events except for tutorials. One day passes can only be purchased at the conference.

Two Additional Presentations Have Been Added to the Schedule

Squat: a minimal yet extensible Smalltalk system
Presentation
Craig Latta: The NetJam project
Wednesday 9:15 am to 10:00 am

Abstract: Squat (http://netjam.org/squat) is a portable Smalltalk system comprised only of that needed to start and extend itself. With its web-based installer, a visitor can transfer and run the system in a few seconds, by making a single webpage visit. This has the potential to make Smalltalk more accessible to newcomers. Squat's module system affords clean organization of the system, and accurate network distribution of behavior without using files or the compiler. This has the potential to increase the efficacy of Smalltalk software distribution and team development. This presentation is a look behind the scenes. We'll examine Squat's remote message-sending framework, how it enables both remote snapshot dissection and module distribution, and the virtual machine changes underlying it. We'll also look at the module system proper.

Bio: Craig Latta (http://netjam.org), a diligent minimalist, hesitates to say more about himself. However, he points out that he started Smalltalking in 1991 while in the music department at UC Berkeley, and has been an active contributor to Squeak since its first release in 1996, when he was at Interval Research. He currently works as a consultant on projects at Bedarra Research Labs and EZBoard, and records music in a Squeak-based digital studio.

Using SNMP for high-performance network monitoring
Presentation
Alex Pikovsky: Quallaby
Wednesday 2:00 pm to 2:45 pm

Abstract: The SNMP protocol is the principal tool for network discovery, data collection, monitoring and management. However, SNMP structure and design present a number of problems for high-volume/high-performance network monitoring.

In this presentation I start with a brief introduction of SNMP. I then discuss issues involved in SNMP-based data collection. Techniques for building a flexible, high-performance SNMP collection engine are introduced. The second part of the presentation discusses network discovery via SNMP. Alternative approaches are presented and case is made for using relational model for the discovery. It then discusses using a combination of ECMAScript and SQL for SNMP object discovery and data collection.

Bio: Alex Pikovsky became involved with Smalltalk in 1995 when he joined Cincom Systems. At Cincom, he combined consulting gigs with development work on ObjectStudio Smalltalk. Alex redesignedthe native thread engine and developed a new Class Browser for ObjectStudio. He was also interested in transactional computing and co-authored the object-transactional framework ObjectLinks with Stephen Pair. After Cincom's purchase of VisualWorks from ObjectShare, Alex led the Internet Connectivity project for VisualWorks. He designed e-mail and HTTP clients. He was also responsible for XML-to-Object engine and Web Services framework (SOAP and WSDL).

For the last three years Alex has been a principal engineer at Quallaby working on network performance monitoring software. He lives in Boston with his family.

Tutorial Added

Modular Smalltalk -- Refactoring Smalltalk to produce cross-language consumable components
Tutorial (extra cost applies)
David Simmons: Smallscript Corp
Monday 2:00 pm to 5:30:00 pm

Abstract: A large proportion of software is developed today using a variety of languages for extending or consuming pre-built components and shared class-libraries that are designed to function within one or more widely available cross-language server systems or frameworks. For commercial purposes, it is essential for today's programming languages to be capable of readily consuming building blocks and libraries from other languages. However, it has become equally critical for commercial viability that such languages also be capable of producing building blocks and libraries in cross-language standard formats for transparent consumption by other languages. This interactive presentation and discussion will both outline the objectives behind the modular architecture of the S# smalltalk dialect and it will explore the benefits of rethinking the single-image concept by modularizing Smalltalk frameworks and projects.

The presentation will discuss design challenges in modularizing Smalltalk and the related demands of cross-language integration, specific design solutions employed in the implementation of Smallscript Corp's S# smalltalk dialect and its underlying Agile Object System (AOS) Runtime and Framework, and demonstrations of components built in S#. The components presented in the final section will illustrate Smalltalk's ability to produce industry standard executables and shared-libraries (dll's) that exhibit both fast code execution and small deployment sizes.

Specific attention will be given to capabilities for automatically exposing libraries (written in Smalltalk) to other languages without sacrificing reflection or other dynamic language features when the same components are shared with other Smalltalk executables and dll's.

Depending on audience interest, the talk may also explore just-in-time integration which includes illustration of side-by-side sharing of different(dll) versions of the same class modules within a single application. Of note in such explorations are the capabilities that make it possible for a single application/executable to simultaneously host multiple Smalltalk dialect frameworks.

Bio: David Simmons has been designing and developing language systems and virtual machines since the early 1980's. He was the principal designer and architect for QKS Smalltalk-91, its commercial toolset, and its pre-emptively multi-threaded virtual machine. Since 1999, his ongoing work on the smalltalk language has focused on the design and development of the S# smalltalk dialect for both Microsoft's .NET Framework and Smallscript Corporation's Agile Object System (AOS) Framework, a modular multi-threaded platform for dynamic languages. This work has concentrated heavily on modularization, performance, object models, and meta-object protocol capabilities for supporting cross-language integration and runtime framework support of a superset of today's popular language features.

See you in Seattle!

 Share Tweet This

itNews

I'm not dead yet...

April 19, 2004 19:50:39.991

InfoWorld reports that a new rev of Netscape is in the offing...

 Share Tweet This

games

Gamers and Smalltalk

April 19, 2004 20:03:10.568

I ran across an interesting VisualWorks application this evening: the BESM Character Generator:

The future is now! How often have you said to your close friends, "Well, I would LIKE to make up a morphing mecha magical girl berserker, but it's just too much trouble. I guess I have no choice but to play the same old boring 11-levels-of-combat-mastery-kensin-ripoff character that I always do." Now with the power of wacky space age style programming technology, constructing even the most min-maxed 100-interlocking-attributes every-stupid-flaw-in-the-rulebook combat demon is as easy as taking out Tokyo in a 120-point battle mech!

Check out the site - they make the sources available as well - I'm going to download the application and take a look. Very cool looking!

 Share Tweet This

itNews

Cringely on Sun - no chance

April 19, 2004 21:01:46.178

Cringely doesn't think much of Sun's chances:

Look at the companies that can be thought of as true competitors of Microsoft -- companies that have caused Microsoft fits in the past. There aren't very many such companies, but ones that come to mind (in no particular order) are Netscape, Novell, Lotus, Adobe, Intuit, and IBM. This is not intended to be an exhaustive list, just some that came to mind; if your company also qualifies, well, I salute you. Some of these companies were in businesses where Microsoft had ambitions, like personal finance software and fonts. Some were at one time bigger than Microsoft, like Lotus and certainly IBM. Some created products that defined whole product classes like Netscape and Novell. And in every case, if we look to the time when that competitor was causing the greatest grief for Microsoft, it was when they were also paying no attention whatsoever to Microsoft.

His point - Sun is still too focused on MS - unlike the examples he gives. Read the whole thing.

 Share Tweet This

development

More thoughts on sealed/final

April 20, 2004 10:33:31.575

There's been a lot of talk about sealed/final since I posted here. In various posts (like this one from Ted Neward, the assertion is made that languages like Java and C# (any CLR based language, actually) need this capability, while Smalltalk doesn't. That sounded wrong to me, but I'll get to it. The other argument came across in a brief conversation I had with Joshua Bloch after this talk at ot2004. The argument goes like this: There's a pyramid of developers, with elite developers at the top (in small numbers) - with most living at the bottom two rows of the pyramid. making classes "final" protects this class of developer from themselves. I've pondered these two arguments, and had a few conversations about them on the Smalltalk IRC channel, with people who have experience with Smalltalk, Java, and C#. Here's what we came up with:

In Java, interface inheritance is the way to do things. A change in the API or semantics of the interface will ripple through all users - even though they aren't inheriting from the base class. So exactly what have you saved people from? Nothing except the option to inherit from a class if they wanted to take on that responsibility. So posit a class SecurityChecker and a method checkPassword(). That method should only take an instance of String, not some subclass or compatible class. That kind of security is arguably ok - but making it impossible to subclass String for any reason, ever - is overkill. The controls belong at a finer grain. What "final" ends up doing is cutting off your nose to spite your face. Here's a question: who's in a better position to know whether subclassing is appropriate:

  • The library developer who has never seen the end developer's code
  • The end developer who has seen both the framework and the end developer code?

Ted and Joshua Bloch say the library designers are in the better position. I say that's just silly - it really is akin to deciding that you are going to protect your children from all possible harm that could come to them by standing next to them 24x7. Sure, they'll be better protected. They'll also grow up as less than adults. This kind of protection means that developers have lots of (potentially better) options closed off to them, and they'll create crufty code. Worse, they'll start thinking that it's a good idea. The protection extended to them has ended up crippling them.

So now we come to arguments that Whidbey (the next gen of VisualStudio) should declare classes final by default, forcing developers to open them if they so choose. For the reasons given above, I think this is an awful idea. It will end up creating inflexible code - and since api changes ripple through a declared interface anyway, it offers few of the supposed benefits. I really have no idea why anyone thinks this is a good idea...

 Share Tweet This

spam

SpamCop - really stupid morons

April 20, 2004 12:57:14.083

So I'm trying to send mail to a BottomFeeder user - not using my corporate (Cincom) mail (why that doesn't work is another story for another day). So I send the mail off, using my Comcast account. Boom - notice from SpamCop that it's been blocked, due to spam from the server in question (i.e., the comcast mail server). So let me get this straight - because some people using Comcast as an ISP are sending spam (likely infected PC's), all of us using comcast as an ISP are being punished? That's bad enough - I figured ok, I'll try and contact SpamCop with a question. No dice on that:

  • No email addresses for contact on their website
  • I registered for their support frum, but since I'm not a customer, I can't post a question
  • No phone number on their website

So who the $%^&*() are these evil people? They filter out major ISP mail servers and leave no opening for complaint? I guess I have to contact comcast and see what (if anything) they can do for me. SpamCop - evil morons from heck.

 Share Tweet This

general

Dvorak - dumber than you thought

April 20, 2004 15:37:31.100

John Dvorak has had plenty of stupid things to say before, and he stays true to form here - he's off on a rant about how useless chat (AIM, IRC, etc) is. Oh? Sure, there's wasted time involved (just as there is in ad-hoc "water cooler" meetings in an office - but it's like any other conversation mechanism - it's as useful or as useless as the people involved care to make it.

 Share Tweet This

blog

Not getting it

April 20, 2004 19:54:40.518

Seth Finkelstein thinks that the "A-List" bloggers are the new gatekeepers in the blogosphere. Let me just relate my experience on this. I started blogging in the summer of 2002. I was getting something like 10 pageviews a day for the first few months. It accelerated some with the addition of an RSS feed, but not tons. Building up a readership (my pageview count averages around 2500 a day now) took a long time and took a lot of work. What's it take? Well, regular postings, on topics that people find interesting enough to read and/or discuss. It's helped that I've blogged a few conferences - some of the readers who followed conference writeups have stuck around to read whatever else I blather on about. It's not magic, and it doesn't require affirmation from A-Listers (gosh knows I haven't gotten it or tried to get it :) ). What it takes is consistently putting out content that other people are interested in. Nothing more, nothing less.

 Share Tweet This

management

How not to motivate your staff

April 20, 2004 20:33:02.326

AT&T Wireless gives us an excellent example of de-motivation in action:

However a new CIO appointed in April 2003 from Indian offshoring firm Wipro had his own techniques for motivating the IT staff, which borrowed heavily from Dilbert's Pointy Haired Boss. At Merrill Lynch, Christopher Corrado had been responsible for sending tech jobs offshore.

"Former employees say morale wasn't helped by Corrado's first presentation to the IT group, in which they say he proclaimed, 'Come in every day and expect to be fired'. Intended to inspire the troops to greater effort, the talk backfired," reports CIO magazine.

That's a sure-fire way to motivate the troops - letting them know just how much in danger their jobs are. Maybe if this bozo had gotten the same speech from his management...

 Share Tweet This

development

Releasing Software

April 20, 2004 20:39:33.251

Charles Miller has some really insightful thoughts on releasing software. Read the whole thing; this summary really does sum it up:

Anyway, as I was saying in the first paragraph, I used to think that the hardest thing a software project had to do was make the painful cut of features and bugs for 1.0. It turns out I was wrong. The hardest thing to do is, in fact, to make the cut for 1.1. The moment you release 1.0, you start getting these incredible things called users, who find all those bugs you never turned up during development, and who make really cool suggestions for things you could add.

Everyone who has ever released software that gets used learns this one the hard way...

 Share Tweet This
-->