TweetFollow Us on Twitter

NeXT Evolution
Volume Number:5
Issue Number:7
Column Tag:Developer's Forum

NeXT Evolution

By Paul Snively, Contributing Editor, Wheeling, IL

Evolution

Those of you who are waiting for the next (NeXT?) revolution in microcomputing are likely to be disappointed lately, and are probably going to remain that way for some time to come. That’s the news that I have to offer now that I have access to a NeXT computer. Before you go jumping out of your office windows or selling off your worldly goods and waiting for the end of the world to arrive, let me quickly add that this doesn’t mean that the picture is bleak. Far from it. Let me explain:

There’s a cube sitting about ten feet away from me. I won’t bore you with digitized pictures or a gushing description of how sexy it is; we’ve all seen the pictures, and we all know how sexy basic black can be (a fact that’s never been lost on the fashion world). The fact of the matter is that there are probably a fair number of people in MacTutor’s readership who remain without hands-on experience with this particular cube and would like some ideas from a fellow Macintosh developer as to just what this enigmatic little machine is like.

This Baby Ain't Portable!

For starters, the machine is, well, enigmatic. If you ever have to carry one of these things, the first thing that you realize is that the MegaPixel display that ships standard with every machine is far, far heavier than the computer itself is. Aside from that, there are virtually no physical problems with the machine. Putting one together is a simple matter of plugging the keyboard and mouse into the monitor, running a large cable between the computer and the monitor, and plugging the computer into the wall. Oh, by the way, you can plug the computer into the wall in the United States, England, Germany, or most other European countries with equal facility and no converters necessary.

25 mHz 68030 Processor

The computer itself, from an internal standpoint, is something of a throwback to a bygone era, at least in the microcomputer world: the case is simply a card cage. It consists of a power supply, an optical disk drive, optionally an internal Winchester hard disk, and a single card that literally can be described as the motherboard. The motherboard contains the obvious things: a 25 mHz MC68030 microprocessor, a similarly-clocked MC68882 floating-point coprocessor, and the by-now-famous Motorola DSP (Digital Signal Processor) chip. There are also two rather large custom VLSI chips that provide the I/O throughput that NeXT is so proud of. There’s also on-board Ethernet support for the thin-wire connector that sits on the backplane of every machine (and you thought AppleTalk on every machine was something).

Most of us are at least in touch with the hardware specs for the machine, and those who weren’t are now, after just two paragraphs of my lurid prose, so I’d better get to the point, which is this: the NeXT computer is a very nice 68030-based low-end workstation that supports a very nice version of UNIX (it’s Carnegie-Mellon’s MACH operating system, which consists of a rather small, tight kernel that provides a few new wrinkles in terms of memory management, networking, and multiprocessing, but manages to be compatible at the OS call level, not just the user level, with BSD4.3 UNIX). On top of MACH is Display Postscript, with a few NeXT wrinkles, such as fast bitmap compositing, thrown in for good measure (actually, even bitmap compositing isn’t entirely NeXT’s; it was jointly developed with Steve Jobs’ other little company, Pixar. By the way, if Pixar isn’t doing a chipset/card for the NeXT computer that’ll turn it into one of the hottest graphic workstations around, I’ll eat my shirt).

Ok, so we have what, from almost all outside appearances, is a 68030-based UNIX box running Display Postscript. Now what?

An Object-Oriented Computer From Ground Up!

“Now what” is what this article is really about. Because the reason that the NeXT computer is a piece of evolution that we should all be paying attention to as developers has nothing to do with the 68030, with the DSP, with optical storage, with UNIX or MACH, or any of that. It comes down to this:

The NeXT computer is an object-oriented computer almost from the ground up. Every machine ships with Stepstone, Inc.’s Objective-C, and the Free Software Foundation’s gcc (the GNU C compiler), gdb (GNU C source-level debugger), and GNU EMACS (as well as the Berkeley standard vi editor and NeXT’s own “Edit,” which is--as you might have guessed--a simple multi-window text editor based on NeXT’s windowing system, Display Postscript, etc.)

It doesn’t stop there. Each and every machine includes the Application Toolkit. The only way that I can describe the AppKit, as it’s called by NeXT, is that it’s what MacApp should have been. Again, this is nothing radical or new; it’s just the NeXT evolutionary step along the road that MacApp paved. The AppKit has a relatively small number of classes, and the hierarchy is fairly straightforward. The AppKit does what the AppKit should do: it makes the process of writing a NeXT application as painless as programming such a machine should be.

