TweetFollow Us on Twitter

May 93 - WAMADA Notes

WAMADA Notes

John MacVeigh

The February WAMADA meeting was held a week late to avoid conflicting with MADACON. As a result, members who traveled to San Diego had a chance to report on the latest news from the conference. It will suffice to say that no one leapt for the phone to change their current development plans. The expected release of another MacApp update was the piece of news most immediately useful to our members. Component Software seems to be off to a good start with their plan to involve third parties in the enhancement of Component Workshop™. This could become a key weapon in their upcoming battle for market share with Symantec's Think C++. Bedrock is still on the horizon, and the viability of a single framework which provides a "native" look and feel on more than one platform remains barely tested. At the 50,000 foot level (a common Apple metaphor for "the big picture") the concept of writing frameworks to encapsulate your application's knowledge is the latest programming paradigm. Dave Wilson was the most public advocate of this idea, Taligent the most subtle.

Threads and Asynchronicity

The second part of the February meeting focused on ways of providing multiple execution paths in MacApp applications. Yvon Perreault of Cactus Inc. (a large-format color printing company) presented some sample code for the use of Apple's Threads package to provide asynchronous polling of PPC I/O completion calls. One "gotcha" with using threads is that segments can not be unloaded while a thread is executing, and since the main program is also a thread, MacApp's auto-unload feature had to be disabled.

Phil Flack of McDonnell Douglas Aerospace showed his code which provides event handling while the mouse is held down in controls. This was used to allow the monitoring of real-time devices which can transmit data to the Mac at any time. Phil overrode Button, CheckBox and Radio controls to set the control's action proc to a function which calls PollEvent during tracking. The key "trick" to making this work is to call Focus after PollEvent has returned. If the routine which is calling PollEvent is performing drawing, you need to also save off and restore the visRgn, clipRgn, and state of the fUpdating flag during the call.

Phil and coworker Mark Gerl also showed some code for a TEventHandler class called TTimedHandler which serves as an intermediary for TBehaviors on the application's idle chain. Since TBehaviors are not descended from TEventHandler, they can not directly be part of the idle chain. By using a TTimedHandler, a TBehavior can indirectly add itself to the idle chain. The TTimedHandler just passes the DoIdle call through to the TBehavior. Lastly, they described how the use of a state machine within idle methods can be used to break up processing of lengthy tasks without destroying the responsiveness of the user interface.

Affiliate Matters

The March WAMADA meeting fell four days after the infamous blizzard of '93, and squarely on Saint Patrick's Day. As a result, attendance also fell. Still, almost a dozen attendees gathered and, to start the meeting, tackled the subject of becoming an official MADA affiliate. The chief concern was that an admittance charge for non-members would drive people away, rather than encourage them to pay for membership. This lead to a discussion on how to structure MADA's fees and benefits. One proposed benefit of becoming an official affiliate is that we would receive a small share of the profits from MADA products sold at meetings. Since this is an inconvenient way to purchase software, it was suggested that a member's affiliation be recorded when they sign up, and that the affiliate get a cut from any MADA purchase which they made. Electronic access to bulletin boards is a common and often essential part of our jobs, so it was suggested that MADA establish a board on one or more of the commercial systems and limit access to members only. (Using existing systems removes the costs of billing and some administration from MADA, and provides the most widespread service). Also suggested was a more staggered fee structure, where a higher fee gains you increasing access to MADA's benefits, namely: printed information, books and software, on-line services, meetings and conferences. The question of where affiliate meetings fell in this list of services was left unanswered. Since the board member writing the affiliates rules (Leslie Jeffries) is also in charge of WAMADA, we agreed that becoming an affiliate was a good thing to do, but we wanted to see a more complete design of the implementation before making a formal declaration (typical OO programmers, huh?).

Mitem View

Our March speaker was Dan Corenzwit of Mitem Corporation. Mitem makes MitemView™, a communications product which people often associate exclusively with HyperCard. While HyperCard is the original interface for MitemView, it is no longer the only one. Now in its fourth generation, MitemView can make use of HyperCard, 4D, and C++. Note that I said "make use of" rather than "be used by". This is because Mitem considers MitemView (MV) to be a framework rather than a library. Dan credits Dave Wilson's session at MADACON for putting the difference in perspective. A library provides services which your application must determine how and when to call. A framework provides functionality that calls your application's additions at the appropriate time.

