Using VMware Fusion 5 to run Windows 8 Pro 64-bit in a bootcamp partition from the Mac has been amazing. One bit of trouble recently popped up for me, though, when we moved offices to a new location. My VMWare networking uses Bridged mode, and everything works perfectly at home. But at the office, I was getting nothing but the warning that I had no internet.
I called VMware support, and they did a laudable job in getting back to me over the phone and trying to help, but in the end, the recommended solution was either to run under Bridged mode with the Firewall disabled, or use NAT. I figured out after the call that the reason disabling the Firewall made things work is that it would then not use the option to Block connections. So my search started to figure out how to change the network type from Public to Private.
The final answer was rather simple. Launch explorer, select Network on the left, and then click the yellow bar that says to Enable sharing. Doing that marked the network as Private. I seem to recall being offered the choice to turn sharing on or not the first time I hit it at the new location, so I probably said Don't Share, which resulted in the network being marked as Public, which meant the Firewall rules pertaining to Public were applied, and why I couldn't access anything.
Here are my final notes on getting HockeyApp
to integrate nicely with MonoTouch:
- Use the MonoTouch bindings from GitHub. I cleaned up the sample to demonstrate what happens when an exception is thrown, and also added the DebugLogEnabled property binding in case things aren't working. Also be sure to go through the readme in the github project to add the EnableCrashReporting() method.
- Place a copy of the HockeySDKResources.bundle in the root of your project directory (a bundle is really a directory of files). Select the Display All Files option from the Solution (not the project).
- If adding a reference to the precompiled HockeyApp.dll, and if you get build errors when compiling to device (error MT5202: Native linking failed. Please review the build log), add the following to your Additional mtouch arguments: -gcc_flags "-framework CoreGraphics -framework CoreText -framework QuartzCore"
- Be sure to do a Rebuild All, as the UUID of the dSYM doesn't update unless you do this, which will cause problems symbolicating the crash log.
- Make certain that your info.plist has a "Bundle versions string (short)" (CFBundleShortVersionString) entry.
- HockeyApp deals with unhandled exceptions. So if you had put a try/catch around your Main.cs, that exception will not be unhandled and will not get processed by HockeyApp. Ask me how I know... :(
I was using TestFlight for my existing Xamarin MonoTouch project, but it didn't really do what I wanted. I wanted something that would centralize crash reporting for me when something went wrong with my app after it was downloaded from the App Store. TestFlight never really worked for that (at least for me). It allowed me to send beta versions of my app, which was cool, but I wanted a bit more.
I downloaded the binary version of HockeyApp
and also set up an account and an app on hockeyapp.net
. I got it working by:
- Add the reference to the pre-compiled HockeyApp.dll
- Place the bundle in the root of my project directory (a bundle is really a directory of files). The instructions on that site no longer work to just Include in Project, so I did an "Add Files from Folder" option
- I was sure to add the code to make things crash proof
- I was getting a build error when compiling to device (error MT5202: Native linking failed. Please review the build log. Which was really due to Undefined symbols for architecture armv7:
"_CTFontCreateCopyWithAttributes"). I fixed that by adding the following into my Additional mtouch arguments:
-gcc_flags "-framework CoreGraphics -framework CoreText -framework QuartzCore"
After all of that, I was able to get things compiled. I then followed the deployment suggestions from the readme.md page on the github project.
I was able to upload the dSYM.zip and ipa files, and get the email invite and tried to download the app. I initially received an "Unable to install the app at this time" error message. That led me to believe the device wasn't imported, so I tried to import using the hockey app bookmarklet. It brought me a list of existing UDIDs back to the hockey app site, but the import did not save those devices. I need to drill down on this some more to get a solid list of steps needed to release both beta and app store versions.
I'd also like to be able to have logging data stream to the hockeyapp server and correlated to a specific device. And I'm not 100% certain I've done things properly, but this was a good cookbook on what I did to get things at least uploaded to the hockeyapp server. If I can get this to work, it's well worth the $10. per month.
I wanted to breathe some new life into my Bootcamp running Windows 7 32-bit on my MacBook Pro. I figured the easiest way to do this was to move the entire bootcamp partition over to a brand new Samsung Electronics 840 Pro Series 2.5-Inch 128 SATA_6_0_gb Solid State Drive MZ-7PD128BW
. It looks like the best option to get a second hard drive in a MacBook is the MCE Optibay
Unfortunately, it's not as easy as just throwing the second drive in, moving the partition over and being done. For starters, the Bootcamp Assistant does a little bit more than simply add a Windows partition for you, so creating your own partition didn't seem to work. Bootcamp Assistant did create a parition for me on my second drive, but I then had a partition on both drives named "BOOTCAMP". I then decided the machine was ready for Windows 8 64 bit, but unfortunately, I was greeted with a black screen and blinking cursor when trying to boot off the external USB drive to finish off the Windows install.
After all of that pain (and various utilities to clean up the bad things I did in the last paragraph, like: /sbin/fsck -fy), and some failed attempts to use VMWare Fusion to restore the prior BOOTCAMP partition, I found this thread in macrumors.com
. I'm reposting a portion of the brilliant post be richlee111 that finally got things working. Granted, it was a lot of opening and closing of the MacBook, and I had to deal with a stripped screw on one occasion, but everything worked beautifully thanks to his advice:
So if you want to run 2 HDDs from your Macbook, with one being for boot camp, the steps below worked for me:
- Take out the MCE optibay and put back the superdrive into its original location.
- Install the drive that you want to install boot camp into the original HDD drive bay.
- Stick the original OSX install disk into the superdrive and first install Mac OSX onto it.
Realize that you are only doing this to run the boot camp install and will be wiping it out later.
- After you have installed OSX, go through the initial setup and be at the desktop. Run the
boot camp assistant and go through with the install and have it create a partition for boot camp.
At this point, it doesn't really matter how big/small the patition is for Windows. You can adjust
and resize the partition during the Windows install process for choosing the location and partition.
- Go through finishing the boot camp assistant in OSX, stick your Windows install CD into the drive
and boot into it. This time it should work.
- Once you have completed the Windows installation and you are at the Windows desktop, stick the
Mac OSX cd back into the drive and run the setup.exe. This will install all the drivers that will
make it recognize all the Mac hardware, etc.
- Finally, take out the CD drive, swap back in the optibay, put your boot camp HDD in there, and
put back the HDD with your Mac OS.
Other tidbits of trivia and lessons learned during this process:
- To get the iSight camera working with Windows 8 inside VMWare Fusion, select the Virtual Machines | USB & Bluetooth | Connect Apple FaceTime HD Camera menu item.
- Creating a dmg backup of your Bootcamp partition is not recommended. There is no way that I found to restore the dmg to the new partition (yes, I tried the dd command, but it did not end well).
- This is a good resource page to show how to deal with updating drivers (if you need it), what to do about Retina macs, and even a hint to deal with a freezing problem in Windows 8 if it affects you.
- Installing IIS in Windows 8
The end result is incredible. It is lightning fast, and my first impressions of Windows 8 are extremely positive.
After getting my WHS Console issue resolved
, I noticed that my Shared Folders tab listed several of my folders as "Failing (Check Health)". That led me to look at the Server Storage tab where one of the drives was reported as "Missing". The drive was dead. Not to worry, I thought, because I had Duplication turned on for those folders that I really did not want to lose (e.g. music, photos).
I spot-checked several items in those folders and noticed that they weren't accessible. I tried to copy them off of the WHS server to my local PC and was greeted with a "Error 0x8007048F: The device is not connected." message. I had removed the bad drive from the WHS and rebooted, and still, things looked bad.
Thanks to a post in the We Got Served Forums
, the answer was to simply go to the WHS Console, Server Storage tab, and Remove the bad drive via software as well. After doing that, I had to let WHS do its thing, but after a couple of hours, all of my files are fine, the folders are listed as "Healthy", and I have a new hard drive on the way.
What I thought was a potentially devastating issue turned out to be handled easily, reliably, and gracefully through WHS. What an awesome device.
I've had pretty good luck with my WHS (v1) system. It's been mostly fire and forget. I've had good success restoring 2 computers from the automatic backup. In short, I've been pretty happy. This is the first of 2 posts of problems I've now had with it. One minor (this one), and the next, potentially devastating.
For a while now, I haven't been able to select the "Windows Home Server Console" menu to connect to my WHS Console. It would sit there forever and just error out.
I was able to RDP in to the box, though, and from there, I was able to get to the C:\Documents and Settings\All Users\Application Data\Microsoft\Windows Home Server\logs\console.*.log file. In there, I saw this:
[11/15/2012 5:32:17 PM 182c] WARN : CreateAndConnectRdp - admin name is WHS\Administrator.
[11/15/2012 5:32:17 PM 182c] Connecting to WHS at path C:\Program Files\Windows Home Server\
[11/15/2012 5:32:28 PM 182c] WARN : Disconnected, reason=2, extended reason=0
I then noticed this file on the server was blank: c:\program files\windows home server\homeserverconsole.exe.config. I deleted it, and rebooted the server, and I was able to connect to the Console again. What I found after being able to connect, though, was most troubling. More on that later...
The new DisplayMode engine in ASP.NET MVC 4 is rather nice. By default, it will detect whether you come in from a mobile device or a desktop machine, and load up a specialized view for you based on that detection.
For example, if you were trying to navigate to http://www.example.com/Players from an iPhone, the default behavior will be to look for Players\Index.Mobile.cshtml, followed by Players\Index.cshtml. Whichever it finds first will be the view that gets used. Note that this also requires you to have a _Layout.Mobile.cshtml file.
This is great for new projects, but I have a non-trivial app with a lot of views that have been built over the years using the technique by Scott Hanselman
. That approach would look for the file in Players\Mobile\Index.cshtml. I was not looking forward to renaming all of those files.
In order to use my already existing file structure, I added one class:
public class SubfolderDisplayMode : DefaultDisplayMode
public SubfolderDisplayMode() : base("Mobile")
// Be sure to use 51degrees.mobi, or a good browser capabilities file
ContextCondition = (context => context.GetOverriddenBrowser().IsMobileDevice);
protected override string TransformPath(string virtualPath, string suffix)
var dir = VirtualPathUtility.GetDirectory(virtualPath);
var filename = VirtualPathUtility.GetFileName(virtualPath);
return VirtualPathUtility.Combine(dir, "Mobile/" + filename);
Registered it in my Globabl.asax.cs:
DisplayModeProvider.Instance.Modes.Insert(0, new SubfolderDisplayMode());
It works very well, and I can come back and rename those files later.
Also be sure to put a call to @Html.Partial("_VewSwitcher") somewhere in your desktop _Layou.cshtml file so the user can get back to the mobile version of the site.
Updated on 11/9/12 to clean the sample code up a bit
After installing the RTM version of VS2012 last week and upgrading my project, I noticed that my web site was broken. The real culprit seemed to be that Microsoft changed how bundling works (the process of combining and minifying resources like js script and css files) between the RC version and the RTM version. For an excellent background on what this feature can do for you, see this tutorial
It turns out my real problem was with Kendo. They don't provide non-minified files in the trial version, so the new bundling mechanism wasn't including the minified assets, which meant the Kendo minified assets were getting stripped out when I was trying to run under debug. (Reference here
). I was able to use the work-around offered on this thread, and things started working again.
However, there are a few wrinkles when using the bundling code, so I thought I'd capture my experiences here. For example:
It seems that there is quite a bit of friction in the current version of the bundling framework. Fortunately, it resides in the Optimization assembly which can be upgraded independently of the entire MVC framework. I hope Microsoft releases an update very soon to overcome these obstacles. I have every reason to believe that they will since I'm seeing the author of this assembly
answering tons of questions on StackOverflow.