プログラミング言語 D (D Programming Language) について語るスレッドです。
■本家
http://dlang.org/ - 公式(英語)
http://www.kmonos.net/alang/d/ - 公式の和訳 (やや古いので注意)
https://issues.dlang.org/ - D言語バグ報告
https://github.com/D-Programming-Language - D言語開発リポジトリ
■Wiki
http://wiki.dlang.org/ - 公式Wiki
http://dusers.dip.jp/ - D言語友の会(日本語フォーラムあり)
■プログラミング言語D (TDPL: The D Programming Language)
Andrei Alexandrescu 日本語版
http://www.shoeisha.co.jp/book/detail/9784798131108
ソース貼付サイト http://dpaste.dzfl.pl/
<$><$> https://www.bountysource.com/trackers/383571-d-programming-language
■前スレ
D言語 Part33
http://toro.2ch.net/test/read.cgi/tech/1396145538/
■過去スレ、関連スレ
http://makimo.to:8000/cgi-bin/search/search.cgi?q=D%8C%BE%8C%EA&sf=2&all=on&view=table&shw=5000
D言語 Part34©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
2015/01/25(日) 12:07:29.52ID:gAd5OZDm
278デフォルトの名無しさん
2015/11/21(土) 14:42:18.71ID:8z9xCqW5 Hoge という型と Fuga という型があって
Hoge[Fuga] hage;
という連想配列は定義できるみたいなのですが
Any という任意の型があるとして
Any[Any] moge;
みたいな連想配列は作れますか?
Hoge[Fuga] hage;
という連想配列は定義できるみたいなのですが
Any という任意の型があるとして
Any[Any] moge;
みたいな連想配列は作れますか?
279デフォルトの名無しさん
2015/11/21(土) 14:47:56.80ID:8z9xCqW5 ちなみに
["A": "B", "C": 3, 4: "E"]
みたいなのを作りたいのです
["A": "B", "C": 3, 4: "E"]
みたいなのを作りたいのです
280デフォルトの名無しさん
2015/11/21(土) 15:28:20.57ID:8z9xCqW5 Object[Object] moge = ["A": "B", "C": 3, 4: "E"];
これでだめでした orz
これでだめでした orz
281デフォルトの名無しさん
2015/11/21(土) 22:31:38.28ID:jpeEJ7vY import std.variant;
auto moge = [Variant("A"): Variant("B"), Variant("C"): Variant(3), Variant(4): Variant("E")];
とかいうダサい感じのしか思いつかない。
auto moge = [Variant("A"): Variant("B"), Variant("C"): Variant(3), Variant(4): Variant("E")];
とかいうダサい感じのしか思いつかない。
282デフォルトの名無しさん
2015/11/21(土) 23:35:17.00ID:BXVotCtM283デフォルトの名無しさん
2015/11/22(日) 12:23:27.44ID:rXOpUu6m >>278
型付き言語に喧嘩売ってんのか
型付き言語に喧嘩売ってんのか
284デフォルトの名無しさん
2015/11/22(日) 12:42:54.55ID:rXOpUu6m >281
ダサくてよければ
Variant[Variant] constructor(T...)(T plist){
Variant[Variant] result;
foreach(ref p; plist) result[new Variant(p.keys[0])] = new Variant(p[p.keys[0]]);
return result;
}
Variant[Variant] moge = constructor(["A": "B"], ["C": 3], [4: "E"]);
試してないけど
ダサくてよければ
Variant[Variant] constructor(T...)(T plist){
Variant[Variant] result;
foreach(ref p; plist) result[new Variant(p.keys[0])] = new Variant(p[p.keys[0]]);
return result;
}
Variant[Variant] moge = constructor(["A": "B"], ["C": 3], [4: "E"]);
試してないけど
285デフォルトの名無しさん
2015/11/22(日) 18:10:01.30ID:K6EhBG35 引数が1個ずつ別のAAになってる…?
きもちわるすぎる
きもちわるすぎる
286デフォルトの名無しさん
2015/11/22(日) 18:34:22.00ID:uPJ5yBy3 import std.variant;
import std.stdio;
Variant[Variant] makeTable(T...)(T p) {
static assert(T.length%2 == 0);
Variant[Variant] t;
foreach (i, ref v; p) {
static if (i%2 == 0) {
t[Variant(p[i])] = Variant(p[i+1]);
}
}
return t;
}
void main() {
auto t = makeTable(1, 2, "hoge", 123.2);
writeln(t);
}
import std.stdio;
Variant[Variant] makeTable(T...)(T p) {
static assert(T.length%2 == 0);
Variant[Variant] t;
foreach (i, ref v; p) {
static if (i%2 == 0) {
t[Variant(p[i])] = Variant(p[i+1]);
}
}
return t;
}
void main() {
auto t = makeTable(1, 2, "hoge", 123.2);
writeln(t);
}
287デフォルトの名無しさん
2015/11/22(日) 19:32:11.41ID:QPIcOg4c288287
2015/11/22(日) 19:46:28.38ID:QPIcOg4c やっぱコード追加で。連投御免。
http://dpaste.dzfl.pl/19cc3ea3bd0d
http://dpaste.dzfl.pl/19cc3ea3bd0d
289デフォルトの名無しさん
2015/11/23(月) 14:44:46.01ID:5yZmzCJ8 mixin使ったら負けな感じ半端ない
290デフォルトの名無しさん
2015/11/23(月) 23:06:50.39ID:zlo1l7ot やろうとしてること自体闇魔術臭いしわりと妥当なのかもしれない
291デフォルトの名無しさん
2015/11/24(火) 12:03:53.42ID:Dj+m8Q01292デフォルトの名無しさん
2015/11/25(水) 00:37:26.01ID:euvQfHeH >>291
どんなコードが生成されるか知らないのでベンチとって見た結果
http://dpaste.dzfl.pl/85212474e9f0
281: TickDuration(3595337)
284: TickDuration(9347285)
286: TickDuration(4128184)
288: TickDuration(3554533)
どんなコードが生成されるか知らないのでベンチとって見た結果
http://dpaste.dzfl.pl/85212474e9f0
281: TickDuration(3595337)
284: TickDuration(9347285)
286: TickDuration(4128184)
288: TickDuration(3554533)
293デフォルトの名無しさん
2015/11/26(木) 17:49:18.83ID:yeqvnwwH Dでcomのclientを書こうとして付属のサンプルソースを試したら動作しました
wshサーバーをdispatchしてEcho('hoge')みたいなポップアップを出したいのですが
サンプルをどのように書き直せばよいのですか
wshサーバーをdispatchしてEcho('hoge')みたいなポップアップを出したいのですが
サンプルをどのように書き直せばよいのですか
294デフォルトの名無しさん
2015/11/26(木) 17:58:08.82ID:yeqvnwwH 途中まで書いたコードです
extern (Windows) HRESULT CLSIDFromProgID(const wchar *, CLSID *);
const string wsh = "WScript.Shell";
interface IWSH : IUnknown {
extern (Windows) int Echo();
}
DWORD dwVer = CoBuildVersion();
HRESULT hr = CoInitialize(null);
hr = CLSIDFromProgID(wsh.toUTF16z(), &clsid);
IWSH pIWSH;
hr = CoCreateInstance(&clsid, null, CLSCTX_ALL, &IID_IUnknown, &pIWSH);
// FAILED(hr)の判定コードは省略していますがここまでは動作しているようです
// pIWSHに値は入っているようですが次の場所でAccessViolationします
pIWSH.Echo();
CoUninitialize();
pIWSH.Echo(); の行をコメントアウトすると何も起きませんが正常に完了します
あと
&IID_IUnknown
のところを
&IID_IDispatch
に書き換えてもだめでした
extern (Windows) HRESULT CLSIDFromProgID(const wchar *, CLSID *);
const string wsh = "WScript.Shell";
interface IWSH : IUnknown {
extern (Windows) int Echo();
}
DWORD dwVer = CoBuildVersion();
HRESULT hr = CoInitialize(null);
hr = CLSIDFromProgID(wsh.toUTF16z(), &clsid);
IWSH pIWSH;
hr = CoCreateInstance(&clsid, null, CLSCTX_ALL, &IID_IUnknown, &pIWSH);
// FAILED(hr)の判定コードは省略していますがここまでは動作しているようです
// pIWSHに値は入っているようですが次の場所でAccessViolationします
pIWSH.Echo();
CoUninitialize();
pIWSH.Echo(); の行をコメントアウトすると何も起きませんが正常に完了します
あと
&IID_IUnknown
のところを
&IID_IDispatch
に書き換えてもだめでした
295デフォルトの名無しさん
2015/11/26(木) 21:43:51.54ID:FqPwpLUO296デフォルトの名無しさん
2015/11/27(金) 08:55:22.81ID:H96QzFnR297デフォルトの名無しさん
2015/11/27(金) 09:52:51.69ID:c/N8jVfb >>294
WScript.Shell に Echo は無いよw
WScript.Shell に Echo は無いよw
298デフォルトの名無しさん
2015/11/27(金) 10:48:43.15ID:Og1YQ9Di >>297
うっかり勘違いしてました
標準のinterfaceから継承する方法ですが
interface IWSH : IUnknown { // add vtbl to define as IDispatch
extern (Windows) HRESULT GetTypeInfoCount(UINT *);
extern (Windows) HRESULT GetTypeInfo(UINT, LCID, REFIID);
extern (Windows) HRESULT GetIDsOfNames(REFIID, LPOLESTR *, UINT, LCID, DISPID *);
extern (Windows) HRESULT Invoke(DISPID, REFIID, LCID, WORD, DISPPARAMS *, VARIANT *, EXCEPINFO *, UINT *);
}
にして
hr = CoCreateInstance(&clsid, null, CLSCTX_ALL, &IID_IDispatch, &pIWSH);
したら
後は >>295 さんと同じように PopUp("Hage") を Invoke 出来ました
ほんとうにありがとうございました
うっかり勘違いしてました
標準のinterfaceから継承する方法ですが
interface IWSH : IUnknown { // add vtbl to define as IDispatch
extern (Windows) HRESULT GetTypeInfoCount(UINT *);
extern (Windows) HRESULT GetTypeInfo(UINT, LCID, REFIID);
extern (Windows) HRESULT GetIDsOfNames(REFIID, LPOLESTR *, UINT, LCID, DISPID *);
extern (Windows) HRESULT Invoke(DISPID, REFIID, LCID, WORD, DISPPARAMS *, VARIANT *, EXCEPINFO *, UINT *);
}
にして
hr = CoCreateInstance(&clsid, null, CLSCTX_ALL, &IID_IDispatch, &pIWSH);
したら
後は >>295 さんと同じように PopUp("Hage") を Invoke 出来ました
ほんとうにありがとうございました
299デフォルトの名無しさん
2015/11/27(金) 11:49:41.82ID:c/N8jVfb 質問です。
SysTime st = Clock.currTime();
writefln("%s", st.toISOExtString());
writefln("%s", st.toISOString());
の動作で末尾の小数点以下の数字 (hnsecs) が
7桁になるときと6桁になるときがあるみたいです。
先頭の 0 が表示されないケースがあると思ったのですが
通常の '年月日T114500.1234567' 以外に
'年月日T114500.0123456' は表示されました。
ところがたまに '年月日T114500.123456' と表示されることがあります。
つまり '年月日T114500.0123456' なのか '年月日T114500.1234560' なのか判りません。
hnsecs==0 のときにこのパターンがあるみたいなのですがみなさんのところはどうですか?
DMD32 D Compiler v2.063.2
です。
SysTime st = Clock.currTime();
writefln("%s", st.toISOExtString());
writefln("%s", st.toISOString());
の動作で末尾の小数点以下の数字 (hnsecs) が
7桁になるときと6桁になるときがあるみたいです。
先頭の 0 が表示されないケースがあると思ったのですが
通常の '年月日T114500.1234567' 以外に
'年月日T114500.0123456' は表示されました。
ところがたまに '年月日T114500.123456' と表示されることがあります。
つまり '年月日T114500.0123456' なのか '年月日T114500.1234560' なのか判りません。
hnsecs==0 のときにこのパターンがあるみたいなのですがみなさんのところはどうですか?
DMD32 D Compiler v2.063.2
です。
300デフォルトの名無しさん
2015/11/27(金) 11:52:34.38ID:c/N8jVfb ちょっと紛らわしいので一部訂正します。
x 小数点以下の数字 (hnsecs) が
o 小数点以下の数字 (total hnsecs) が
x hnsecs==0 のときにこのパターンが
o msecs==123, usecs=456, hnsecs==0 のときにこのパターンが
x 小数点以下の数字 (hnsecs) が
o 小数点以下の数字 (total hnsecs) が
x hnsecs==0 のときにこのパターンが
o msecs==123, usecs=456, hnsecs==0 のときにこのパターンが
301デフォルトの名無しさん
2015/11/27(金) 14:33:53.29ID:gmvL3Mcs "年月日T114500.123456" == "年月日T114500.1234560"じゃないの?
302デフォルトの名無しさん
2015/11/27(金) 15:13:20.37ID:c/N8jVfb なるほど小数点以下だから末尾の0は除かれるんですね。
7桁だと思って決め打ちしない方が良いですね。
7桁だと思って決め打ちしない方が良いですね。
303デフォルトの名無しさん
2015/11/27(金) 15:16:44.79ID:c/N8jVfb Duration d = hoge - fuga;
d.total!"msecs", d.total!"usecs", d.total!"hnsecs" を使うことにします。
d.total!"msecs", d.total!"usecs", d.total!"hnsecs" を使うことにします。
304デフォルトの名無しさん
2015/11/28(土) 10:52:50.96ID:BU0Z8dtz python の __getattr__
ruby の method_missing
javascript の __noSuchMethod__
みたいなものを期待して
D で同じようなものが有るかどうか検索したら
http://forum.dlang.org/post/op.usipp0mij5j59l@my-tomato
というやりとりが見つかりました
そこのサンプルをコンパイルしようとしたのですがエラーになります
D で opDotExp ってどう使うんですか?
ruby の method_missing
javascript の __noSuchMethod__
みたいなものを期待して
D で同じようなものが有るかどうか検索したら
http://forum.dlang.org/post/op.usipp0mij5j59l@my-tomato
というやりとりが見つかりました
そこのサンプルをコンパイルしようとしたのですがエラーになります
D で opDotExp ってどう使うんですか?
305デフォルトの名無しさん
2015/11/28(土) 11:37:36.45ID:3W8Apw0w opDispatch()
ただし型のコントロールは引数とか名前付けとか工夫して自前で面倒を見る必要がある
ただし型のコントロールは引数とか名前付けとか工夫して自前で面倒を見る必要がある
306デフォルトの名無しさん
2015/11/28(土) 17:00:55.36ID:OpEOTh0X ないですね
307デフォルトの名無しさん
2015/11/29(日) 18:45:48.60ID:DyLnKIJJ import std.stdio;
class Hoge {
void opDispatch(string s)() {
class Hoge {
void opDispatch(string s)() {
308デフォルトの名無しさん
2015/11/30(月) 20:34:23.05ID:SJumDZBl 有賀d
309デフォルトの名無しさん
2015/11/30(月) 20:43:06.11ID:SiMJvgO4 IDispatch で
auto xl = Dispatch("Excel.Application");
xl.Visible = true;
auto workbooks = xl.Workbooks;
まではうまく逝くのに
auto book = workbooks.Add();
で Access Violation してしまう
何が間違ってるんだろう
auto xl = Dispatch("Excel.Application");
xl.Visible = true;
auto workbooks = xl.Workbooks;
まではうまく逝くのに
auto book = workbooks.Add();
で Access Violation してしまう
何が間違ってるんだろう
310デフォルトの名無しさん
2015/12/01(火) 02:22:06.91ID:Zh0/OJc/ Excel持ってないんであれだけど、Workbooksが返すのはコレクションらしいよ。
https://msdn.microsoft.com/ja-jp/library/aa288625%28v=vs.71%29.aspx
https://msdn.microsoft.com/en-us/library/microsoft.visualbasic.collection.add%28v=vs.90%29.aspx
とか見るに、Add()はリストに追加しますよってメソッドじゃね?
https://msdn.microsoft.com/ja-jp/library/aa288625%28v=vs.71%29.aspx
https://msdn.microsoft.com/en-us/library/microsoft.visualbasic.collection.add%28v=vs.90%29.aspx
とか見るに、Add()はリストに追加しますよってメソッドじゃね?
311デフォルトの名無しさん
2015/12/01(火) 08:39:45.47ID:yW8K+bhB Add がデフォルト引数を持ってるけど引数明示したらどうなるかな
ぐぐったら xlFileFormat 列挙型 とか出てくる
ぐぐったら xlFileFormat 列挙型 とか出てくる
312デフォルトの名無しさん
2015/12/01(火) 20:10:30.52ID:9BYkXgQy a.unknownproperty = hoge;
みたいなのも opDispatch!"unknownproperty"(Args args...) で書けますか?
みたいなのも opDispatch!"unknownproperty"(Args args...) で書けますか?
313デフォルトの名無しさん
2015/12/01(火) 23:55:05.63ID:LyUKVfDv314デフォルトの名無しさん
2015/12/02(水) 04:01:42.11ID:53wnCEvY ちょっと違う気がしますが
なんとなく方向性はわかりました
なんとなく方向性はわかりました
315デフォルトの名無しさん
2015/12/02(水) 05:34:41.55ID:53wnCEvY さっきから変な現象になりました
windows10 なのですが
import std.stdio;
int main(string[] args)
{
writefln("@");
return 0;
}
だけのファイルを d_opDispatch.d というファイル名で保存して
dmd -run d_opDispatch.d を実行しても何も表示されないので
dmd d_opDispatch.d を実行して出来た d_opDispatch.exe を
cmd.exe から実行すると UAC のポップアップが出ていることがわかりました
そのまま許可すると別の cmd.exe が開かれてその中で @ が出力されています
また d_opDispatch.exe を test.exe に rename したら UAC は出なくなりましたω
それで test_opDispatch.exe にするとまた UAC が出たので
test_op_Dispatch.exe とか op_Dis_patch.exe とか試したのですが
この二つも UAC が出てきますω
また test.exe に戻したら普通に動くようになりました
ソースのときのファイル名は関係ないみたいなので
dmd -oftest.exe -run d_opDispatch.d
でとりあえず解決は出来てるんですけど何なんですかねこれ
windows10 のブラックリストに登録されちゃってるんですか?ω
それともうちだけですか?
windows10 なのですが
import std.stdio;
int main(string[] args)
{
writefln("@");
return 0;
}
だけのファイルを d_opDispatch.d というファイル名で保存して
dmd -run d_opDispatch.d を実行しても何も表示されないので
dmd d_opDispatch.d を実行して出来た d_opDispatch.exe を
cmd.exe から実行すると UAC のポップアップが出ていることがわかりました
そのまま許可すると別の cmd.exe が開かれてその中で @ が出力されています
また d_opDispatch.exe を test.exe に rename したら UAC は出なくなりましたω
それで test_opDispatch.exe にするとまた UAC が出たので
test_op_Dispatch.exe とか op_Dis_patch.exe とか試したのですが
この二つも UAC が出てきますω
また test.exe に戻したら普通に動くようになりました
ソースのときのファイル名は関係ないみたいなので
dmd -oftest.exe -run d_opDispatch.d
でとりあえず解決は出来てるんですけど何なんですかねこれ
windows10 のブラックリストに登録されちゃってるんですか?ω
それともうちだけですか?
316デフォルトの名無しさん
2015/12/02(水) 05:39:16.56ID:53wnCEvY opDis_patch.exe もだめです
名前変えるだけで動かなくなります orz
名前変えるだけで動かなくなります orz
317デフォルトの名無しさん
2015/12/02(水) 06:03:46.07ID:J+Rb91dQ UACのインストーラ自動判定によるものだね
http://sceneryandfish.withnotes.net/?p=1632
http://sceneryandfish.withnotes.net/?p=1632
318デフォルトの名無しさん
2015/12/02(水) 08:37:40.95ID:nn4vPBry 実行ファイル名で必要権限が変わるという余計なお世話なアレか
319デフォルトの名無しさん
2015/12/02(水) 19:11:19.07ID:7L3lrCLQ >>317
横からですがありがとう
横からですがありがとう
320デフォルトの名無しさん
2015/12/03(木) 01:03:51.80ID:8SmBlBH8321デフォルトの名無しさん
2015/12/03(木) 01:25:39.08ID:y1qNQeGi 名前付きenumが普通に想像するようなenum
名前なしenumは常時インライン展開されてデータセクションに出力されないconstもどき、じゃなかったっけ
その上で 型.メンバ の形で使えるプロパティは 変数(定数).メンバ の形でも使えるというだけのような気がする
名前なしenumは常時インライン展開されてデータセクションに出力されないconstもどき、じゃなかったっけ
その上で 型.メンバ の形で使えるプロパティは 変数(定数).メンバ の形でも使えるというだけのような気がする
322デフォルトの名無しさん
2015/12/03(木) 01:51:22.50ID:2XsySS+x323デフォルトの名無しさん
2015/12/04(金) 09:37:05.62ID:prxSfFNA auto hoge(T...)(T args){ return args[0] ; }
みたいな関数があるとき
呼び出し側で
auto fuga = hoge();
で呼ばれたか
auto fuga = hoge;
で呼ばれたか
どちらなのかを呼ばれた側で区別出来ますか?
みたいな関数があるとき
呼び出し側で
auto fuga = hoge();
で呼ばれたか
auto fuga = hoge;
で呼ばれたか
どちらなのかを呼ばれた側で区別出来ますか?
324デフォルトの名無しさん
2015/12/04(金) 11:41:34.38ID:qnfnKzej たぶん無理
それにその辺りの仕様はふらついているので
今の仕様で組んでも後でダメになる可能性がある
それにその辺りの仕様はふらついているので
今の仕様で組んでも後でダメになる可能性がある
325デフォルトの名無しさん
2015/12/04(金) 15:12:03.13ID:prxSfFNA call と get と set を実装して dispatch する目論見だったんですが
PyObject だと get と call の区別が微妙なんです
PyObject だと get と call の区別が微妙なんです
326デフォルトの名無しさん
2015/12/04(金) 15:29:35.37ID:eLJR6e6w DWT(https://github.com/d-widget-toolkit/dwt)を試しているのですが
Drag and Drop のサンプル(snippetxx.d)が全く見つからないので
SWT(http://www.eclipse.org/swt/snippets/#dnd)を取ってきて試すも
cannot cast expression event.data of type object.Object to string
のコンパイルエラー、cast じゃダメなので何がしかの変換が必要らしい
で、DWT の Drag and Drop はこんな感じで
動かしてるよ〜という情報をお持ちの方おしえてくださいませm(_ _)m
Drag and Drop のサンプル(snippetxx.d)が全く見つからないので
SWT(http://www.eclipse.org/swt/snippets/#dnd)を取ってきて試すも
cannot cast expression event.data of type object.Object to string
のコンパイルエラー、cast じゃダメなので何がしかの変換が必要らしい
で、DWT の Drag and Drop はこんな感じで
動かしてるよ〜という情報をお持ちの方おしえてくださいませm(_ _)m
327デフォルトの名無しさん
2015/12/04(金) 16:03:35.97ID:u0bQfuw3328デフォルトの名無しさん
2015/12/04(金) 18:01:46.27ID:5R2qZuA/ 2.069.2でDelimited Strings内にASCII以外があると怒られるよぅ
q"EOS
日本語 ← Error: character 0xa5 is not a valid token
EOS"
q"EOS
日本語 ← Error: character 0xa5 is not a valid token
EOS"
329デフォルトの名無しさん
2015/12/04(金) 18:39:04.25ID:qnfnKzej 2.069の文字列処理で日本語入ってるときの挙動が変わって往生した
330デフォルトの名無しさん
2015/12/05(土) 11:43:03.20ID:pK0sc289 >>324
とりあえず呼び出し側で
auto fuga = hoge.unknownmethodcall([]);
と
auto fuga = hoge.unknownproperty;
で区別することにしたらうまく別けられました
ところが今度は
hoge.unknownproperty = hage;
で代入しようと hoge class 内で
void opDispatch(string propertyname, T)(T arg){
}
と setter を定義したのですが
hoge.unknownmethodcall([]);
の方まで setter に奪われるようになってしまいました
とりあえず呼び出し側で
auto fuga = hoge.unknownmethodcall([]);
と
auto fuga = hoge.unknownproperty;
で区別することにしたらうまく別けられました
ところが今度は
hoge.unknownproperty = hage;
で代入しようと hoge class 内で
void opDispatch(string propertyname, T)(T arg){
}
と setter を定義したのですが
hoge.unknownmethodcall([]);
の方まで setter に奪われるようになってしまいました
331デフォルトの名無しさん
2015/12/05(土) 23:07:38.68ID:IGesALUR getterのopDispatchの戻り値を構造体でラップするとか。
http://dpaste.dzfl.pl/e089dbd99093
http://dpaste.dzfl.pl/e089dbd99093
332デフォルトの名無しさん
2015/12/06(日) 13:00:28.84ID:OHUYOsyJ ああテンプレートで呼び分けるんじゃなくて
全部まとめて一ヶ所で受けて if で分けるんですね
参考になります
ありがとうございます
全部まとめて一ヶ所で受けて if で分けるんですね
参考になります
ありがとうございます
333デフォルトの名無しさん
2015/12/07(月) 22:12:53.36ID:yUJmRPdi import std.process;
で pipeProcess とか spawnProcess とか使えるのは判ったのですが
windows で win32api の CreateProcessAsUser とか CreateProcessWithLogonW
に相当することが実行可能なモジュールはありますか?
で pipeProcess とか spawnProcess とか使えるのは判ったのですが
windows で win32api の CreateProcessAsUser とか CreateProcessWithLogonW
に相当することが実行可能なモジュールはありますか?
334デフォルトの名無しさん
2015/12/07(月) 22:30:26.17ID:ka6hrItk 標準では最低限のAPIしかないので
自分でポーティングするか拾ってくるかしましょう
自分でポーティングするか拾ってくるかしましょう
335デフォルトの名無しさん
2015/12/07(月) 22:42:24.23ID:yUJmRPdi thx!
336デフォルトの名無しさん
2015/12/09(水) 01:01:38.90ID:Iqk5klbT linuxで7zip.soのbindingを書こうとしています。7zipのC++側のIUnknownが
struct IUnknown
{
STDMETHOD(QueryInterface) (REFIID iid, void **outObject) PURE;
STDMETHOD_(ULONG, AddRef)() PURE;
STDMETHOD_(ULONG, Release)() PURE;
#ifndef _WIN32
virtual ~IUnknown() {}
#endif
};
このように宣言されているのですが、Dのinterfaceでデストラクタを宣言できなくて困っています。
超その場しのぎとして、DのIUnknownの宣言のReleaseの後にダミーのメソッドを、
・2個追加することでC++で実装されたinterfaceをDから呼び出すことが、
・1個追加することでDで実装されたinterfaceをC++から呼び出すことが、
それぞれできたのですが、とてもまともな解決策とは思えません。
どうすべきでしょうか。
struct IUnknown
{
STDMETHOD(QueryInterface) (REFIID iid, void **outObject) PURE;
STDMETHOD_(ULONG, AddRef)() PURE;
STDMETHOD_(ULONG, Release)() PURE;
#ifndef _WIN32
virtual ~IUnknown() {}
#endif
};
このように宣言されているのですが、Dのinterfaceでデストラクタを宣言できなくて困っています。
超その場しのぎとして、DのIUnknownの宣言のReleaseの後にダミーのメソッドを、
・2個追加することでC++で実装されたinterfaceをDから呼び出すことが、
・1個追加することでDで実装されたinterfaceをC++から呼び出すことが、
それぞれできたのですが、とてもまともな解決策とは思えません。
どうすべきでしょうか。
337デフォルトの名無しさん
2015/12/09(水) 06:33:38.56ID:wRgo2YTq クソして寝ればいいと思うよ
338デフォルトの名無しさん
2015/12/09(水) 09:39:07.56ID:3EPxHLPC339デフォルトの名無しさん
2015/12/09(水) 10:05:46.43ID:IXqPU77s winじゃなくてlinuxでやりたいみたいよ
一晩寝たら 空のデストラクタなんていらなかったんや
って気づくかもしれない
一晩寝たら 空のデストラクタなんていらなかったんや
って気づくかもしれない
340336
2015/12/09(水) 18:59:13.67ID:bSTrBSEY >>337-339 クソして寝ましたが、仮に空(とはいえvirtual)のデストラクタがまるで無意味だったとしても、
bindingの体をとっているのでp7zip側のコードを変えるのはちょっと。
むしろvtblのズレが336程度の単純さならばソレで行くかと。
気になるのはDから呼ぶ場合とC++から呼ぶ場合の非対称性ですが、こういうもんなんですか?
bindingの体をとっているのでp7zip側のコードを変えるのはちょっと。
むしろvtblのズレが336程度の単純さならばソレで行くかと。
気になるのはDから呼ぶ場合とC++から呼ぶ場合の非対称性ですが、こういうもんなんですか?
341デフォルトの名無しさん
2015/12/09(水) 19:32:29.57ID:sRhtlXMa C++ネイティブの呼び出しっていつから「ちゃんと」できるようになったんですか?(小声)
342336
2015/12/09(水) 20:30:12.63ID:bSTrBSEY あ、非対称っていうのは勘違いだったかもごめ。
http://dpaste.dzfl.pl/4e7956f36a47
これで解決や!どうもありがとう!
>>341 WindowsでCOMを使った7zipのbindingはもっとすんなりいきましたよ。
http://dpaste.dzfl.pl/4e7956f36a47
これで解決や!どうもありがとう!
>>341 WindowsでCOMを使った7zipのbindingはもっとすんなりいきましたよ。
343デフォルトの名無しさん
2015/12/10(木) 12:53:37.73ID:gg94mj0B Dで書かれた2chブラウザって何かあったっけ
344デフォルトの名無しさん
2015/12/11(金) 10:36:51.24ID:Q/bqtNpc 振りかな?
345デフォルトの名無しさん
2015/12/11(金) 11:05:46.98ID:DzIPXkfp346デフォルトの名無しさん
2015/12/11(金) 16:50:35.23ID:W1u3sjBk http://qiita.com/advent-calendar/2015/d-man
こっちのほうが盛り上がってる感じでちょっと笑う
こっちのほうが盛り上がってる感じでちょっと笑う
2015/12/14(月) 11:06:28.62ID:baKxaSGv
自分のクラス(Fuga)を定義していて string へ変換するときに
Fuga f("hage");
string hoge = f;
みたいな書き方をしたいのですが
どんなメソッドを作っておけば良いのですか?
Fuga f("hage");
string hoge = f;
みたいな書き方をしたいのですが
どんなメソッドを作っておけば良いのですか?
2015/12/14(月) 11:07:18.65ID:baKxaSGv
Fuga f = new Fuga("hage");
string hoge = f;
です
string hoge = f;
です
2015/12/14(月) 14:25:36.75ID:ilKRKXII
class Fuga {
private string s_;
this(string s) { s_ = s; }
alias s_ this;
}
private string s_;
this(string s) { s_ = s; }
alias s_ this;
}
350名無しさん@そうだ選挙に行こう
2015/12/14(月) 14:30:09.48ID:baKxaSGv alias s_ this; とは驚きですが
Fuga f = new Fuga("123");
int i = f;
としたときでも i に 123 が入るようになりますか?
条件後出しですみません
Fuga f = new Fuga("123");
int i = f;
としたときでも i に 123 が入るようになりますか?
条件後出しですみません
2015/12/14(月) 14:33:32.26ID:baKxaSGv
ちなみに
Fuga f = new Fuga("123");
string s = f; // なら s = "123"; と同じ
int i = f; // なら i = 123; と同じ
という意味です
これも alias だけで出来てしまうんでしょうか?
Fuga f = new Fuga("123");
string s = f; // なら s = "123"; と同じ
int i = f; // なら i = 123; と同じ
という意味です
これも alias だけで出来てしまうんでしょうか?
2015/12/14(月) 15:09:08.43ID:2JSVZtRY
そういうのはたいてい変数に移して終わりじゃなくて、その先があるでしょ
例えば関数に渡すならその関数をテンプレートでうまくまとめるのが D流
単に出力するだけなら writeln(f)
例えば関数に渡すならその関数をテンプレートでうまくまとめるのが D流
単に出力するだけなら writeln(f)
2015/12/14(月) 17:11:34.59ID:reTGASBb
ここを参考に
http://www.kmonos.net/alang/wnd/topics/winapi.ja.html
Win32API を使って drag & drop を実装してみたところ
case WM_DROPFILES: の中で
HDROP dr = cast(HDROP)wp;
TCHAR[] buf = new TCHAR[MAX_PATH];
int l = DragQueryFile(dr, 0, buf.ptr, buf.length);
if(l < buf.length) buf[l] = 0;
string bs = to!string(buf[0..l]);
version(Unicode){
writefln("0: %s", to!string(bs.toMBSz()));
string name = bs;
}else{
writefln("0: %s", bs);
string name = fromMBSz(bs.toStringz());
}
writefln("1: %s", name);
とすると
drag & drop したファイル名が 「森鷗(環境依存文字2)外(環境依存文字3)る.ext」 のとき
最後の name の表示が -version=Unicode したときとしないときで結果が違います
toMBSz と fromMBSz とで不可逆なのは判るのですが
MBSz -> UTF8 するときも結果が違うのは何故でしょうか?
(ただし表示は違うのですが同じファイルが対象になってちゃんと動作します)
http://www.kmonos.net/alang/wnd/topics/winapi.ja.html
Win32API を使って drag & drop を実装してみたところ
case WM_DROPFILES: の中で
HDROP dr = cast(HDROP)wp;
TCHAR[] buf = new TCHAR[MAX_PATH];
int l = DragQueryFile(dr, 0, buf.ptr, buf.length);
if(l < buf.length) buf[l] = 0;
string bs = to!string(buf[0..l]);
version(Unicode){
writefln("0: %s", to!string(bs.toMBSz()));
string name = bs;
}else{
writefln("0: %s", bs);
string name = fromMBSz(bs.toStringz());
}
writefln("1: %s", name);
とすると
drag & drop したファイル名が 「森鷗(環境依存文字2)外(環境依存文字3)る.ext」 のとき
最後の name の表示が -version=Unicode したときとしないときで結果が違います
toMBSz と fromMBSz とで不可逆なのは判るのですが
MBSz -> UTF8 するときも結果が違うのは何故でしょうか?
(ただし表示は違うのですが同じファイルが対象になってちゃんと動作します)
2015/12/14(月) 17:23:00.56ID:reTGASBb
文字化けしてるので補足
環境依存しない方の文字はこちらです
森鴎外叱る
2 鷗外
3 る
がそれぞれ環境依存文字です
この辺が関係ありそうなのですが fromMBSz のバグなのか何なのかよく判りませんでした
https://msdn.microsoft.com/ja-jp/library/cc419800.aspx
http://download.microsoft.com/download/B/0/9/B09F266D-8D54-4476-A3EC-E974CA5F61F8/BS_303.pdf
環境依存しない方の文字はこちらです
森鴎外叱る
2 鷗外
3 る
がそれぞれ環境依存文字です
この辺が関係ありそうなのですが fromMBSz のバグなのか何なのかよく判りませんでした
https://msdn.microsoft.com/ja-jp/library/cc419800.aspx
http://download.microsoft.com/download/B/0/9/B09F266D-8D54-4476-A3EC-E974CA5F61F8/BS_303.pdf
355デフォルトの名無しさん
2015/12/14(月) 21:06:28.36ID:uspa+zNB356デフォルトの名無しさん
2015/12/15(火) 04:33:41.61ID:iPeNyqfl >>353 SHIFT-JISに含まれてない文字だから仕方ないとおもわれ。
DragQueryFileAの方ではかわりに 63(ASCIIのハテナマーク)が送られてきてる。
A付関数のことなんて早く忘れるんだ!
DragQueryFileAの方ではかわりに 63(ASCIIのハテナマーク)が送られてきてる。
A付関数のことなんて早く忘れるんだ!
357デフォルトの名無しさん
2015/12/15(火) 09:35:34.07ID:GmzcEDm2 string valueOf(){ return s_; }
int valueOf(){ return to!int(s_); }
alias valueOf this;
int valueOf(){ return to!int(s_); }
alias valueOf this;
358デフォルトの名無しさん
2015/12/15(火) 09:37:35.44ID:GmzcEDm2 >>356
不思議なのは *A バージョンの方でも正常に動作してるって所なんだよね
不思議なのは *A バージョンの方でも正常に動作してるって所なんだよね
359デフォルトの名無しさん
2015/12/15(火) 09:57:14.35ID:ax++RPg4 上は Utf16->Utf8->SJIS で余計な変換してるからじゃないの
360デフォルトの名無しさん
2015/12/18(金) 01:01:03.51ID:fYXmJuMp361デフォルトの名無しさん
2015/12/18(金) 17:04:11.83ID:mbvyIjbK362デフォルトの名無しさん
2015/12/20(日) 01:09:48.99ID:VpDH1DV/ >>361
?が1文字マッチのワイルドカードってのは関係してない?
?が1文字マッチのワイルドカードってのは関係してない?
363デフォルトの名無しさん
2015/12/20(日) 11:01:49.72ID:8RLYRFXT364デフォルトの名無しさん
2015/12/20(日) 17:10:30.71ID:uT5SbDNR あれ、戻り値だけ違う関数ってオーバーロードできたっけ?
365デフォルトの名無しさん
2015/12/21(月) 12:10:28.67ID:ayhLnjzU 宣言はできるけど使えない
左辺値から型推論とかしてくれると嬉しいんだけどね
左辺値から型推論とかしてくれると嬉しいんだけどね
366デフォルトの名無しさん
2015/12/21(月) 14:13:11.66ID:1HvlxK+M T valueOf(T)(){ return to!T(s_); }
これもうまくいかんな
これもうまくいかんな
367デフォルトの名無しさん
2015/12/22(火) 23:01:04.25ID:RP62Thfp 明示cast必須になるけど
T opCast(T)(){ return s_.to!T; }
T opCast(T)(){ return s_.to!T; }
368デフォルトの名無しさん
2015/12/23(水) 08:52:41.01ID:2F8TsTF+ alias hoge this; しなくてよくなるからありがたいね
369デフォルトの名無しさん
2015/12/23(水) 10:13:41.06ID:1VnhNGH+ 明示的キャスト滅すべし
370デフォルトの名無しさん
2015/12/26(土) 10:10:16.02ID:PvF8tuZ2 みなさん良いお年を
371デフォルトの名無しさん
2015/12/26(土) 12:41:22.97ID:yhjxl89x D言語話題ないの?
372デフォルトの名無しさん
2015/12/26(土) 13:55:49.41ID:Y1V4v3Og Advent Calendar面白かったよ。
書いた人たち乙です。
書いた人たち乙です。
373デフォルトの名無しさん
2015/12/26(土) 17:44:23.06ID:OqNeHPOm 冬休み中にAdventCalendarゆっくり読む
楽しみだなあ。書いた人たち乙〜。
楽しみだなあ。書いた人たち乙〜。
374デフォルトの名無しさん
2015/12/27(日) 16:08:22.48ID:xwOrDqSJ Voting For std.experimental.ndslice
http://forum.dlang.org/thread/nexiojzouxtawdwnlfvt@forum.dlang.org
そろそろ投票終わり
http://forum.dlang.org/thread/nexiojzouxtawdwnlfvt@forum.dlang.org
そろそろ投票終わり
375デフォルトの名無しさん
2016/01/04(月) 12:10:44.32ID:bFE828K2 https://github.com/D-Programming-Language/dlang.org/commit/77324039087e9283f40244195857c2f9fd4712eb#diff-59280080f58c2ff747f066c5b0b2fcebL423
- $(LI As a first programming language - Basic or Java is more suitable
+ $(LI As a first programming language - Python or JavaScript is more suitable
時代の流れを感じる
Basicの方が初めてのプログラミングには良いと思うんだがなぁ
- $(LI As a first programming language - Basic or Java is more suitable
+ $(LI As a first programming language - Python or JavaScript is more suitable
時代の流れを感じる
Basicの方が初めてのプログラミングには良いと思うんだがなぁ
376デフォルトの名無しさん
2016/01/04(月) 18:59:05.97ID:uh/Y4MEw BASICは害悪
377デフォルトの名無しさん
2016/01/04(月) 19:11:18.78ID:SQWKaGiq まあ妥当と思う。Basicって括りがざっぱだけど、
(N-88とかそういう)BASIC → まあやらんでええやろ。行番号とか。ねえ?
VB → PowerShellが出てシリスボミ感がある。
Python → 個人的にはtkinterの存在がでかい。
JavaScript → すぐ遊べる。すぐ自慢できる(←重要
あとは英才教育的な観点からならプログラミンとか?
(N-88とかそういう)BASIC → まあやらんでええやろ。行番号とか。ねえ?
VB → PowerShellが出てシリスボミ感がある。
Python → 個人的にはtkinterの存在がでかい。
JavaScript → すぐ遊べる。すぐ自慢できる(←重要
あとは英才教育的な観点からならプログラミンとか?
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 空自機レーダー照射、音声データ公開 中国 ★2 [蚤の市★]
- 中国とロシアの爆撃機、日本周辺で共同飛行 [少考さん★]
- 「中国側も日本機のレーダーを感知していた」 中国メディアが報道 [♪♪♪★]
- 【YouTuber】バイク事故で入院のゆたぼん、振込で「お見舞金」募る [muffin★]
- 高市早苗首相、消費税減税に後ろ向き 足かせはレジシステム? 「責任ある積極財政」期待高いが [蚤の市★]
- 堀江貴文、キャッシュレス非対応の店にモヤッ 『PayPay』立ち上げの人物にまさかの直談判「現金決済しかできないんだけど…」 [冬月記者★]
- 防衛省、中国を完全論破www 「事前通告があったのは海自であって空自ではない」 高市早苗勝利 [175344491]
- ネトウヨ「これが理想の世界地図な、世界がこうだったらいいのに」10万いいね [165981677]
- 【悲惨】中国軍が自衛隊に「事前通告」し自衛隊も返答した音声が公開されてしまうwwwこれは高市チェックアウトゕ★4 [597533159]
- 【悲報】JA「全然米が売れなくて倉庫を圧迫してる。助けて!」米卸売り業者「安売りしたら赤字になる…助けて!」 [802034645]
- まえあつの写真集買う?
- 小難しいテクニックを習得する前に基礎固めたほうがいいんじゃ?って初心者いるじゃん?
