MacTech Network:   MacForge.net  |  Computer Memory  |  Register Domains  |  Printer Supplies  |  Cables  |  iPod Deals  |  Mac Deals  |  Mac Book Shelf


  MacTech Magazine

The journal of Macintosh technology

 
 
Power Save Mac

Magazine In Print
  About MacTech  
  Home Page  
  Subscribe  
  Archives DVD  
  Submit News  
  Submit a Tip!  
  Get a copy of MacTech RISK FREE  
Google
Entire Web
mactech.com
Mac Community
More...
MacTech Central
  by Category  
  by Company  
  by Product  
MacTech News
  MacTech News  
  Previous News  
  MacTech RSS  
Article Archives
  Show Indices  
  by Volume  
  by Author  
  Source Code FTP  
Inside MacTech
  Writer's Kit  
  Editorial Staff  
  Editorial Calendar  
  Back Issues  
  Advertising  
Contact Us
  Customer Service  
  MacTech Store  
  Legal/Disclaimers  
  Webmaster Feedback  
ADVERTISEMENT
Click Here
Volume Number:7
Issue Number:6
Column Tag:Tools of the Trade

HyperCom: HC 2.0 Networking

By Dave Kelly, MacTutor Editorial Board

HyperCom™: HyperCard 2.0 Network

Communications the easy way!

HyperCard has invaded the AppleTalk network with HyperCom™ 2.0 from GAVA Corporation. HyperCom is so easy to use that it seems like a natural part of HyperTalk. In fact, HyperCom is a set of extendable XCMDs and XFCNs that take care of all the details of network communications. All that’s left for you is to develop your own HyperTalk scripts to create network software for nearly any purpose.

The best thing about HyperCom is how much fun you can have with it. Programming with HyperCom is not a drudgery; it doesn’t leave you with hours trying to figure how to get it to work. It’s simplicity is the key. There is only one XCMD that is used to communicate with other HyperCom users over AppleTalk.

HyperCard 2.0’s ability to open multiple windows at the same time makes it possible to use HyperCom’s XCMDs and XFCNs without moving them to your stack. You can set up your stack to include the HyperCom stack in the current inheritance path by using the HyperTalk command:

start using stack HyperCom

This statement allows you to access handlers in the HyperCom stack without having to modify your Home stack or your copy of HyperCard.

HyperCom has one command, “Tell”. “Tell” has three special forms that can be used to find the names of other registered HyperCom users. 1) tell who puts a delimited list of all HyperCom users on the network into “the result”. Your scripts can evaluate the list in “the result” to decide who you want to send your message to. 2) tell whom shows a pop-up menu with all the HyperCom users listed. It returns the selected user name in “the result”. 3) tell whol brings up a dialog box with a list of all HyperCom users on the network. One or more users may be selected and returned in “the result”.

Once you know who you will be sending the message to, you use “Tell” and the name (or names) of the users and send your message or messages. In my example, I use tell whol to ask for a network user.

 tell whol,,”Set clock of which Mac:”

Then I use the following lines to tell the user to execute the XCMD “SetTimeDate” installed in the user’s stack.

--1

 put the result into them
 put the seconds into standardtime
 tell them, “SetTimeDate”, standardtime

The purpose of my example is to use HyperCom communications to synchronize the clock on every computer on the network with a single computer. Since HyperCard doesn’t have a command to set the clock, I made one. The Pascal source code is included at the end of this column. After the XCMD is compiled and installed into a stack, clicking on a single button brings up the user list to select which users’ clock you want to set. Then the script gets the time from the HyperTalk seconds function and sends it to the user with the command to use the SetTimeDate XCMD to set the clock.

Each copy of HyperCom is serialized and set up for a specific number of users. The basic HyperCom package supports 2 users, but there is technically no limit on the number of users. HyperCom has been used at sites with as many as 600 users over several zones. Some schools have 40-50 users on a single zone. HyperCom does not get slowed down with more users. Yet, it makes sense that if the implementation uses a single server, where the server seeks information and sends it back to the requesting station, that the speed would be affected. Of course, then, the speed is dependent on how long it takes to process each query. Database types of applications with 10-20 users are not uncommon. HyperCom does queue up messages, and allows long scripts to execute new messages to be executed by calling “Tell” in the body of the handler. Because the limitation with HyperCom is not with the network traffic, speed problems can be solved by distributing the data or processing on several machines, or using faster processors.

GAVA also provides other XCMDs and XFCNs that can be used to extend the capabilities of HyperCom. These are very useful efficiency savers. For example, with the sendResource XCMD, the SetTimeDate XCMD could be sent to the user, used to set the clock, then deleted when done. I don’t have the sendResource XCMD so I couldn’t try it. The sendFileXCMD sends files over the network. The sendSound XCMD sends a sound to be played by the receiving machine. Other commands include sendCard, sendClipboard, sendScreen and the question XFCN to evaluate expressions on a remote Macintosh.

The manual for HyperCom is brief (29 pages) and get right to the point, but since the commands are simple not much explanation is required. It does a good job in telling what the tell command does, but it leaves out a few minor details. For example, it didn’t say what to expect if the user didn’t select any users, but used the cancel button instead. Since HyperCom is simple to use, these omissions can be figured out without too much trouble.

