On Tuesday, 27 September 2016 at 17:53:39 UTC, Steven
Schveighoffer wrote:
On 9/27/16 1:38 PM, Mark wrote:
I've been going through Andrei's excellent book and I noticed
that the
latest printing is from 2010. Since D is still a very young
language I
can imagine it changing quite a bit within
On Monday, 12 December 2016 at 21:58:23 UTC, Relja Ljubobratovic
wrote:
[1]
http://blog.mir.dlang.io/ndslice/algorithm/optimization/2016/12/12/writing-efficient-numerical-code.html
[2] https://github.com/libmir/dcv
[3] https://github.com/libmir/dcv/pull/58
Very impressive work.
On Thursday, 24 November 2016 at 14:06:40 UTC, Jonathan M Davis
wrote:
Personally, I don't care much about having body as a usable
symbol. It occasionally would be useful, but I can live without
it. However, I _do_ find it very annoying that it's required
for the function body when you have
On Sunday, 8 January 2017 at 00:15:23 UTC, Seb wrote:
On Saturday, 7 January 2017 at 23:33:45 UTC, Benjiro wrote:
Maybe something to add ( for new users ) is something similar
to:
http://rustbyexample.com/
Easy to use, lots of information, simple tasks that involve
interaction for the user,
On Monday, 19 December 2016 at 17:50:17 UTC, Seb wrote:
On Monday, 19 December 2016 at 17:44:29 UTC, Andrei
Alexandrescu wrote:
Take a look e.g. at
https://dlang.org/phobos-prerelease/std_algorithm_iteration.html. Examples now have "Edit" and "Run" buttons that allow you to play with them
On Saturday, 24 December 2016 at 07:30:56 UTC, Ali Çehreli wrote:
On 12/15/2016 12:20 AM, Ali Çehreli wrote:
https://www.meetup.com/D-Lang-Silicon-Valley/events/236253882/
The slides:
http://files.meetup.com/18234529/The%20Curse%20of%20Knowledge.pptx
The video:
On Thursday, 3 August 2017 at 15:49:06 UTC, Martin Tschierschke
wrote:
On Thursday, 27 July 2017 at 08:29:14 UTC, Martin Tschierschke
wrote:
On Friday, 16 December 2016 at 05:43:02 UTC, Kai Nacke wrote:
Hi all,
Packt Publishing offers eBooks for $5 for a limited time. If
your collection of D
On Sunday, 14 May 2017 at 04:44:26 UTC, bluecat wrote:
On Saturday, 13 May 2017 at 23:22:41 UTC, Ali Çehreli wrote:
I've updated the book to 2.074.0. I've updated all paper and
electronic versions at all publishers. However, I recommend
that you wait a week or so before ordering (e.g. from
Ok.
So I have a BST template, and it passes my tests.
However, if you look at how I insert the data into the BST,
you'll quickly notice the problem I have.
https://dpaste.dzfl.pl/ff58876ce213
Keep in mind I just pasted that stack in there because I use it
in my last unittest at the bottom.
On Tuesday, 16 May 2017 at 17:44:28 UTC, Walter Bright wrote:
http://nwcpp.org
May 17th, 2017 at 7:00 PM
Steptoe Room, Cafeteria 40,
Microsoft Campus,
156th Ave NE,
Redmond, WA 98052.
Eric's talks are generally not to be missed.
We often go out for beer afterwards :-)
I remember this talk
Awesome. That worked.
On Friday, 2 June 2017 at 22:30:28 UTC, Stefan Koch wrote:
On Friday, 2 June 2017 at 22:21:07 UTC, Mark wrote:
Hello,
I am trying to make a class that can accept any type as an
argument.
[...]
the stack class needs to be a template as well.
This is not java ;)
Hello,
I am trying to make a class that can accept any type as an
argument.
Here is the class:
import std.container: SList;
class Stack {
private SList!T list;
private int _size;
this(T)() {
list = SList!T;
_size = 0;
}
public void push(T)(T item) {
On Saturday, 3 June 2017 at 19:57:47 UTC, Mark wrote:
Hello again.
I'm designing a template version of a BST.
Because of this, I want to be able to compare if two objects of
the same class type are references to the same anonymous class
on the heap somewhere.
Example:
Not sure what
On Saturday, 3 June 2017 at 22:52:42 UTC, Mark wrote:
Thanks again.
Nevermind, I got it.
On Saturday, 3 June 2017 at 23:32:44 UTC, Ali Çehreli wrote:
...
Ali
Awesome, that might be handy in the near future.
Thanks.
Hello again.
I'm designing a template version of a BST.
Because of this, I want to be able to compare if two objects of
the same class type are references to the same anonymous class on
the heap somewhere.
Example:
On Saturday, 3 June 2017 at 22:38:31 UTC, Mark wrote:
...
Thanks.
Actually, I got another question,
how Can I obtain the actual memory address of a class?
I'll still need to solve the problem of taking ints/floats/reals
etc., as well as structs and classes and sending them right/left
in
On Saturday, 3 June 2017 at 20:24:44 UTC, ag0aep6g wrote:
By default, they act the same. But you can change how `==`
behaves by overriding `opEquals`. You cannot override `is`.
Ok. So by using '==' it should compare the addresses of the
objects?
I think I didn't include the other file as
On Friday, 2 June 2017 at 23:34:14 UTC, Ali Çehreli wrote:
You've probably seen H. S. Teoh's answer but still... :)
...
Ali
Awesome, thanks everyone!
On Friday, 9 June 2017 at 05:53:11 UTC, ag0aep6g wrote:
...
Get rid of `real val;` and just compare `payload`s. For
classes, you can detect them with `static if (is(T == class))`
or some such, and cast to void* when comparing.
But when you cast to void*, you're ignoring an opEquals or
opCmp
On Saturday, 10 June 2017 at 14:35:48 UTC, ag0aep6g wrote:
...
Just that you shouldn't take my version of addNode and rely on
it without double checking that it's correct.
Ah, Okay. I rechecked that everything is working. The size is
correct, and the membership is correct for every
Ok. WOW!
I was way off. I adapted your code to my BST and it works
perfectly.
Thanks!
I didn't know what static if was. I should experiment with it.
For the code that I mentioned, I'd have to retype it. I wrote,
tried and deleted those pieces of code several days ago because
it really
On Wednesday, 20 September 2017 at 19:25:58 UTC, Timon Gehr wrote:
Actually, it is useful enough to have a Wikipedia page:
https://en.wikipedia.org/wiki/Iverson_bracket
Example of a good use:
void floodFill(dchar[][] data,dchar c,int i,int j) {
void dfs(int a, int b) {
if (a<0 ||
On Wednesday, 30 August 2017 at 15:06:12 UTC, Jonathan M Davis
wrote:
[...]
Thank you for the detailed response.
On Thursday, 31 August 2017 at 17:40:16 UTC, bitwise wrote:
On Thursday, 31 August 2017 at 16:37:35 UTC, SrMordred wrote:
On Thursday, 31 August 2017 at 14:57:28 UTC, bitwise wrote:
https://www.tiobe.com/tiobe-index/d/
What happened in 2009?
My first thought was that it was related to the
C++ has the issue of iterator invalidation, where certain
operations on a container while iterating on it may invalidate
the iterator, in which case it is no longer safe to use the
iterator.
D has ranges, but presumably the same issue can arise in D. For
instance, if I have a ForwardRange
On Monday, 28 August 2017 at 12:19:26 UTC, Mike Parker wrote:
Jean-Louis Leroy posted about his open methods library here in
the forums some time ago. Now, he's written a blog post that
explains what open methods are, and describes the D
implementation and how it compares to his C++ library.
On Saturday, 21 October 2017 at 18:20:13 UTC, Ali Çehreli wrote:
D Fibers
Ali will present a shorter version of his DConf 2016 talk:
http://dconf.org/2016/talks/cehreli.html
D's fibers (coroutines in other languages) are not a part of
the language but a feature implemented by the D
std.format has the function formattedRead which can be used to
parse a string, e.g.
string first_name;
string last_name;
string info = readln();
formattedRead(info, "%s %s", first_name, last_name);
This piece of code works as intended. However, since I don't need
the input after it's parsed,
On Wednesday, 6 December 2017 at 18:57:55 UTC, Ali Çehreli wrote:
On 12/06/2017 10:47 AM, Mark wrote:
> string info = readln();
> formattedRead(info, "%s %s", first_name, last_name);
>
> This piece of code works
> formattedRead(readln(), "%s %s", first_name, last_name);
>
> But this raises a
On Wednesday, 3 January 2018 at 23:49:33 UTC, H. S. Teoh wrote:
On Wed, Jan 03, 2018 at 03:42:07PM -0700, Jonathan M Davis via
Digitalmars-d-learn wrote:
On Wednesday, January 03, 2018 22:25:16 Mark via
Digitalmars-d-learn wrote:
[...]
> https://dlang.org/spec/function.html#safe-functi
On Saturday, 6 January 2018 at 23:32:42 UTC, Paul Backus wrote:
On Saturday, 6 January 2018 at 03:38:35 UTC, codephantom wrote:
or even..
a.append( s.to!ConvertToElementType(a) );
That's not valid code of course, but the semantics are all
contained in that single chunk.
This works:
import
Hello,
I re wrote my old BST. This one is far more complete and clean.
However, It fails my final unittest when I try to stick a class
in as its type.
Link: https://dpaste.dzfl.pl/95e1ae49b25b
Ive done this type of thing before, but it is giving me this
error:
BinarySearchTree.d(30):
On Sunday, 21 January 2018 at 20:46:56 UTC, Timon Gehr wrote:
On 21.01.2018 21:20, Mark wrote:
Just realized that I commented out the creation of the BST
new link: https://dpaste.dzfl.pl/ce620cbee919
'in' means 'const scope', but it seems you need references that
are allowed to mutate the
Just realized that I commented out the creation of the BST
new link: https://dpaste.dzfl.pl/ce620cbee919
Hello!
As the title suggests, I'm looking for the answer to this
question. I've searched / asked it on the vibe forums, but nobody
has answered.
I'm not familiar enough with JS frameworks / vibe to really know
how this would (not) work together.
I've experimented with vibe, and I would
On Wednesday, 3 January 2018 at 22:12:01 UTC, Jonathan M Davis
wrote:
On Wednesday, January 03, 2018 22:02:22 Mark via
Digitalmars-d-learn wrote:
The documentation says the modification of pointer values is
not allowed in safe functions. Yet the following compiles fine
on dmd:
void main
The documentation says the modification of pointer values is not
allowed in safe functions. Yet the following compiles fine on dmd:
void main() @safe
{
int* x = new int;
int* y = new int;
y=x;
}
Is this simply a compiler bug?
What I'm trying to do here is to be able to call a function based
off of a key.
I'm not sure how to do this, I've been messing around a bit, but
the compiler doesn't like what I'm doing.
Im getting:
test.d(20): Error: cannot implicitly convert expression
of type void delegate() to void
On Wednesday, 3 January 2018 at 17:27:38 UTC, Marc wrote:
for a safe programming, since C/C++ times I try to make thing
const as possible. locals, parameters etc anything which isn't
going to change.
How do you do that in D? immutable everywhere?
for example:
foreach(Field field;
On Thursday, 12 July 2018 at 14:49:14 UTC, bachmeier wrote:
AFAICT, the money goes to internal compiler work to add new
features to the language in order to appeal to C++ users.
Well, there's also the redesign of the Phobos collections.
I don't know if attracting C++ users is currently a
On Thursday, 17 January 2019 at 20:47:38 UTC, Steven
Schveighoffer wrote:
well, there was no static foreach for that article (which I
admit I didn't read, but I know what you mean).
But it's DEFINITELY not as easy as it could be:
import std.conv;
alias AliasSeq(P...) = P;
template
On Friday, 18 January 2019 at 20:29:08 UTC, H. S. Teoh wrote:
That would work, but it would also suffer from all the same
problems as macro-based programming in C. The compiler would
be unable to detect when you accidentally pasted type names
together where you intended to be separate, the
I have the following array of structs:
struct Person {
string name;
int age;
};
Person people[];
Person p;
Person p1 = {
"Bob",
12
};
Person p2 = {
"Bob",
12
};
people ~= p1;
people ~= p2;
I've read through the std.json documentation, but I'm still
confused as to
On Wednesday, 12 February 2020 at 05:59:53 UTC, cc wrote:
On Monday, 3 February 2020 at 13:26:38 UTC, mark wrote:
I'm using std.zip.ZipArchive to read zip files, e.g.:
[snip]
I couldn't find one either, I had to do this:
version(Windows) {
enum uint FILE_ATTRIBUTE_DIRECTORY = 0x10;
}
On Tuesday, 11 February 2020 at 20:49:40 UTC, Ron Tarrant wrote:
On Sunday, 9 February 2020 at 13:28:59 UTC, mark wrote:
I found a much easier way to get GtkD working on windows than
that described in
https://gtkdcoding.com/2019/01/11/-introduction-to-gtkDcoding.html
Just FYI...
I don't
According to the GtkD web site https://gtkd.org/ this GUI library
is cross-platform, so hopefully just what I need.
The introductory blog
https://gtkdcoding.com/2019/01/11/-introduction-to-gtkDcoding.html explains how to install and get started with GtkD on Windows (which I plan to use
I've just completed my first D package:
http://code.dlang.org/packages/ddiff
It is a straight port, so it isn't at all functional-style.
I'd be happy and interested if anyone could show me how to
replace some/all of the for[each] loops (without reducing
performance), or for any other code
I've been learning D for a few weeks now.
I'm an experienced programmer in other languages (esp. Python,
but also Rust and C++).
Here're some *early* impressions and notes.
D Tour
I found the D Tour, esp. "D's Basics" to be very helpful. Each
part is short and in most cases understandable.
I'm starting out with GtkD and have this function:
void main(string[] args) {
Main.init(args);
auto game = new GameWindow();
Main.run();
}
and this method:
void quit(Widget widget) {
Main.quit();
}
When I run dscanner --styleCheck it reports:
On Wednesday, 12 February 2020 at 11:46:02 UTC, Dennis wrote:
Thanks for your perspective. Just a few things are unclear to
me:
On Wednesday, 12 February 2020 at 10:39:06 UTC, mark wrote:
I don't find the presentation of the member properties and
methods very easy to read
Can you elaborate
On Wednesday, 12 February 2020 at 14:15:40 UTC, Adam D. Ruppe
wrote:
On Wednesday, 12 February 2020 at 10:39:06 UTC, mark wrote:
Library Reference Documentation
Have you seen my fork?
http://dpldocs.info/experimental-docs/std.zip.ZipArchive.html
Yours is *much* clearer.
However, if you
On Wednesday, 12 February 2020 at 18:20:47 UTC, Adam D. Ruppe
wrote:
On Wednesday, 12 February 2020 at 15:52:35 UTC, mark wrote:
Yours rolls the two examples into one and doesn't show the
Standards or Usage sections.
Weird, that's a legit bug in there. I'll fix them.
I also think you split
On Sunday, 23 February 2020 at 09:35:30 UTC, Jacob Carlborg wrote:
On 2020-02-23 10:03, mark wrote:
Then this would not only help dscanner, but also make it clear
to programmers that the argument could be modified.
It's not necessary for dscanner. It should look at the
signature of
I've just completed a small D/GtkD game.
It might be useful for others trying to learn GtkD since it is
only just over 1000 lines, yet shows how to create a dialog-style
app with a modal dialog and a modeless dialog, and a custom drawn
widget, as well as keyboard and mouse handling.
The
There seems to be some support for SQLite 3 in std. lib. etc when
looking at the stable docs:
https://dlang.org/phobos/etc_c_sqlite3.html
But this isn't visible when looking at stable (ddox).
Is this the best SQLite 3 library to use or is a third-party
library best?
For example
On https://wiki.dlang.org I can find GSOC ideas 2011-2019, but
not 2020.
I know the 2020 one's haven't been accepted, but I'd like to know
what they are in case I feel like having a go at one as part of
learning D.
I changed int to size_t and used const(char[]) etc. as suggested.
It ran but crashed. Each crash was a range violation, so for each
one I put in a guard so instead of
if ( ... m_b[m_k])
I used
if (m_k < m_b.length && ... m_b[m_k)
I did this kind of fix in three places.
The result is that
I suspect the problem is using .length rather than some other
size property.
On Thursday, 5 March 2020 at 11:12:24 UTC, drug wrote:
On 3/5/20 2:03 PM, mark wrote:
[snip]
Your code and errors seem to be not related.
OK, it is probably that the D stemmer is 19 years old!
I've now got Martin Porter's own Java version, so I'll have a go
at porting that to D myself.
On Thursday, 5 March 2020 at 13:31:14 UTC, Adam D. Ruppe wrote:
On Thursday, 5 March 2020 at 11:03:30 UTC, mark wrote:
I want to use the Porter stemming algorithm.
There's a D implementation here:
https://tartarus.org/martin/PorterStemmer/d.txt
I think I (or ketmar and I stole it from him)
In Adam Ruppe's D Cookbook there're these lines in a ref counting
example:
RefCountedObject o = void; // What does this mean/do?
o.data = new Implementation();
o.data.refcount = 1;
I don't understand the first line; could someone explain please?
On Thursday, 5 March 2020 at 08:35:52 UTC, drug wrote:
On 3/5/20 10:47 AM, mark wrote:
In Adam Ruppe's D Cookbook there're these lines in a ref
counting example:
RefCountedObject o = void; // What does this mean/do?
o.data = new Implementation();
o.data.refcount = 1;
I don't understand the
I want to use the Porter stemming algorithm.
There's a D implementation here:
https://tartarus.org/martin/PorterStemmer/d.txt
The main public function's signature is:
char[] stem(char[] p, int i, int j)
But I work entirely in terms of strings (containing individual
words), so I want to add
Below is a program that produces a wordladder.
The algorithm is probably suboptimal, but I don't care since I've
implemented the same one in Python, Rust, Go, Java, and Nim, so I
find it useful for language comparison purposes.
What I'd like some feedback on is how to improve the code
In the D Cookbook it has as part of the FibonacciRange example:
@property FibonacciRange save() { return this; }
And in the description it says:
"...save, which returns a new range that is a copy of the current
range and can be advanced independently..."
Why is this a *copy*? (For a copy
On Thursday, 30 January 2020 at 10:31:08 UTC, mark wrote:
In the D Cookbook it has as part of the FibonacciRange example:
@property FibonacciRange save() { return this; }
And in the description it says:
"...save, which returns a new range that is a copy of the
current range and can be
On Tuesday, 4 February 2020 at 09:21:17 UTC, Andre Pany wrote:
On Tuesday, 4 February 2020 at 09:13:48 UTC, mark wrote:
Is it possible to create a dub project that has one library
and one or more executables (that use the library)? If so,
could someone point me to the docs for this since I
I am starting on porting Python's difflib's sequence matcher to D.
I want to have a class that will accept two ranges whose elements
are of the same type and whose elements can be compared for
equality.
How do I make a class declaration that specifies a (forward)
range type and an
I forgot to mention: I want the class to work with:
Diff(aForwardRange, bForwardRange)
where T = ForwardRange, E = anything that supports ==
A common use case is for two sequences of strings (i.e., lines
read from two files).
Diff(aString, bString) where
T = char[] or wchar[] or dchar[] E =
On Thursday, 6 February 2020 at 15:21:46 UTC, Steven
Schveighoffer wrote:
[snip]
3. You should declare constraints signifying what types are
valid. i.e.:
class Diff(T) if (
isForwardRange!T // it's a forward range
&& is(typeof(T.init.front == T.init.front)) // elements are
comparable
On Thursday, 6 February 2020 at 16:29:57 UTC, Steven
Schveighoffer wrote:
On 2/6/20 11:05 AM, mark wrote:
src/package.d(50,35): Error: no property opCall for type
diffrange.Diff!(dchar[]), did you mean new Diff!(dchar[])?
Hah, forgot that it's a class. Yes, I DID mean new Diff ;)
-Steve
I forgot to mention: I know it isn't worth bothering with
const/immutable for this tiny example. But I want to learn how to
write large D programs, so I need to get into the right habits
and know the right things.
On Wednesday, 29 January 2020 at 11:57:14 UTC, Jan Hönig wrote:
On Monday, 13 January 2020 at 16:37:31 UTC, Ron Tarrant wrote:
On Monday, 13 January 2020 at 10:28:48 UTC, mark wrote:
I'm just starting out learning D.
Andrei Alexandrescu's "The D Programming Language" is 10
years old, so is
Thanks for your implementation.
I can't use the levenshtien distance because although it is a
better solution, I want to keep the implementation as compatible
with those in the other languages as possible.
Your main() is much shorter than mine, but doesn't match the
behaviour (and again I
I've done quite a few small corrections/improvements to the
D-tour's English. Almost all have been accepted.
However, four have not been accepted, apparently for technical
reasons. But I don't understand what's wrong or what I need to do
to fix them. (I'm not very knowledgeable about github.)
On Sunday, 2 February 2020 at 12:49:31 UTC, MoonlightSentinel
wrote:
On Sunday, 2 February 2020 at 08:54:02 UTC, mark wrote:
However, four have not been accepted, apparently for technical
reasons. But I don't understand what's wrong or what I need to
do to fix them. (I'm not very knowledgeable
Thanks Petar... I'm in no hurry, just glad that they're in
process:-)
I'm using std.zip.ZipArchive to read zip files, e.g.:
auto zip = new ZipArchive(read(filename));
// ...
foreach (name, member; zip.directory) {
if (name.endsWith('/')) // skip dirs
continue;
mkdirRecurse(dirName(name));
zip.expand(member);
Thanks for that thorough and careful explanation.
Since I'm trying to learn to write D in good style and want my
code to be reliable and maintainable, I've now switched to using
"" rather than null.
I have just discovered that D seems to treat empty and null
strings as the same thing:
// test.d
import std.stdio;
import std.string;
void main()
{
string x = null;
writeln("x = \"", x, "\"");
writeln("null = ", x == null);
writeln("\"\"= ", x == "");
writeln("empty
Just found this post by Mark Parker that explains:
https://forum.dlang.org/post/gvveit$10i5$1...@digitalmars.com
// test.d
import std.stdio;
import std.string;
void main()
{
report(null, "null");
report("");
report("x");
}
void report(const string x, const string name=null) {
Is it possible to create a dub project that has one library and
one or more executables (that use the library)? If so, could
someone point me to the docs for this since I couldn't find this
in the dub docs?
Aside: I'm learning D to give me something approaching the
convenience of Python with
Some languages support this kind of thing:
if ((var x = expression) > 50)
print(x, " is > 50")
Is there anything similar in D?
I am porting code from other languages to D as part of learning
D, and I find I've used sets quite a lot. AFAIK D doesn't have a
built-in set type or one in the std. lib.
However, I've been perfectly successfully using int[E] where E is
my ElementType, and adding with set[element] = 0. I
Thanks for the excellent replies.
On Friday, 7 February 2020 at 22:03:00 UTC, H. S. Teoh wrote:
On Fri, Feb 07, 2020 at 07:37:08PM +, mark via
Digitalmars-d-learn wrote:
[snip]
bool[E] works just fine.
[snip]
Or you can wrap void[0][E] in a nice user-defined type that
gives nice set-like syntax. But IMO, this is all
I have this code:
import std.random;
import std.stdio;
void main()
{
auto aa = ["one": 1, "two": 2, "three": 3];
writeln(aa);
auto rnd = rndGen;
auto word = aa.byKey.choice(rnd);
writeln(word);
}
And in the D playground it gives this error:
onlineapp.d(8): Error: template
On Saturday, 25 January 2020 at 08:59:23 UTC, Basile B. wrote:
On Saturday, 25 January 2020 at 08:35:18 UTC, mark wrote:
I have this code:
import std.random;
import std.stdio;
void main()
{
auto aa = ["one": 1, "two": 2, "three": 3];
writeln(aa);
auto rnd = rndGen;
auto word =
In the end I used this line since I'm not fussy about the rnd for
this:
auto word = compatibles.byKey.array.choice;
Thank you!
I'm porting a simple game to GtkD to learn the library and more
about D.
Unfortunately, I've hit a show-stopping crash.
I have a subclass of ApplicationWindow which has this method:
private void onChangeState(int score, Board.State state) {
import std.format: format;
Thanks for your question, it led me to focus on the Label and now
I've solved the problem.
I thought that onChangeState was never called before the Label
was constructed, but it turns out it is called before. So now I
use:
if (statusLabel !is null)
On Sunday, 9 February 2020 at 12:03:23 UTC, Ron Tarrant wrote:
On Sunday, 9 February 2020 at 11:52:19 UTC, mark wrote:
right now I want to start on Linux and I'm stuck.
Maybe this will help...
https://gtkdcoding.com/2019/03/31/x0002-gtkd-in-a-linux-environment.html
Unfortunately it didn't
Turns out I didn't need to add lines to dub.sdl at all. So my
dub.sdl is now just:
name "gtktest"
description "Gtk Test"
authors "Mark"
targetType "executable"
dependency "gtk-d:gtkd" version=">=3.9.0"
The solution was to do this:
$ dub add-path ~/opt/GtkD3/
After that it does static builds,
I found a much easier way to get GtkD working on windows than
that described in
https://gtkdcoding.com/2019/01/11/-introduction-to-gtkDcoding.html
1. I downloaded and installed the Gtk3 runtime (the link is on
https://gtkdcoding.com/2019/01/11/-introduction-to-gtkDcoding.html)
2. I
On Sunday, 9 February 2020 at 14:08:02 UTC, Daniel Kozak wrote:
"lflags-windows": ["/SUBSYSTEM:WINDOWS",
"/ENTRY:mainCRTStartup"],
[snip]
Is there a way to avoid the console Window, at least for
release builds?
Thank you! Your solution I guess is for dub.json.
For those using dub.sdl the
On Sunday, 9 February 2020 at 14:08:02 UTC, Daniel Kozak wrote:
"lflags-windows": ["/SUBSYSTEM:WINDOWS",
"/ENTRY:mainCRTStartup"],
[snip]
Is there a way to avoid the console Window, at least for
release builds?
Thank you! Your solution I guess is for dub.json.
For those using dub.sdl the
I use dscanner to lint my code and find it helpful.
However, in GtkD there are several functions which take ref args,
and these confuse dscanner.
For example:
uint kv;
event.getKeyval(kv); // ref arg is updated here
dscanner incorrectly (but understandably) reports:
On Saturday, 15 February 2020 at 07:23:02 UTC, Basile B. wrote:
On Thursday, 13 February 2020 at 17:15:50 UTC, mark wrote:
I'm starting out with GtkD and have this function:
[snip]
Otherwise here is an example of how you can tune the different
checks:
In the D tour example shown here
https://tour.dlang.org/tour/en/basics/ranges
there is the following import:
import std.range : drop, generate, take;
But generate is not used so I think it ought to be deleted to
avoid confusion.
101 - 200 of 266 matches
Mail list logo