The reason that it’s so painless, however, is only partially a function of using Objective-C and the AppKit. The other important element in the development-tool arena is the Interface Builder.

Now, judging from the name alone, you wouldn’t think that the Interface Builder is anything special. In fact, it sounds an awful lot like ResEdit, doesn’t it? After all, ResEdit is a nice interactive utility for creating things that are, by and large, human interface elements, such as windows, dialog boxes, menus, strings, string lists, and the like. Certainly Interface Builder does all of these things, but more importantly, Interface Builder has some smarts about Objective-C and the AppKit. You can build dialogs in Interface Builder in the way you’d expect--by dragging buttons, sliders, fields, etc. to a window--but once you’ve done that, you can go a step or two further.

Interface Builder knows about objects that are part of the AppKit. It knows that applications have a main window and a main menu. It knows that there may be other windows, and submenus attached to the main menu. It knows about the standard behaviors that the AppKit defines for these objects (for example, it knows that when you click a button, the button should send some message to an object).

Non-human-interface objects--any object that isn’t part of the AppKit, in fact--Interface Builder knows nothing about by default. However, you can specify any custom object to Interface Builder, describing its methods in just enough detail to allow Interface Builder to use them in the process of connecting things.

To use a trivial example, let’s convert degrees Celsius to degrees Fahrenheit. To do this, we probably want a dialog that contains two text fields, Celsius and Fahrenheit, and a button, which we’ll title “>>Convert>>” to highlight the fact that we’re converting from Celsius to Fahrenheit.

All that we have to do to create this dialog is to drag two text fields and a button to our application’s main window. We should lay things out appropriately and label the fields and button appropriately. Then what we need to do is define a custom object, called “Converter,” to the Interface Builder. Converter isn’t a user-interface object--it’s the object that actually does the computation. It will only have one method, “convert,” which will take zero parameters, and it will have two “outlets,” input and output.

Outlets are the means by which non-user-interface objects communicate with user-interface objects. An outlet is an instance variable that an object possesses that gets initialized to the id of some other object so that the object owning the outlet can send messages to the other object. In this case, we will use the Interface Builder to connect the Celsius field to the Input outlet and the Fahrenheit field to the Output outlet. This way Converter’s convert method can refer to Input and Output to do the job without worrying about exactly what the objects being referred to are--Input could, after all, be connected to some object that provides a C-language-style float value based on a signal from an A/D converter attached to some sensor somewhere. Converter and its convert method shouldn’t--and don’t--care.

By now you may be wondering how all these connections are made. The Interface Builder includes a Connect panel that has square recessions to contain the sender object, the receiver object, and the outlet object. There are also two scrolling fields above the recessions. First, you would drag the button object to the sender recession and the Converter object to the receiver recession. The left-most scrolling text field would then list all of the messages that the Converter understand. We defined it to only understand one, convert. Clicking on that line in the scrolling field will cause a cable to appear between the button object and the Converter object, with separated screw and tab connectors in between. Clicking the cable closes the connection, indicating that clicking the button will send the convert message to the Converter object.

The right-most scrolling text field will list the outlets for the Converter object. Again, we defined two, Input and Output. We would drag the Celsius field to the outlet recession, then click on the line showing Input. A cable with separated male and female connectors would appear between the Converter object and the Celsius field. Clicking the cable would indicate that we want the Input instance variable initialized to refer to the Celsius text field in our dialog. We would repeat the process for the Fahrenheit field, connecting it to the Output outlet (read “instance variable.”)

It’s unfortunate that I can’t include NeXT screen dumps in this article; this whole process requires far too much verbiage to describe. Everything I’ve discussed so far can be done in Interface Builder in considerably less than sixty seconds. All that remains, then, is to save your work in Interface Builder and actually sit down and write the code for the Converter object.

I won’t go into massive details of the syntax and concepts behind Objective-C here, partially because this isn’t the time or place, and partially because my understanding of both is extremely incomplete at this point. In any case, the process consists of creating a new class, Converter, that will simply be a subclass of Object, since it doesn’t need to inherit anything special from anything else. Converter would have two instance variables, Input and Output, both of type id (all objects in Objective-C are of type id). We would then define the single method, convert. Convert will have two local variables of type float, c and f. The code for convert would then look something like this:

c = [Input getFloatValue];
f = (c *9.0 / 5.0) + 32.0;
[Output setFloatValue: f];
return(self);

Apart from declaring the class and its instance variables and the method and its local variables, that is all there is to converting from celsius to fahrenheit at literally the click of a button. The Interface Builder prevents you from having to write any more code than that to make your application work.

