_bstr_t は何気に便利だな、とか。

昔書いてたメモ帳から転記。今更感がマックスの、備忘録メモ。

ちょこっとCOMクライアントとかのテストコード書く際に、ワイド文字列(主にWindowsで言うところのUNICODE)と、マルチバイト文字列の相互変換が煩わしいときが多々ある。

まぁ、変換用に関数一個作っとけばいい話なんですが・・・。正直、Win32 APIのMultiByteToWideChar/WideCharToMultibyte は使いたくない。理由はただ一つ。コイツらの使い勝手の悪さときたらどうしようもない。ってとこ。引数が5個も6個もいるし、何より、最低限2回のAPIコールが必要。↓のような感じ。

/*
  マルチバイト文字列 ==> ワイド文字列
*/

#include <windows.h>

//ヒープを使用。
PWSTR AllocString(PCSTR& pStr)
{
  PWSTR pWStr = NULL;
  SIZE_T cchWStr = 0;

  if(pStr == NULL)
    goto cleanup;
  
  cchWStr = MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED,pStr,-1,NULL,0);

  if(cchWStr <= 0)
    goto cleanup;

  if((pWStr = (PWSTR)HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,cchWStr*sizeof(WCHAR))) == NULL)
    goto cleanup;

  if(!MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED,pStr,-1,pWStr,cchWStr))
    FreeString(pWStr);

cleanup:
  return pWStr;
}

//ヒープ解放
BOOL FreeString(PWSTR& pWStr)
{
  BOOL bRet = FALSE;

  if(pWStr && (bRet = HeapFree(GetProcessHeap(),0,reinterpret_cast<PVOID>(pWStr))))
    pWStr = NULL;

  return bRet;
}

でも、こんな感じだと、明らかにテストしたいコードより遙かに長いコード行・・・何か腹立つ。
お金の掛からないVC++ Express Edition を使っていて贅沢は言えませんが・・・なんかで代用できないものか・・・。

で、最近MSDNのドキュメント見てて気付いた。
_bstr_t クラスって便利やないかい!、と。

もともとは、COMでの文字列表現、BSTR型のラップするスマートポインタみたいなクラス。BSTR型はちょっと特殊で簡単に言えば文字列の長さとバッファを合わせたような型。BSTR型をPWSTR型と混同しているケースを極たまに見ます。まぁ、そんなことはどうでもよく。

_bstr_t クラスは、PCWSTR,PCSTRの両方をコンストラクタで受け付けてくれます。しかも、キャスト演算子をオーバーロードしてくれてるので、引数にPCWSTRもしくはPCSTRが必要なAPIや関数にそのまま放り込めます。

※注意点
これらのキャスト演算子は内部バッファへのナマのポインタを返すので、やたらめったら使用すると、おそらくどこかでクラッシュするバグを抱えるでせう。

#pragma comment(lib,"user32.lib")
#pragma comment(lib,"comsuppw.lib")

#include <windows.h>
#include <comutil.h>
#include <tchar.h>

int APIENTRY _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow)
{
  _bstr_t bStr("テストでげす");
  
  //ANSI版
  MessageBoxA(NULL,bStr,"ANSI版",MB_OK);

  //UNICODE版
  MessageBoxW(NULL,bStr,L"UNICODE版",MB_OK);
  
  return 0;
}

/*
ANSIバージョンのAPIは、内部でマルチバイト文字<==>ワイド文字の変換を行って
UNICODE版APIをコールしているだけのようなので、このコード自体無意味。
*/

スコープを抜けると自動的にSysFreeStringをコールしてくれるみたいなので、解放処理も必要なし。

万歳!

インスタント検索を完全に無効にしたいんだけど・・・

普段PCのブラウザは、Google Chromeを使ってます。でも、バージョンアップするのが速すぎのは別に良いとして、ユーザビリティーに関して細かな変更をチョコチョコ行うので、あれ?と思うことが多々ある。

それとは別に・・・

最近になってようやく気づいたんですが、Google検索のインスタント検索がいつのまにか有効になってしまってます。一旦クッキーとか全部履歴を削除して、検索設定を下記のようにしても、設定を無視してインスタント検索されてしまいます。

普段、検索結果の表示件数を100件にしていますが、インスタント検索が有効になってしまうと、10件になってしまい非常に使い勝手が悪くなってしまう。

これって、どうやればインスタント検索が無効になるのかなぁ・・・???

Google Chrome(17.0.963.46)自体の設定で、「オプション >基本設定 > インスタント検索を有効にして・・・」 のチェックを外すと・・・アドレスバーから検索する分にはインスタント検索をオフにすることができました。

が・・・ちょっと使っていると、またインスタント検索が有効になってたりする(`Д´)
フツーに検索結果さえ出してくれればいいんだけど。。。

一太郎は要らないがヒラギノフォントは欲しい!

ちょっと前にジャストシステムから「一太郎バージョンアップ」のDMが来てたんです。が、一太郎自体もう何年も使っていないので、DMをそこらへんに放ったらかしにしてました。

で、さっきたまたまそのDMを開いて見てたんですが・・・、プレミアムバージョンだと、なんと、「ヒラギノフォント」の基本6書体標準搭載って書いてあるじゃないですか!

これは欲しい。だって、普通に「ヒラギノフォント」を手に入れようとしたら、MACを一台買うか、もしくは、ン万円も出してフォント自体を買わないといけない。でも、今更一太郎は買うのも・・・どうせ使わないし・・・ATOKは2年前にバージョンアップして、今のところ不自由ない。

ムムム・・・・。

子供の頃、オマケが欲しくてお菓子を買った、あの感覚に似てるな・・・。

どうしよう。。。15,700円か・・・。ATOKとヒラギノフォント目当てで15,700円。。。。

ムムム・・・

今度の一太郎はEPUB形式で保存できるのか・・・別においら、物書きじゃないし・・・。

今週末リリースか・・・どーしょっかなー・・・。