To list global NPM packages:
npm list -g --depth=0
To update the globally installed NPM packages:
sudo npm -g update
Like the title says - just a whole lot of stuff.
To list global NPM packages:
npm list -g --depth=0
To update the globally installed NPM packages:
sudo npm -g update
A few notes for me...
print “Properties are:”, obj.__dict__
I’ve got a Mac which is running a Windows 10 Parallels VM that I use for Microsoft Visual Studio 2015 development. I’m using the Express Edition of VS2015. If I code up a web application (maybe a web service or an ASP.NET Web API) and run it in the IDE, I can hit it from the browser on that machine at http://localhost:57292/api/test.
How can I consume this Windows 10 web service from my Mac?
First of all I need to know the IP address of my Win 10 machine. Fire up a “cmd" prompt and run “ipconfig”. In my case the "IPv4 Address” is 10.211.55.4
To avoid having to remember and type this address, let’s add it to the “hosts” file on the Mac. Do this from the Terminal on the Mac using “sudo vi /private/etc/hosts” and add in a new line such as:
10.211.55.4 win10
Sadly, if I fire up Safari on my Mac and try to browse to http://win10:57292/api/test or (http://10.211.55.4:57292/api/test), it won’t find the page. There are two reasons for this:
Fortunately, both of these can be overcome thanks to the handy tips on this webpage. Read it for the details, but for my quick reference I need to do the following on the Windows 10 machine:
<binding protocol="http" bindingInformation="*:57292:localhost" />
<binding protocol="http" bindingInformation="*:57292:10.211.55.4" />
NB.This step needs to be done for each new website.
>netsh http add urlacl url=http://10.211.55.4:57292/ user=everyone
>netsh advfirewall firewall add rule name="IISExpressWeb" dir=in protocol=tcp localport=57292 profile=private remoteip=localsubnet action=allow
Now, firing up Safari on the Mac and browsing to http://win10:57292/api/test should work!
If you are getting a 503 error, it could be because IIS Express hasn’t restarted and picked up the new website location. Check in the Windows System Tray for the IIS Express icon and click on it to see when there IP address is listed under the application:
If it isn’t there, stop VS2015, exit IIS Express if still running (using the ‘Exit' option above), and restart your VS2015 application.
NB. Updated for Windows 10/VS2015 here.
I’ve got a Mac which is running a Windows 7 Parallels VM that I use for Microsoft Visual Studio 2013 development. I’m using the Express Edition of VS2013. If I code up a web application (maybe a web service or an ASP.NET Web API) and run it in the IDE, I can hit it from the browser on that machine at http://localhost:57017/api/test.
How can I consume this Windows 7 web service from my Mac?
First of all I need to know the IP address of my Win 7 machine. Fire up a “cmd" prompt and run “ipconfig”. In my case the "IPv4 Address” is 10.211.55.3
To avoid having to remember and type this address, let’s add it to the “hosts” file on the Mac. Do this from the Terminal on the Mac using “sudo vi /private/etc/hosts” and add in a new line such as:
10.211.55.3 win7
Sadly, if I fire up Safari on my Mac and try to browse to http://win7:57017/api/test or (http://10.211.55.3:57017/api/test), it won’t find the page. There are two reasons for this:
Fortunately, both of these can be overcome thanks to the handy tips on this webpage. Read it for the details, but for my quick reference I need to do the following on the Windows 7 machine:
<binding protocol="http" bindingInformation="*:57017:localhost" />
<binding protocol="http" bindingInformation="*:57017:10.211.55.3" />
NB.This step needs to be done for each new website.
>netsh http add urlacl url=http://10.211.55.3:57017/ user=everyone
>netsh advfirewall firewall add rule name="IISExpressWeb" dir=in protocol=tcp localport=57017 profile=private remoteip=localsubnet action=allow
Now, firing up Safari on the Mac and browsing to http://win7:57017/api/test should work!
On my Mac, I needed to reduce the size of some scanned PDF documents - without changing the scanner settings and rescanning them. I tried to Export from Preview as a PDF using the “Reduce File Size” filter, but it made the files too blurry.
Googling revealed a nice solution, which allows you to add your own custom “Reduce File Size” filters to Preview’s Export window. Once you’ve done this once, you can use them whenever you need to:
I am going to repost how to do this here, so I don’t lose it. The original can be found at: http://hints.macworld.com/article.php?story=20120629091437274
I was never satisfied with results of "Reduce File Size" Quartz filter when trying to make some PDFs smaller before sending them by e-mail. It made them too small, and the graphics were fuzzy.
I eventually found where these filters are:
/System/Library/Filters
I was delighted to find out they're XML files easily editable with TextEdit (or any other text editor). I also found why this particular filter makes quite unusable PDFs, as these parameters were just too low:
Compression Quality 0.0
ImageSizeMax 512
So I copied this file to my Desktop, and then made two more copies of it, and called them Reduce File Size Good, Better and Best. Then I changed the parameters of each file to 0.25, 0.5 and 0.75 for Compression Quality, and used these three values for ImageSizeMax:
842 (that's A4 at 72dpi)
1684 (A4 at 144dpi)
3508 (A4 at 300dpi)
Finally, I changed the default string for the Name key at the end of each file to reflect the three settings, so they display the names I have given them in the menu.
Then I copied them to a /Library/Filters folder I created (for some reason, ~/Library/Filters doesn't work in Lion) and now when I open a picture or PDF in Preview, I have the option of four different qualities for reduced file sizes.
As an example, I have a JPEG of scanned A4 invoice at 300dpi and it's 1.6MB. When exporting to PDF in reduced size, the file is only 27 KB and it's quite unusable - very fuzzy and hard to read. The Good one is much easier to read, slightly fuzzy and still only 80 KB. Better is 420 KB and clear, and the Best is 600 KB and almost as good as the original even on a laser printer.
A few notes:
Public Property Let MyProperty(sValue As String)
...
End Property
Public Property Let MyProperty(ByVal sValue As String)
...
End Property
[id(0x68030000), propput]
HRESULT MyProperty([in, out] BSTR* );
[id(0x68030000), propput]
HRESULT MyProperty([in] BSTR );
Public Sub TestMethod(ByVal sArgIn As String, Optional sArgOut As String)
HRESULT TestMethod(
[in] BSTR sArgIn,
[in, out, optional] BSTR* sArgOut);
.\MyDll13.IDL(30) : warning MIDL2400 : for oleautomation, optional parameters should be VARIANT or VARIANT * : [optional
] [ Parameter 'sArgOut' of Procedure 'TestMethod' ( Interface '_TestClass' ) ]
using System.Runtime.InteropServices;
namespace MyDllNet
{
[ProgId("MyDll.TestClass")]
[ComVisible(true)]
[Guid("D860A2A8-5003-4714-AE59-918FE2B0FC42")]
public class MyProxyClass : MyDll13ModifiedTA.TestClass
{
public string GetVersion()
{...}
public void TestMethod(string sArgIn, [OptionalAttribute]ref string sArgOut)
{...}
}
}
C# DLL implements IDL with optional BSTR* argument | ||
---|---|---|
VB6 Binding | Pass One Arg | Pass Two Args |
Early Binding | OK | OK |
Late Binding | OK | Error "Type mismatch" |
public void TestMethod(string sArgIn, [OptionalAttribute]ref object sArgOut) {}
C# DLL implements IDL with optional VARIANT* argument | ||
---|---|---|
VB6 Binding | Pass One Arg | Pass Two Args |
Early Binding | Error clr.dll APPCRASH | Error clr.dll APPCRASH |
Late Binding | OK | OK |
Imports System.Runtime.InteropServices
<ProgId("MyDll.TestClass")>
<Guid("D860A2A8-5003-4714-AE59-918FE2B0FC42")>
Public Class MyProxyClass
Implements MyDll13TldAssembly.TestClass
Public Function GetVersion() As String Implements MyDll13TldAssembly._TestClass.GetVersion
...
End Function
Public Sub TestMethod(ByVal sArgIn As String, Optional ByRef sArgOut As String = Nothing) Implements MyDll13TldAssembly._TestClass.TestMethod
...
End Sub
End Class