Retro Fireworks Mac OS

  • Jun 24, 2016 Cool Retro Term is available for Mac OS X and for Linux, which makes the most sense given the Terminal replacement, but it’s open sourced too just in case you want to try and port it over to your TI-85 graphing calculator or Nokia flip phone. Cool-Retro-Term from the developer on Github here.
  • You can play retro games on macOS with an emulator. An emulator imitates a console gaming system, allowing you to play console games on your Mac. With the instructions below, you can play retro games on macOS from NES, SNES, Nintendo 64, Game Boy, and a ton more. Get an Emulator.

Several weeks ago I ordered a retro Mac CPU upgrade on eBay that I wanted to write an article about. I was very excited to get my hands on one; I’ve been keeping an eye out for years, and now I’d finally be able to run some tests and get an idea as to how much it helped the performance of several retro Macs I own. When it arrived I was both excited and disappointed. When I ordered the the card, the item pictured showed a necessary PDS Adapter to make it work with one certain model. I just assumed that the adapter was included with the card; I was wrong.

I reached out to the seller. I told him that I was a columnist for Low End Mac and that I purchased the card so I could write an article about it. Mark (the seller) reached back to me and was happy to send the adapter my way. He mentioned that he was with MacEffects, a new LLC that makes special clear injection molded cases for retro Apple computers. He asked me if I’d like a new MacEffects Clear Case for one of my Mac SEs to review. I accepted his offer, as I knew that their Clear Cases looked great; I’d actually been wanting to write a review on one for a while, but I hadn’t been able to justify the expense.

MacEffects Clear Case for ADB Mouse

Big selection of used software and games for Mac OS. Some of the titles are from the 90's so please check if software / games are compatible with your Mac. Cool Retro Term is available for Mac OS X and for Linux, which makes the most sense given the Terminal replacement, but it’s open sourced too just in case you want to try and port it over to your TI-85 graphing calculator or Nokia flip phone. Cool-Retro-Term from the developer on Github here.

Mac

A few weeks later, Mark reached back to me and let me know that he had finally received more stock of both the Macintosh Clear Case and a clear ADB Mouse to match. He told me that he had sent them my way, and a few days later I received the Clear Case and the mouse. When I opened them up, I was absolutely blown away by the amazing quality of the plastics that were used. This is not some cheap lightweight plastic that feels like you’re going to break it just by looking at it the wrong way; it is very solid and has a good weight to it. The ADB Mouse also feels very nice, and it’s awesome to see the Axis Wheels spinning as you use the mouse.

WARNING!

Mac

Installing the components of your Macintosh into the clear case is not for the faint of heart. It requires that you discharge the CRT and remove High Voltage components from the original case. Please do not try this at home if you’re not familiar with how to safely work with High Voltage Electronics. If you do decide to take this project on, please remember to safely discharge the CRT in your machine before you attempt to remove any components. DO NOT leave your machine plugged in at any time when the back cover has been removed.

Once you have the CRT discharged the removal of components from the old case and installation in to the new Clear Case is very easy. You have to be careful of the CRT’s neck, you don’t want to bang it on anything. If you do the CRT could be damaged.

Once I had played with the mouse for a moment, I decided it was time to take apart one of my Mac SEs and transfer all of the components in to the new Clear Case. Using my special Extra Long T-15 screwdriver and my MacCracker, I was able to crack open my Mac SE. I discharged the CRT, and proceeded to remove all of the components. I installed the CRT first, as I didn’t want it laying around, the rest of the components you have to install in reverse order.

The clear case came with a new cooling fan that is clear and has a green LED that turns on when you turn on the computer. It really has a stunning look to it when it is all assembled. I really like how the whole thing looks when it is all put together. As I said before, it has a quality feel to it. Actually, I’d go as far as to say the plastic actually feels better than the original case plastics did. I love being able to see the Hard Drive Rotor moving as the drive seeks, and the green LED in the included clear cooling fan really makes the whole thing stand out when it’s turned on.