The question I have is this: why hasn’t anyone done anything like that for MacApp? Certainly parsing and generating Object Pascal code with some amount of “inside knowledge” of MacApp shouldn’t be that tough; anyone who’s ever used compiler-development tools such as yacc and lex knows that. Let’s not let this piece of evolution pass us by. With tools like this, programming can become much easier for all of us.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Navicat Premium Essentials 12.1.25 - Pro...
Navicat Premium Essentials is a compact version of Navicat which provides basic and necessary features you will need to perform simple administration on a database. It supports the latest features... Read more
Sketch 58 - Design app for UX/UI for iOS...
Sketch is an innovative and fresh look at vector drawing. Its intentionally minimalist design is based upon a drawing space of unlimited size and layers, free of palettes, panels, menus, windows, and... Read more
ClipGrab 3.8.5 - Download videos from Yo...
ClipGrab is a free downloader and converter for YouTube, Vimeo, Facebook and many other online video sites. It converts downloaded videos to MPEG4, MP3 or other formats in just one easy step Version... Read more
Dash 4.6.6 - Instant search and offline...
Dash is an API documentation browser and code snippet manager. Dash helps you store snippets of code, as well as instantly search and browse documentation for almost any API you might use (for a full... Read more
FotoMagico 5.6.8 - Powerful slideshow cr...
FotoMagico lets you create professional slideshows from your photos and music with just a few, simple mouse clicks. It sports a very clean and intuitive yet powerful user interface. High image... Read more
Civilization VI 1.2.4 - Next iteration o...
Sid Meier’s Civilization VI is the next entry in the popular Civilization franchise. Originally created by legendary game designer Sid Meier, Civilization is a strategy game in which you attempt to... Read more
Skype 8.52.0.138 - Voice-over-internet p...
Skype allows you to talk to friends, family and co-workers across the Internet without the inconvenience of long distance telephone charges. Using peer-to-peer data transmission technology, Skype... Read more
Bookends 13.2.6 - Reference management a...
Bookends is a full-featured bibliography/reference and information-management system for students and professionals. Bookends uses the cloud to sync reference libraries on all the Macs you use.... Read more
BusyContacts 1.4.0 - Fast, efficient con...
BusyContacts is a contact manager for OS X that makes creating, finding, and managing contacts faster and more efficient. It brings to contact management the same power, flexibility, and sharing... Read more
Chromium 77.0.3865.75 - Fast and stable...
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all Internet users to experience the web. Version 77.0.3865.75: A list of changes is available... Read more

Latest Forum Discussions

See All

Yoozoo Games launches Saint Seiya Awaken...
If you’re into your anime, you’ve probably seen or heard of Saint Seiya. Based on a shonen manga by Masami Kurumada, the series was massively popular in the 1980s – especially in its native Japan. Since then, it’s grown into a franchise of all... | Read more »
Five Nights at Freddy's AR: Special...
Five Nights at Freddy's AR: Special Delivery is a terrifying new nightmare from developer Illumix. Last week, FNAF fans were sent into a frenzy by a short teaser for what we now know to be Special Delivery. Those in the comments were quick to... | Read more »
Rush Rally 3's new live events are...
Last week, Rush Rally 3 got updated with live events, and it’s one of the best things to happen to racing games on mobile. Prior to this update, the game already had multiplayer, but live events are more convenient in the sense that it’s somewhat... | Read more »
Why your free-to-play racer sucks
It’s been this way for a while now, but playing Hot Wheels Infinite Loop really highlights a big issue with free-to-play mobile racing games: They suck. It doesn’t matter if you’re trying going for realism, cart racing, or arcade nonsense, they’re... | Read more »
Steam Link Spotlight - The Banner Saga 3
Steam Link Spotlight is a new feature where we take a look at PC games that play exceptionally well using the Steam Link app. Our last entry talked about Terry Cavanaugh’s incredible Dicey Dungeons. Read about how it’s a great mobile experience... | Read more »
PSA: GRIS has some issues
You may or may not have seen that Devolver Digital just released GRIS on the App Store, but we wanted to do a quick public service announcement to say that you might not want to hop on buying it just yet. The puzzle platformer has come to small... | Read more »
Combo Quest (Games)
Combo Quest 1.0 Device: iOS Universal Category: Games Price: $.99, Version: 1.0 (iTunes) Description: Combo Quest is an epic, time tap role-playing adventure. In this unique masterpiece, you are a knight on a heroic quest to retrieve... | Read more »
Hero Emblems (Games)
Hero Emblems 1.0 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0 (iTunes) Description: ** 25% OFF for a limited time to celebrate the release ** ** Note for iPhone 6 user: If it doesn't run fullscreen on your device... | Read more »
Puzzle Blitz (Games)
Puzzle Blitz 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: Puzzle Blitz is a frantic puzzle solving race against the clock! Solve as many puzzles as you can, before time runs out! You have... | Read more »
Sky Patrol (Games)
Sky Patrol 1.0.1 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0.1 (iTunes) Description: 'Strategic Twist On The Classic Shooter Genre' - Indie Game Mag... | Read more »

Price Scanner via MacPrices.net

Preorder your Apple Watch Series 5 today at A...
Amazon has Apple Watch Series 5 GPS models available for preorder and on sale today for $15 off Apple’s MSRP. Shipping is free and starts on September 20th: – 40mm Apple Watch Series 5 GPS: $384.99 $... Read more
21″ iMacs on sale for $100 off Apple’s MSRP,...
B&H Photo has new 21″ Apple iMacs on sale for $100 off MSRP with models available starting at $999. These are the same iMacs offered by Apple in their retail and online stores. Overnight shipping... Read more
2018 4 and 6-Core Mac minis on sale today for...
Apple resellers are offering new 2018 4-Core and 6-Core Mac minis for $100-$150 off MSRP for a limited time. B&H Photo has the new 2018 4-Core and 6-Core Mac minis on sale for up to $150 off... Read more
Save $150-$250 on 10.2″ WiFi + Cellular iPads...
Verizon is offering $150-$250 discounts on Apple’s new 10.2″ WiFi + Cellular iPad with service. Buy the iPad itself and save $150. Save $250 on the purchase of an iPad along with an iPhone. The fine... Read more
Apple continues to offer 13″ 2.3GHz Dual-Core...
Apple has Certified Refurbished 2017 13″ 2.3GHz Dual-Core non-Touch Bar MacBook Pros available starting at $1019. An standard Apple one-year warranty is included with each model, outer cases are new... Read more
Apple restocks 2018 MacBook Airs, Certified R...
Apple has restocked Certified Refurbished 2018 13″ MacBook Airs starting at only $849. Each MacBook features a new outer case, comes with a standard Apple one-year warranty, and is shipped free. The... Read more
Sunday Sale! 2019 27″ 5K 6-Core iMacs for $20...
B&H Photo has the new 2019 27″ 5K 6-Core iMacs on stock today and on sale for up to $250 off Apple’s MSRP. Overnight shipping is free to many locations in the US. These are the same iMacs sold by... Read more
Weekend Sale! 2019 13″ MacBook Airs for $200...
Amazon has new 2019 13″ MacBook Airs on sale for $200 off Apple’s MSRP, with prices starting at $899, each including free shipping. Be sure to select Amazon as the seller during checkout, rather than... Read more
2019 15″ MacBook Pros now on sale for $350-$4...
B&H Photo has Apple’s 2019 15″ 6-Core and 8-Core MacBook Pros on sale today for $350-$400 off MSRP, starting at $2049, with free overnight shipping available to many addresses in the US: – 2019... Read more
Buy one Apple Watch Series 5 at Verizon, get...
Buy one Apple Watch Series 5 at Verizon, and get a second Watch for 50% off. Plus save $10 on your first month of service. The fine print: “Buy Apple Watch, get another up to 50% off on us. Plus $10... Read more

Jobs Board

*Apple* Mobility Pro-Store 149 - Best Buy (U...
**731985BR** **Job Title:** Apple Mobility Pro-Store 149 **Job Category:** Store Associates **Location Number:** 000149-Towson-Store **Job Description:** At Best Read more
Student Employment (Blue *Apple* Cafe) Spri...
Student Employment (Blue Apple Cafe) Spring 2019 Penn State University Campus/Location: Penn State Brandywine Campus City: Media, PA Date Announced: 12/20/2018 Date Read more
Windows/ *Apple* Technical Support Engineer...
Windows/ Apple Technical Support Engineer McLean , VA , US Apply + Be you + Be Booz Allen + Be empowered + Learn More Job Description Location: McLean, VA, US Job Read more
*Apple* Mobile Master - Best Buy (United Sta...
**725617BR** **Job Title:** Apple Mobile Master **Job Category:** Store Associates **Location Number:** 001095-Chesterfield-Store **Job Description:** **What does a Read more
Geek Squad *Apple* Master Consultation Agen...
**732415BR** **Job Title:** Geek Squad Apple Master Consultation Agent **Job Category:** Services/Installation/Repair **Location Number:** 000425-Hickory-Store **Job Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.