最終更新: 2018-02-15T12:43+0900
メモ帳でできるように……と書くために今試してみたのだけど、挿入されたのが「00:49 2017-12-17」だった。なんだこのキモい並びは。年月日も時刻もフォーマットこそ OSの地域と言語のオプションに従ってはいるものの、その前後関係が決定的にYMD文化圏のそれではない。
メモ帳はどうでもいい。サクラエディタには「日付を挿入」コマンドと「時刻を挿入」コマンドがある。それぞれのフォーマットをカスタマイズできる。日付を挿入するコマンドを F5 に割り当てて、そのフォーマットを「yyyy-MM-dd HH:mm」にすればいいと考える。できない。日付書式と時刻書式が分かれていて同時に使用できないせい。
ソースを見れば一目瞭然だけど、Windowsが GetDateFormatと GetTimeFormatという2つの APIを公開していて、サクラエディタのコマンドがその薄い被せ物だというのが、おそらくこの不便な分離の理由。くっつけたっていいでしょ。
カスタムフォーマットの場合に限り GetDateFormatと GetTimeFormatの両方の APIを呼ぶ。そうでないと OSの設定で日付フォーマットを「'hh' yyyy'年'M'月'd'日'」みたいにしたときに hh がそのまま hh とは表示されなくなる。
書式文字列と書き込み先が同じポインタでも問題ないみたい。フォーマットに対して書き込み文字数の方が多い場合があるとしたら問題になるだろうか。ANSI版で日本語の曜日が書き込まれるときとか?
GetTimeFormatは時刻だけしか対応していなくて、日付を整形したい場合はGetDateFormatというAPIを使うことになります。これが2つに分かれている所為で、両方を一度に整形したい場合に実に厄介な問題が発生するんですが、まぁそれは置いておいて………。
置いておかないで。知りたい。
「tt」が「AM」になるのか「午前」になるのかは、実行したOSの設定次第です(日本語設定なら「午前」とか)。
それでは、日本語環境で「t」はどうやって表示されるのでしょう。
「AM」が「A」、「PM」が「P」に対応するみたいで、なんとなく「t」は「tt」の短縮形じゃないかと想像付くんですけど、果たして、「午前」「午後」はどのように短縮されるんでしょうかね…。
wwwwww
20170908p02で書いた明示的デストラクタ呼び出しと placement new の組み合わせがここでも。そんなにありふれてるかなあ。
20170908p02で結論が出てるけど、一時オブジェクトとスワップするのが最適解。ナンセンスに思えた途中の試行が実はいいセンいっていたという。さらに最近の C++ なら素直に移譲コンストラクタが使える(らしい)。
約200行ほどの関数です。別にどうと言うことの無い関数なんですが(個人的には幾つかに分割したいんですけど)、何故にinlineになっているのかっ!
インライン展開するには大きすぎるから。って言うか、そもそもインライン展開する必要ないでしょ。プログラムの起動時に1回だけ呼ばれる初期化用の関数なんだし。
自分がわりと inline を、とりあえず付けておこうっていう人間かな。このファイル(脳log[20170908p01] ツールチップ>a.patch)の中を inline で検索すると知れると思うけど。
基準は、今考えてるんだけど、以下のいずれか。
最近 C++ In Depthシリーズを読み返してるんだけど、そして実はシリーズに見えてシリーズとは書かれていないんだけど、『Efficient C++』の中に「シングルトン関数」という呼び名で3番目の関数のインライン考が載せられていた。同意するかは読み手に任されるとしても、そういう考えのもとにインライン化することもあるってことで。
2番目の「実質的に小さい」は、よく考えると嘘かもわからんね。呼び出す関数の引数が多かったり、呼び出すつもりの関数がインライン展開されたりすると、ソースコード上の見た目以上に大きいということがわりにありそう。
他の関数を真似してinlineをつけたんだと思うけど、「訳がわからんけど動くからそれで良いや」的にコンパイラを誤魔化すだけのテクニックなんて使用厳禁っ!
最近知ったんだけど、inlineを付けるだけで関数の多重定義によるリンクエラーが避けられるらしいですねえ>20170410。そういうことをしだすと、「道具として使う」を通り越して乱用の域に達してると思う。
pHを測る機械があって、ピッと簡単に数字が出るのかは実際に使わなかったから知らないけど、「原理も知らずに……(もにょもにょ)」というぼやきが聞こえてきたのが印象に残ってる。原理を知らないと手段の優劣も限界も条件にあった適切な選択もわからんもんね。
道具ってのは元をたどれば誰かが目的のために最適な手段を求めた結果として生み出された経緯があると思う。予め用意された道具を使っているだけではアマチュアの域を出られないのではなくて? 知の高速道路に関係する話。開拓者とフォロワーの違い。大多数にはハイアマチュアも届かない存在かもしれんけど。
日付と時刻を同じひとつのフォーマットで指定できる。そのソースがたぶんここ>「HRESULT tePSFormatForDisplay(PROPERTYKEY *ppropKey, VARIANT *pv, DWORD pdfFlags, LPWSTR *ppszDisplay)」
[hHmst]が時刻を表すフォーマット文字としてリストでき、[dMyg]が日付の文字としてリストできる。時刻文字が見つかると日付文字が見つかるまで、日付文字が見つかると時刻文字が見つかるまで API 呼び出しを遅延し、切り替わる部分まで(もしくは文字列末尾まで)をフォーマット文字列として、対応する API を呼び出している。どんなフォーマットでも最低1回は GetDateFormat を呼び出してるっぽいのは、2値だと if 文の条件がシンプルに書けるからか。必ず1度は、それも最初に日付フォーマット文字に出くわすだろうという推定は、すごく妥当だと思います。
これが真摯な対応というべきものか。俺は2割のコーナーケースを捨てて過度にシンプルな解法を選びがち。
先に挙げたコードの通りの回答。たぶん AM
とか PM
とか Thu
とか Sat
とか Oct
とかに展開された文字列が再度フォーマット文字として解釈されてしまうんだろう。まじめに挙げると問題のあるロカールでは問題ばかりだった。
矩形選択時は左右カーソル移動で上下行に移動しないように変更」これはもう実装されたと思う。考えることは一緒か。■「
矩形選択中の[BackSpace]動作を変更。(旧)選択範囲を削除。(新)選択範囲の直前(左端)を削除。用途:矩形選択→複数行入力→[BackSpace]→複数行"再"入力」 用途が書いてあるのがポイント高い。実際役に立つと思う。[BackSpace]と[Delete]を使い分けられる人なら受け入れられるだろう。自分は元に戻したときに矩形選択が維持されるようにしてるから、[BackSpace]ではなく[Ctrl]+[Z]してから再入力できてる>20110612p01。■「
水平スクロールバーの最大値をメモ帳風に。1.ファイル読込み時、最大行長にあわせて水平スクロールバーの最大値を決定。2.編集時、↑を超える行長になったら水平スクロールバーの最大値を更新。3.全行削除時、水平スクロールバーの最大値をリセット」というのはこれだと思う>[r1653]。コミッタはご本人ではない。最長の行が縮んだときに更新しないのはフルスキャンを嫌ったのだろう。■「
再読み込み後も「編集」-「元に戻す」を実行可能に。」 これどうやるの? ひょっとしてアンドゥ履歴ってキーマクロ形式でシリアライズできる? あとはどこに保存するか。desktop.ini も Thumbs.db も嫌われるけど。■「
全角文字を含むURLも色分け/ジャンプできるようにしてみました」 今は正規表現で「URL」を定義できたはず。■「
読み取り専用で開いたときの制限を変更。(旧):上書き保存不可, すべての編集系コマンド実行不可。(新):上書き保存不可」 うん、自分もそうしてる。マクロに
Editor.ReadOnly()
と Editor.ViewMode()
があって、明らかに2つの指す概念は異なるのに、どっちもビューモードを設定するのが残念。今に至るも両者が区別されてないんだよね。■「矩形選択後に正規表現置換で改行を削除するとカーソル位置,選択範囲表示が変になる場合があったのを修正」 最近いじってたところ。
const TCHAR *strstartp, const TCHAR *targetstartp, const TCHAR *targetendp
の他に const TCHAR *strendp
に相当する引数が必要なんだけどそれは targetendp
と一体化してるっぽい。Bregexp.dll for SAKURA が BREGEXP.DLL を拡張して派生せざるを得なかった(※想像)残念な省略がまたしても。BoSubstExW の登場が待たれるな。<Meryみたいに直に叩いてフル機能を使えばって話でもあるんだけど、テキストエディタのユーザーが Windows版バイナリを手に入れる方法がね。■「この条件さえ満たせば、BSDライセンスのソースコードを複製・改変して作成したオブジェクトコードをソースコードを公開せずに頒布できる。」ライセンスさえ明示すればただコンパイルしたバイナリを再配布することが可能だろうか<そもそも Meryがやってる。sourceforge.netをただのファイル置き場にできる?svn st
がくっそ速い。■メタデータの保存場所がワーキングコピーのルートディレクトリのみになったようで(gitと同じ?)、ワーキングコピーのサブディレクトリをよそに持ち出して .svn が邪魔ということがない。svn export
しろって話なんだけど、目の前にあるものを使いたいこともある。嘘をつきました。そういう時しかない。■1.6系の svn diff
に不満があって、比較される複数のファイルの並びが一定しないということがある。パッチの第1版を svn diff で作成します。変更されたファイルの差分が a.cpp b.cpp c.cpp の順番で現れます。それが第2版では b.cpp c.cpp a.cpp になったりする。パッチの比較ができない。■何かいい diff はないかなーという探索活動の中で行われた Subversionのアップデートだけど、改善はありましたかね。■俺もシンプルな解決法が欲しいよ>「Can I get svn diff in sorted order? - Stack Overflow」