Macsurf,macOS 9 的“现代”网络浏览器
Macsurf, "modern" web browser for macOS 9

原始链接: https://github.com/mplsllc/macsurf

**MacSurf** 是一款处于早期开发阶段(early-alpha)的网页浏览器,旨在将现代网络体验带入运行 Classic Mac OS 9 的 PowerPC 架构电脑。通过利用 NetSurf 的原生移植版以及自定义的 **macTLS** 库,MacSurf 使老旧硬件(例如 233 MHz 的 G3 iMac)能够在无需外部代理的情况下,与安全网站建立原生的 TLS 1.2/1.3 连接。 虽然它还不是一款适合“日常使用”的浏览器,但它是一项重大的工程里程碑,首次在 OS 9 上实现了对 CSS Grid、自定义属性和 ES5 JavaScript 的原生支持。该项目使用 C89 和 CodeWarrior 8 构建,利用 Carbon、QuickDraw 和 Open Transport 等原生 Mac OS 技术,在早已被认为无法浏览网页的硬件上渲染布局、渐变、动画和透明效果。 截至 1.3.1 版本,MacSurf 支持高级加密曲线和多曲线 ECDHE,使得像 68kmla.org 这样的网站能够完整呈现。尽管它在处理复杂的现代 Web 应用(如 React)或高负载媒体时表现吃力,但它为复古电脑爱好者提供了一个功能性门户,让他们能在 25 年前的原始硬件上探索当代网络。

抱歉。
相关文章

原文

MacSurf

The modern web, on a 25-year-old Mac.

MacSurf is a web browser for Classic Mac OS 9 PowerPC. CSS3, ES5 JavaScript, PNGs with alpha, running on a G3 iMac.

Latest release License Open issues Stars Mac OS 9 PowerPC Built with CodeWarrior Carbon API CSS coverage JavaScript engine Discussions


Mac OS 9, meet TLS — Native, no proxy needed.


Warning

MacSurf is early alpha. It runs, it renders, it talks TLS 1.2 natively to real HTTPS sites (as of May 2026), and it executes JavaScript on a 233 MHz G3. That doesn't mean it's ready for daily driving — most of the modern web still won't work in it. Heavy SPAs, modern CSS features we haven't shipped, missing form interactions, slow JS on real hardware. Plenty is rough.

But it's ready for people to try. If you've got a Power Mac G3 or G4 sitting around, please load it and see what breaks. Bug reports and screenshots from real hardware are exactly what this project needs. Contributors welcome too — there's a lot of CSS, DOM, and JS surface left to fill in, and the code is plain C89 (the same C you'd have written in 1999). See docs/status.md for the current punch list.

What you can expect: hand-built pages, retro-style sites, a respectable chunk of CSS Grid, native HTTPS with the full Mozilla CA bundle, and the strange thrill of running ES5 JavaScript on a PowerPC. What you shouldn't expect yet: smooth browsing on arbitrary modern sites, video, audio, WebGL, service workers, anything heavy on React.

First numbered release was 0.1a1 in May 2026. Latest is v1.3.1 — Forward, refined (2026-05-29): multi-curve ECDHE in TLS 1.3. macTLS now offers X25519, secp256r1 (P-256), and secp384r1 (P-384) in supported_groups, with HelloRetryRequest handled cleanly so servers that mandate a NIST curve can drive the rekey. That unblocks 68kmla.org — one of the largest active Classic Mac communities, XenForo on nginx with NIST-only curve config — which now renders fully on a G3 iMac via TLS 1.3 + P-384. Predecessor v1.3 — Forward landed the first native TLS 1.3 implementation on Classic Mac OS, ever — RFC 8446 handshake on BearSSL primitives, ChaCha20-Poly1305 + AES-128-GCM, verified end-to-end on a G3 iMac by Cloudflare's /cdn-cgi/trace, Akamai, BrowserLeaks, and How's My SSL. The day before, v1.2 — Sealed closed the documented insecure-stub entropy hole with macEntropy v1.0, wired POST forms through both fetchers, and shipped a real download manager. Full v1.3.1 notes in docs/release-notes/MacSurf-1.3.1.md. Predecessors: v1.3 notes, v1.2 notes, v1.0 notes.


The web outgrew Classic Mac OS twenty years ago. Modern HTTPS finished it off around 2016. Pull a G3 or G4 out of the closet today and it can barely reach a single live website.

MacSurf is an attempt to fix that on the machine itself — no screenshot proxy, no remote terminal trick. A native browser, built with the tools that were already on the platform: CodeWarrior, Carbon, QuickDraw, Open Transport. Real CSS3 layouts and real JavaScript, running inside the 64 MB memory floor of a 1999 iMac. Since late May 2026 it speaks TLS 1.2 directly to the modern web through macTLS, a BearSSL-based stack that ships inside the browser binary with 121 trust anchors from the Mozilla CA bundle. No proxy needed anymore.

As far as we can tell, this is the first serious NetSurf port to Classic Mac OS, and the first browser ever shipped on Mac OS 9 with native CSS Grid, CSS custom properties, and ES5 JavaScript.


Each shot below is a real milestone, captured on a Power Macintosh G3 running Mac OS 9. The fix-number annotations match this repo's commit history.