In the case of MV the functionality provided is the ability to recognize the arrival of messages and associated data from remote machines (usually mainframes) and then call your code to handle the message and its data. Its primary market is people who need to use "legacy" applications (all those mainframe COBOL applications which communicate with hardwired terminals) on their micros. Dan explained that MV views the remote system as a non-sequential, non-deterministic state machine and attempts to linearize the complexity of moving between states. MV works asynchronously (hmmm, I see a trend here!). It accepts input from a variety of communication services (SNA, TCP/IP, etc.) examines the "presentation" of the data (sort of a generalized terminal emulation) and matches incoming patterns with pre-built messages which it then sends to you. MV is able to update itself on the fly, from information provided by the sender, if a new configuration is needed to handle changes in the presentation.

To support MacApp, Mitem provides several C++ classes, along with code which is installed in your application as resources. The MV communication objects are not part of the target chain. This allows interactions with the remote machine to work in parallel with user interface activity. When MV recognizes a pattern it sends your code a message in the form of a message name. This name is turned into a method call by way of a registration table which your application builds. The result is that your application becomes a sort of way station between two users: the person running it, and the remote machine sending in data.

In combination with the previous month's discussion of handling asynchronous I/O, I found the asynchronous nature of MitemView its most interesting feature. Dan showed that responding to messages from MV in the proper order can improve response time, by taking the remote machine's processing time into account. As operating systems (including the Mac's) move towards providing multi-threading and multi-processing services, those of us who long ago became comfortable with event-based programming will have to take the next step to working with these new services. Thinking back to MADACON, I don't recall many vendors touting multi-threading as a factor in the design of their frameworks (SmalltalkAgents is the only exception that comes to mind). Let's hope this changes as fast as the new OSs change.

If you're in the D.C. area, and interested in object oriented programming, give WAMADA a visit. We meet every third Wednesday at McDonnell Douglas in Tyson's Corner, Virginia, beginning around 7:15 p.m. For a map, send a message to JEFFRIES.L on AppleLink, or call Leslie at (301) 340-5126 during business hours (EST).

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Day One 2.3 - Maintain a daily journal.
Day One is the easiest and best-looking way to use a journal / diary / text-logging application for the Mac. Day One is well designed and extremely focused to encourage you to write more through... Read more
Carbon Copy Cloner 4.1.16 - Easy-to-use...
Carbon Copy Cloner backups are better than ordinary backups. Suppose the unthinkable happens while you're under deadline to finish a project: your Mac is unresponsive and all you hear is an ominous,... Read more
Sketch 45 - 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
NeoFinder 7.1 - Catalog your external me...
NeoFinder (formerly CDFinder) rapidly organizes your data, either on external or internal disks, or any other volumes. It catalogs all your data, so you stay in control of your data archive or disk... Read more
TunnelBear 3.0.15 - Subscription-based p...
TunnelBear is a subscription-based virtual private network (VPN) service and companion app, enabling you to browse the internet privately and securely. Features Browse privately - Secure your data... Read more
Hopper Disassembler 4.2.5- - Binary disa...
Hopper Disassembler is a binary disassembler, decompiler, and debugger for 32-bit and 64-bit executables. It will let you disassemble any binary you want, and provide you all the information about... Read more
BetterTouchTool 2.261 - Customize Multi-...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more
Sketch 44.1 - Design app for UX/UI for i...
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
BetterTouchTool 2.260 - Customize Multi-...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom... Read more
Chromium 59.0.3071.115 - 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 59.0.3071.115: This update has no Flash plug... Read more

Latest Forum Discussions

See All

You can now travel to Skyrim in The Elde...
The Elder Scrolls: Legends' new expansion has opened up Skyrim's craggy mountains and snowy plains for exploration today. Heroes of Skyrim is out now, adding a bunch of new Skyrim content to Bethesda's recent CCG. [Read more] | Read more »
High-stakes solitaire game 'Missile...
Missile Command and Solitaire might seem like an odd couple, but indie developer Nathan Meunier has brought them together to create his first game, Missile Cards, which launched on the App Store today. [Read more] | Read more »
Eos 2 (Music)
Eos 2 2.0.2 Device: iOS Universal Category: Music Price: $5.99, Version: 2.0.2 (iTunes) Description: | Read more »
Supercell celebrates Hay Day's comm...
Before there was Clash Royale or Clash of Clans, there was Hay Day. Now, Supercell's first game is celebrating its fifth anniversary, and the developer is commemorating the event with this touching new video. Supercell picked one long-running Hay... | Read more »
Dive into epic summer adventure with Oce...
Summer may be the best time to enjoy ocean adventures, and now you don’t even have to leave the comfort of your own home, thanks to the folks at Joycity, creators of Oceans & Empires. The old-timey naval MMO is getting a sizable new June Grand... | Read more »
Missile Cards (Games)
Missile Cards 1.0.9 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0.9 (iTunes) Description: "Missile Command meets Solitaire...only with more doomlasers, death, and explosions." | Read more »
Collect mini assassins in 'Assassin...
Assassin's Creed is traveling back in time to the Spanish Inquisition for its latest mobile entry, Assassin's Creed Rebellion. The game is giving the series a look that's a huge departure from its past design, recreating classic characters in a... | Read more »
Animal Crossing is still coming to mobil...
Animal Crossing is still coming to mobile in 2017, according to aWaypointinterview with Nintendo. Announced in 2016, the game was delayed without a defined release window. However, fans of Nintendo's fantasy slice of life game won't have to wait... | Read more »
Ravenscroft 275 Piano (Music)
Ravenscroft 275 Piano 1.0.0 Device: iOS Universal Category: Music Price: $35.99, Version: 1.0.0 (iTunes) Description: Experience the splendor of a Ravenscroft Grand with the most realistic sounding piano ever created for iOS. Launch... | Read more »
This War of Mine gets a new ending and m...
This War of Mine just got a big new update, featuring free DLC that adds a new ending to the game, among other exciting changes. The update is celebrating the game's two-year release anniversary. Apart from the new ending, which will be quite... | Read more »

Price Scanner via MacPrices.net

Will iPad Running iOS 11 Be The ‘Ute’ Of The...
Steve Jobs’ analogy comparing iPads and PCs to cars and trucks respectively is seven years old but still stimulates discussion and debate. Appearing on an All Things D panel in 2010 shortly after the... Read more
Free CarePassport App gives Patients control...
Boston based CarePassport is on a mission to enable patients to take control of their medical records by allowing patients to aggregate, store, share and manage all their medical data including... Read more
Western Digital Launches New My Passport Ultr...
Western Digital Corporation has expanded its WD brand My Passport portable drive line with the redesigned My Passport Ultra drive. In addition to a new metallic look, the drive offers intuitive WD... Read more
Clearance 2016 13-inch MacBook Pros available...
B&H Photo has clearance 2016 13″ MacBook Pros in stock today for up to $210 off original MSRP. Shipping is free, and B&H charges NY & NJ sales tax only: - 13″ 2.9GHz/512GB Touch Bar... Read more
Apple Releases iOS 11 Public Beta; How To Get...
The official release of Apple’s latest mobile operating system iOS 11 is vaguely slated for the fall, but as of June 26, ordinary users can download an iOS 11 public beta. To download the iOS 11... Read more
Extend Life of MacBook Pro Retina 2.0TB With...
MacSales.com/Other World Computing has announced availability of the new OWC 2.0TB Aura Pro Solid State Drive for mid-2012 to early 2013 Apple MacBook Pro with Retina display. One of the fastest... Read more
BBEdit SummerFest 2017 Discount Ends Friday,...
You can get 20% off BBEdit for a limited time in Bare Bones Software’s http://www.eastgate.com/Tinderbox/Specials/SummerFest.html?mc_cid=f2101ca260&mc_eid=[UNIQID]SummerFest 2017 sale and... Read more
Use Apple’s Education discount to save up to...
Purchase a new Mac using Apple’s Education discount, and take up to $300 off MSRP. All teachers, students, and staff of any educational institution qualify for the discount. Shipping is free: - 15″ 2... Read more
Clearance 27-inch 3.3GHz 5K iMac available fo...
Amazon clearance 27″ 3.3GHz 5K iMacs (MK482LL/A) available for $1799.90 including free shipping. Their price is $500 off original MSRP, and it’s the lowest price available for this model from any... Read more
13-inch 1.8GHz/256GB MacBook Air on sale for...
B&H Photo has the updated 2017 13″ 1.8GHz/256GB MacBook Air (MQD42LL/A) in stock and on sale for $1129 including free shipping plus NY & NJ tax only. Their price is $70 off MSRP. Read more

Jobs Board

*Apple* Online Store WW Customer Insights -...
…with data mining tools: R, SAS, etc.Experience with common shell scripting tools: unix, python, apple script, Swift etc. Apple Online is one of the largest and Read more
Engineering Project Manager, *Apple* Online...
…the electronic commerce (eCommerce) systems and solutions that enable and support the Apple Online Store (AOS) - one of world's largest online retail businesses, Read more
*Apple* News Product Marketing Mgr., Publish...
…organizational consensus on strategy and vision for publisher tools, authoring, and Apple News Format.Carries this strategy and vision across the organization to Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
Security Data Analyst - *Apple* Information...
…data sources need to be collected to allow Information Security to better protect Apple employees and customers from a wide range of threats.Act as the subject matter Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.