There are a few things that I’d like to see in future revisions of the Clear Case. I love that it includes a clear programmer’s switch with the Reset and Interrupt icons on it, but the case itself does not have any port icons over the ports on the back; I’d like to see those added.

MacEffects Clear Case for ADB Mouse

I’d also like to see a brightness indicator icon below the brightness knob, and possibly a place to put the Apple Logo from the original case. The only real complaint that I have with the setup is that there is no easy way to remove the mouse ball for cleaning. The bottom housing for the mouse is a solid piece, meaning you have to take the whole mouse apart in order to clean it.

Aside from the very minor criticisms that I had for the kits, these are incredibly solid products that I would encourage anyone who is in the Retro Apple Community to consider these products. They make your existing device feel that much more special and will give you many more years of enjoyment.

Thank you, Mark, for giving me the opportunity to review these products. They are extraordinarily excellent, and I can’t wait to see what you have in the pipeline.

I am still working on the articles about the card that I bought that led to this article. It is a Power Macintosh Upgrade Card, and the articles will be about various Macs that it is compatible with – and the performance boost you get from it. I’ll also be writing at least one new article about the x200 series of Macs. Based on new data, I’ve been led to believe that the reputation they have may not be deserved. I look forward to setting the record straight.

Retro Fireworks Mac Os Catalina

Until next time, thank you for reading and have a great day!

A couple of weeks ago RetroShare has released version 0.6.6. But while download page offers quite a variety of pre-built packages for different operating systems, there is no 0.6.6 build for Mac OS (only 0.6.5 is available).

I found this peculiar, so I decided to try to build it from sources myself. It also seemed like a good opportunity to finally try RetroShare, as it has been available for more than 15 years, and I’ve heard many good things about it.

At the moment Mac OS section on download page looks like this:

Let’s take a cheeky look into the building process then.

RetroShare is based on Qt and currently it uses qmake. So as the very minimum, aside from cloning the repository, you need to have Qt installed in your system. If anything, I built mine from sources, but it will most likely just as well work if you’ll get it using official installer.

Just in case, here’s my environment:

The base application is extendable with plugins, and there is a qmake configuration option for building those too. I’ll describe the process for both variants: with and without plugins.

Building without plugins is easier, because it has less 3rd-party dependencies. And I would say, 3rd-party dependencies is the main difficulty of building RetroShare from sources.

Without plugins

There is some documentation on the matter (more about that later), from which I got to know that I need to install the following dependencies:

SDK resolving issue

Let’s try to configure it now:

So right from the very beginning you are getting this fantastic error in your face. Smells like something is hardcoded somewhere.

And indeed, if you open /path/to/retroshare/src/retroshare.pri, there is this weird block at the line 129:

This hardcoded list of versions doesn’t look good at all. And no matter what values I provided to CONFIG, the configuration was always failing with the same error. Certainly can’t tell what grand plan original developer had behind it, but it definitely does not make sense to me. So I ended up editing this block manually like this:

Why 11.1? Because that’s what xcrun reports in my system, and apparently that’s what is getting checked against during configuration.

Now the project configures fine, so we can build:

Missing OpenSSL headers paths

But during the build I got these errors:

That can be solved by explicitly providing paths to OpenSSL headers:

By the way, Homebrew had a warning about something similar:

and I tried to do so in my ~/.bash_profile:

but that didn’t help. And providing paths via qmake CLI parameters did help, so that’s what I will be doing going forward.

Missing dependencies

Next error I got was this:

That is solved by installing RapidJSON:

Then there was this error:

That is solved by installing SQLCipher:

Missing paths to linked libraries

After that everything finally built, but failed on linking stage:

That is because providing just include paths is not enough, you also need to provide paths to linked libraries binaries. So, the final sequence of commands to configure and build RetroShare (without plugins) is this:

Features