JavaScript Hello World on Mac OS 9
v0.2: JavaScript on Mac OS 9
First real-world JS-bearing page. Duktape 2.7.0 ES5 evaluating live: Math.sqrt, JSON, ES5 array methods.
CSS transform rotate, scale, translate
fixes73: CSS transforms
Native transform: rotate() / scale() / translate(). Integer Q15 sin/cos table, no FPU dependency, arbitrary angles on QuickDraw.
CSS radial gradients
fixes74d: radial gradients
2-stop radial gradients via concentric PaintOval stack. 16 levels smeared on decode. Shape + position keywords parsed.
CSS animations: wiggle, swing, slow spin
fixes77: CSS animations
Linear ping-pong animation player on top of fixes73 rotation. Wiggle, swing, and full 0°→359° spin.
PNG image with transparency on Mac OS 9
fixes79b: PNG transparency
QuickTime Graphics Importer feeding the NetSurf image content handler. PNG + GIF + BMP, all with real transparency.
CSS word-break and overflow-wrap
fixes136: word-break / overflow-wrap
word-break: break-all, keep-all, white-space: nowrap, legacy word-wrap: break-word. URL-style aggressive wrapping.
CSS z-index stacking contexts
fixes147: stacking contexts
CSS 2.1 painting order. Opacity, transforms, and explicit z-index all create new stacking contexts, properly painted on real hardware.
CSS Grid column placement
fixes151: CSS Grid column placement
grid-column: span N, 1 / -1 full-row hero, positional start / end, span + auto-wrap. Real Grid layout on OS 9.
MacSurf 1.0 rendering home.macsurf.org
v1.0: Showcase
The new tool-belt toolbar, razor-sharp URL field, and matted icons rendering home.macsurf.org on a G3 iMac running OS 9.2.2. Native HTTPS via macTLS direct to the origin, server-rendered portal, true-colour images end to end.

ComponentLanguagePurpose
browser/ C (C89, CW8) NetSurf fork with a macos9 frontend. Carbon for the UI, QuickDraw for drawing, Open Transport for networking, Duktape for JS.
proxy/ Go (stdlib only) The old TLS-stripping HTTP proxy. Largely retired now that macTLS works natively, but still useful as a fallback or on machines without CarbonLib. Mac sends plain HTTP, proxy fetches via HTTPS, returns plain HTTP.
macTLS
sibling repo
C (CW8) Native TLS 1.2 library for OS 9 — modern HTTPS straight from the Mac, no proxy required. BearSSL underneath, 121 trust anchors baked in.

Rendering pipeline

  • Full NetSurf fetch → parse → cascade → layout → plot
  • Native libcss with var() resolution
  • QuickDraw plotters with an offscreen GWorld back-buffer

CSS — around 150 properties consumed in layout

  • Custom properties and var()
  • Flex: justify-content, align-content, order
  • Grid V1 plus grid-template-columns/rows, gap
  • border-radius, box-shadow, opacity
  • Linear and radial gradients
  • text-shadow, text-overflow: ellipsis
  • transform (rotate, translate, scale)
  • z-index stacking contexts (CSS 2.1 painting order)
  • CSS counters, viewport units, aspect-ratio
  • Font-family aliases for sans, serif, monospace

Full CSS status →

JavaScript — Duktape 2.7.0, full ES5

  • Closures, prototypes, regex, JSON
  • Promises (polyfill), recursion, Mandelbrot
  • About 6 seconds for ackermann(3,7) on a 233 MHz G3

Images — all five formats

  • PNG with real per-pixel alpha (lodepng + CopyMask)
  • GIF with palette transparency
  • JPEG, BMP, TIFF

Networking

  • Open Transport TCP, plain non-InContext calls
  • HTTP/1.1 + chunked + keep-alive + 3xx follow
  • Connection pooling, 15-second no-progress timeout
  • HTTPS via macTLS (default) or the Go proxy (fallback)

Browser chrome

  • Address bar, back / forward / reload / home
  • Status bar, page-info, multi-window
  • Smooth scroll bar, keyboard scrolling

Latest is MacSurf v1.3.1 — Forward, refined (2026-05-29): multi-curve ECDHE in TLS 1.3. X25519, P-256, P-384 all offered in supported_groups, with HelloRetryRequest handled cleanly so NIST-only servers like 68kmla.org can pick a curve and drive the rekey — the forum now renders fully on a G3 iMac via TLS 1.3 + P-384. Predecessor v1.3 "Forward" shipped the first native TLS 1.3 on Classic Mac OS; v1.2 "Sealed" closed the entropy hole and wired POST forms + the download manager; v1.0 "Showcase" was the chrome-redesign release; v0.6.2 "Speed-Run" was the cold-load speedup (mactrove.com 30+s → ~2-3s); first numbered alpha at v0.1a1.

  • MacSurf.sit — the v1.3.1 binary, ready to run. Expand on Mac OS 9.1+ with CarbonLib 1.5+ and launch.
  • Building from source: clone the repo, then on the Mac side open browser/netsurf/frontends/macos9/MacSurf.mcp in CodeWarrior 8 and choose Build. v1.3.1 is a transparent macTLS engine upgrade — no MacSurf project file changes vs v1.3, just rebuild against the updated macTLS tree. v1.3 builders pulling onto a v1.2 workspace need to add four macTLS files to enable TLS 1.3: bearssl/src/ec/ec_c25519_m15.c, os9/ostls_tls13_keysched.c, os9/ostls_tls13_record.c, os9/ostls_tls13_handshake.c. v1.2 builders on a 1.0 workspace need to add desktop/download.c to the project file list. The earliest release also ships a BuildPack.sit snapshot with the CW8 project pre-wired, but current builds work straight from a fresh clone.

Earlier alpha notes if you want context: docs/release-notes/MacSurf-0.1a1.md.


MacSurf is built on Mac OS 9 with CodeWarrior 8 Pro (8.3 update). The source is cross-compile-clean against Retro68 PowerPC GCC, which is what we use for fast Linux-side syntax checks.

A single Go binary. No config files. No dependencies beyond stdlib.

cd proxy
go build -o macsurf-proxy
./macsurf-proxy
联系我们 contact @ memedata.com