There are some sample stacks included with HyperCom. On of the examples is a network checkers game. My son really loved that one. The examples were designed to give you some ideas of what HyperCom can do.

HyperCom is ideally suited for anyone that needs network communication capability in HyperCard. Happy Networking!

HyperCom™ is available from:

GAVA Corporation

1001 4th Ave Plaza, Suite 3200

Seattle, WA. 98154

Phone: 800-767-0647 or 206-223-4282

FAX 206-223-0653

AppleLink GAVA

InterNet: GAVA@applelink.apple.com

CompuServe: 76174,221

GENIE: GAVA

Prices:

HyperCom 2.0 (for 2 users) $99.95

HyperCom 2.0 with HyperCard 2.0 $129.95

Additional license for HyperCom $50.00

Zone license for HyperCom $499.95

sendFile XCMD $35.00, sendSound XCMD $35.00

sendCard XCMD $35.00, sendClipboard $35.00

sendScreen XCMD $35.00, question XFCN $35.00

sendResource XCMD $35.00

Requires: a Macintosh computer with System 6.0.5 or newer, 1MB RAM and a hard disk.

SOFTWARE UPDATES

Be sure to check for upgrades to your applications. Many of these are already available on AppleLink, America On-Line and other services. Some of the new versions which have been available for some time now are: Now Utilities version 2.0.3, Suitcase II version 1.2.9, and QUED/M 2.09.

{ HyperCard SetTimeDate XCMD}
{ by Dave Kelly                    }
unit SetTimeDateUnit;
{ This project handles the SetTimeDate command }
interface
 uses
{include the HyperCard interfaces in the XFCN/CMD}
 HyperXCmd;
 procedure main (paramPtr: XCmdPtr);
{ the entry point for the XCMD/XFCN }
implementation
 procedure main;
 procedure Fail (errMsg: Str255);
{ return a given error message to HyperCard }
 begin
 paramPtr^.returnValue := PasToZero(paramPtr, errMsg);
 {Set return value of the paramBlock to given message. }
 exit(main); {exit the routine }
 end;
 procedure Setthetime (paramPtr: XCmdPtr);
 var
 str: str255;
 TheTimeDate: longint;
 Error: OSErr;
 begin
 if (paramPtr^.paramCount <> 1) then
 Fail(‘%bad parameters’);
 ZeroToPas(paramPtr, paramPtr^.params[1]^, str);
{ convert the location to a string }
 TheTimeDate := StrToNum(paramPtr, str);
 { and thence to a longint }
 Error := SetDateTime(TheTimeDate);
 { if the handle is empty, then return an error}
 if Error <> noErr then
 Fail(‘DateTime not changed!’);
 end;
 begin
 Setthetime(paramPtr);
{entry point; call the Setthetime routine}
 end;
end.

STACK SCRIPT:
-- This product is for licensed HyperCom™ users only
on openstack
  global userchecktime
  start using stack HyperCom
  tell who
  put the result into card field “HyperCom Users”
  put the seconds into userchecktime
  pass openstack
end openstack
on startstack
  global userchecktime
  start using stack HyperCom
  tell who
  put the result into card field “HyperCom Users”
  put the seconds into userchecktime
  pass startstack
end startstack
on idle
  global userchecktime
  put (the seconds - userchecktime) into elapsedtime
  if (elapsedtime>=15) then
    tell who
    put the result into card field “HyperCom Users”
    put the seconds into userchecktime
  end if
  put the long time into card field “Time”
  put the long date into card field “Date”
  pass idle
end idle

CARD BUTTON:
on mouseup
  tell whol,,”Set clock of which Mac:”
  if the first line of the result is empty then exit mouseup
  put the result into them
  put the seconds into standardtime
  tell them, “SetTimeDate”, standardtime
end mouseup



Click here to find out more about our best subscription bundle deal ever!
2 years of the magazine, and the all new MacTech DVD ... at 70% off!



Click on the cover to
see this month's issue!

TRIAL SUBSCRIPTION
Get a RISK-FREE subscription to the only technical Mac magazine!
 
 


MacTech Magazine. www.mactech.com
Toll Free 877-MACTECH, Outside US/Canada: 805-494-9797

Register Low Cost (ok dirt cheap!) Domain Names in the MacTech Domain Store. As low as $1.99!
Save on brand compatible and name brank ink jet and laser supplies.
Save on long distance * Upgrade your Computer
Movies with No Late Fees!

See local info about Westlake Village
SJ * BRJ * BJ * OJ * NITS
Staff Site Links



All contents are Copyright 1984-2007 by Xplain Corporation. All rights reserved.

MacTech is a registered trademark of Xplain Corporation. Xplain, Video Depot, Movie Depot, Palm OS Depot, Explain It, MacDev, MacDev-1, THINK Reference, NetProfessional, NetProLive, JavaTech, WebTech, BeTech, LinuxTech, Apple Expo, MacTech Central and the MacTutorMan are trademarks or service marks of Xplain Corporation. Sprocket is a registered trademark of eSprocket Corporation. Other trademarks and copyrights appearing in this printing or software remain the property of their respective holders.