GithubHelp home page GithubHelp logo

carabina / hypercardpreview Goto Github PK

View Code? Open in Web Editor NEW

This project forked from pierrelorenzi/hypercardpreview

0.0 1.0 0.0 12.03 MB

Little app to see HyperCard stacks in Mac OS X. Programmed in Swift.

Swift 99.58% Objective-C 0.19% HTML 0.24%

hypercardpreview's Introduction

Screenshot

Download v1.3 (September 29, 2018)

Mac OS 10.12 minimum

This application displays HyperCard stacks in Mac OS X.

The binary format of HyperCard stacks has been retro-engineered by numerous people, and now it is known with pretty good reliability. If you want to learn more about it, see the format description.

HyperCardPreview only displays the stacks, it does not edit them, it does not execute them. To do that you have to use a emulator: SheepShaver, Basilisk or vMac. Or try stacks in the HyperCard Stack Archive

It makes the seeing the stacks an experience of the old days. The look is very close to the original one, with bitmap fonts, old-style scrollers, aliasing. In the Home stacks the look is accurate to the pixel, as in most Apple stacks, but less so if there are colors, and not at all if there are XCMDs.

Features:

  • very accurate display,
  • declares the stacks as its own files, so they have an icon again in the Finder,
  • can open stacks from both HyperCard v 2.x and v 1.x,
  • can open stacks with private access by hacking the encryption.
  • can export texts, images and sounds.

How to use it

Browse with Keyboard

Change Card: press an arrow key, or page up / page down / home / end

Show/Hide All Cards: press enter or return

Browse with Trackpad

Change Card: scroll left or right, or swipe

Show/Hide All Cards: pinch

Display Button/Field Info

Get Button Info: press command-option (like in HyperCard), buttons are colored in blue and you can click on one to display the info.

Get Field Info: press command-option-shift (like in HyperCard), both fields and buttons are colored in blue and you can click on one to display the info.

Get Info of a Covered Button or Field: right-click somewhere on the card, the list of the buttons and fields at that location appears, from the frontmost to the outmost. That way you can get info about a button or field even if it is covered by the others.

Technical details

JSON Export

The format of the JSON file is here.

Sounds

Some sounds can't be read: they beep instead of play, and they can't be exported. That's because HyperCardPreview can't read compressed sound resources, only uncompressed ones.

Colors

Colors of the AddColor XCMD are technically handled but cause troubles. For example the stack "Color Tools" is not good at all because the display is managed partly by scripts, which are not executed. Besides, macintosh pictures (PICT resources, which have a complex format designed by Apple) are still accepted by Mac OS X but with restrictions, especially there is no transparency.

Stacks v1.xx

Stacks of HyperCard 1.xx are handled but not accurarely displayed. The problem is that HyperCard changed some display settings between versions 1.xx and 2.xx, for example the text field margins, and HyperCardPreview doesn't handle that. In fact, HyperCardPreview displays v1.xx stacks as if they were just converted to v2.xx and were displayed the v2.xx way.

Scripts

HyperCardPreview doesn't display other scripts that HyperTalk.

It doesn't execute any script or any XCMD or XFNC.

Deprecation

HyperCardPreview doesn't use any deprecated API, so its future is bright.

That means that old APIs had to be partially re-coded: resource fork reading, resource management, text display, bitmap fonts, 1-bit imaging.

HyperCardPreview signing

It seems that I can't have a developer ID without paying a fee to Apple. And I'm not ready to do it just for that little soft.

Changes since version 1.0

Changes in v1.3

The whole structure of a stack can be exported to a JSON file.

Images of cards and backgrounds can be exported.

The resources of a stack can be inspected and exported (icons, pictures, sounds and the rest).

Changes in v1.2

The application is now signed.

Bug fixes in the card list.

Changes in v1.1

Now the scroll fields can be scrolled, and the pop-up buttons can be popped up.

The tools to explore the stacks have been added, it is far more convenient.

Glitches corrected in stacks:

  • vector fonts are now well displayed,
  • AddColor is (nearly) handled,
  • stacks with private access can be opened

…plus a lot of other little bug fixes and optimizations.

Unfortunately, the QuickLook plug-in had to be removed because it is not handled in Swift. A Swift plug-in may work but just if it is the only one plug-in in Swift in the OS, elsewhere it crashes the QuickLook platform, so it is risky.

The future of the app

It won’t grow much larger than that.

I don’t intend it to edit stacks and execute scripts, it would make an app several times more complex, and as long as nobody is using the stacks anymore, I don’t see the point.

But if you have bugs with some of your stacks, please inform me.

Can HyperCard be ported to Mac OS X?

If you have that in mind, check Stacksmith.

In my opinion, HyperCard might be re-invented, but with a big restriction on the use cases. HyperCard had too many of them and that’s why it was so difficult to explain when people asked what it did. For example, HyperCard had cards and backgrounds, intended for display of content (text, images, databases), which is now perfectly handled by websites.

hypercardpreview's People

Contributors

johnlunney avatar pierrelorenzi avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.