You might want to enable/disable certain application features:

  • by default autologin is disabled, so you’ll need to enter your password every time you launch RetroShare, which is certainly more secure but also rather annoying
  • another example is retroshare_service, which, if I understood correctly, allows RetroShare to run “headless” (without GUI). It is enabled by default, and I don’t need it
  • not sure what use_native_dialogs does, but it is disabled by default, and having enabled it I seem to get more responsive GUI dialogs in the application

So my configuration looks like this:

Building takes about 8 minutes on my Mac, and as a result I get a working RetroShare application in /path/to/retroshare/src/build/retroshare-gui/src/RetroShare.app.

With plugins

RetroShare has some plugins as part of the main repository, and there are also plugins in separate repositories (for example, RetroChess).

To enable building RetroShare with plugins, you need to set this:

If you want to build more plugins than just the ones from main repository, clone their repositories and copy sources to /path/to/retroshare/src/plugins folder and add them in plugins.pro:

Before building you need to install required dependencies:

The last one, OpenCV, is one crazy package. It drags a whole bunch of dependencies of its own, which in turn drag a lot more on their own, including by the way Qt. You can see the full list for yourself:

Anyway, having installed all the dependencies, you can now build the project. Needless to say, you’ll face errors about missing headers and linked libraries, so to save you some time, here are all of them:

…Yet, you will still get errors, though different ones this time. Here’s the first one:

This one is happening because RetroShare doesn’t link to one of the libraries from OpenCV. To find out which one, you can google for cv::VideoCapture and discover that it’s part of videoio, so you need to add that missing link with LIBS+=-lopencv_videoio.

Next error was more difficult to figure out:

Luckily, I’ve encountered something similar (not exactly) before, so soon enough I suspected that it’s yet again Mac OS providing an obsolete version of a library. And indeed, after I installed and used the latest XSLT library:

the problem was gone. So, here’s the final configuration command (with the features I’ve enabled):

Having built such a configuration, aside from RetroShare.app you will also get plugins built in /path/to/retroshare/src/build/plugins/**/lib/*.dylib. These files needs to be either bundled into RetroShare.app/Contents/Resources/ or copied to /Users/YOURNAME/.retroshare/extensions6/ (or whichever path is set in Preferences). Having done that, when you launch RetroShare next time, it should discover the plugins:

What about building from Qt Creator

You might ask, why building with bare qmake from CLI, why not building from Qt Creator?

Well, first of all, building from CLI is just faster and actually more convenient. But also here’s what I get when I try to build the RetroShare project from Qt Creator:

And I’ve no idea what this is about. I have CMake discoverable in my PATH, and also it is added in Qt Creator settings, and also I can build other CMake projects from Qt Creator just fine. Yeah, no idea.

Bundling resources

There are certain styles files which need to be bundled in the application bundle. Not sure why those are not added to resources.

So, if you won’t bundle those, the application will still work, but you will be missing some skins/styles in the list of available style options, for example Bubble style for chats:

Bundling stuff into application bundle on Mac OS with qmake is done via QMAKE_BUNDLE_DATA. In /path/to/retroshare/src/retroshare-gui/src/retroshare-gui.pro on line 275 there is a block for macxscope - that’s where the application icon is getting bundled, by the way. To bundle styles (or other resources) too, add the following lines:

Having configured and built the application, you should get the following contents in your RetroShare application bundle:

Making a DMG

If you’d like to distribute your build to other people, you’ll need to bundle required libraries and frameworks and also make a DMG.

Why DMG? No particular reason, really. It can just as well be a ZIP archive, but DMG seem to be more common for distributing applications on Mac OS.

In order to find and copy all the required libraries and frameworks, I would recommend to use macdeployqt. Actually, I would not recommend it, as it seem to bundle some redundant things as well, for example Virtual Keyboard, which I don’t think is used in RetroShare. But still - it does the job, so it’s easier to copy all the dependencies with macdeployqt than to find and copy them manually. Though RetroShare plugins do need to be copied manually.

Conveniently enough, macdeployqt can also make a DMG. So here’s the entire chain of commands for deployment:

Homebrew is awesome

I must say, Homebrew is an absolute life savior. Getting (and building) all the dependencies without it would take dramatically more time. Or maybe I would have just given up halfway.

About RetroShare

I’ve never used RetroShare before, and here’s what I can tell after using it for a week.

Documentation isn’t great

Documentation, and namely Mac OS build instructions, is scattered across several places. I could count at least five:

  1. Three documents (and a patch) in the main repository:
    • MacOS.10.6_RS_Compilation_Instructions.txt
    • MacOS_X_InstallGuide.md
    • OSX_RS_Compilation_Instructions.txt
    • retroshare-mac-build.patch

The manual for building is not very helpful, which is why I created this very article. I would even say, the instructions from manual are half-baked and written in a negligent manner, there are a lot of typos and it even contains nonsense like:

In QtCreator Option Git add its path:

That is from the section about building RetroShare on Mac OS.

General documentation content also seems to be outdated. There are screenshots of menus and settings that no longer exist, and some instructions refer to no longer existing things as well.

Surely, I would be happy to make my contribution and update the documentation with my instructions, and also to fix typos and to make it look better. But given its current state, it just feels like my efforts would go into a void. At the very least documentation should be concentrated in one place first.

Inconsistent connectivity

RetroShare requires you to have “friends” - other people’s nodes who added you as their “friend”. There are no servers: basically everyone is a server, and together they form a network.

That is the first difficulty you will encounter, but that is not an issue, and actually that is one of the main features of RetroShare. It’s even awesome. Also, luckily enough, I’ve got invites from several people, so I had at least something to connect to.

The real issues started to appear later: I tried running RetroShare on Windows, Mac OS and Linux, and I had different experience on all three.

Windows

On Windows I seemed to get connected at first, and I was even getting forums, chats and so on, but the very next day it just stopped: I am no longer able to see any forums, and all the chats I entered the day before now have no people in them.

The NAT and DHT indicators show the following:

And neither of them ever got green.

Mac OS

Then I tried it on Mac OS, as by that moment I’ve managed to build it. There it was better, and I get forum posts, chats and so on.

The NAT and DHT indicators, however, are all red:

Plus Network settings seem to have some troubles getting external IP, though I am not sure if it matters:

Linux

Finally, I tried RetroShare in a virtual machine running Linux, and would you look at that:

Everything is green!

No idea, how come the same thing works so differently across different platforms in the same network. I even tried forwarding ports on my router - that didn’t change a thing: still, only Linux had green DHT indicator, and Windows was still having troubles getting content.

Overall

As much as I wanted to like it, as a user, I can’t say that I will use RetroShare every day or rely on it for something important. It could be that this is because I am still an unexperienced user, but it has been more than a week as I’m trying to get familiar with it, and now I am about to give up.

The idea is certainly great, no doubt about that, especially looking at how “normal” internet is going to shit, but implementation is certainly not perfect. Aside from inconsistent connectivity, there are random (but seldom) application crashes, GUI can freeze on certain actions, notification flags on tabs do not disappear even though there are no unread items left, etc - all that results in not a great user experience.

Mac Os Versions

On the bright side, though, the repository is rather active, so hopefully it all will get better eventually. Maybe I will even find some time to help fixing those issues.

Retro Fireworks Mac Os Catalina

And as a developer, I must admit the fact that (despite the length of my article) RetroShare actually builds just fine on Mac OS, and almost all the troubles I had were coming from missing dependencies. Given the cross-platform nature and the size of the project, this is quite impressive, especially considering that Mac OS is not its primary target platform.

Here are magnet links for my RetroShare 0.6.6 builds on Mac OS:

Mac Os Download

Let me know if it fails to run on your system, because I suspect that macdeployqt doesn’t actually pack all the dependencies.