Since the search on Magento Connect is horrible I created my own. Just to help you not searching the extensions for built-in features, I added the feature lists in the search:
Open the Magento Developer Dashboard
Since the search on Magento Connect is horrible I created my own. Just to help you not searching the extensions for built-in features, I added the feature lists in the search:
Open the Magento Developer Dashboard
Posted in Just Drops | Tagged magento | Leave a Comment »
Since both converting all those strange ooxml units manually and searching the OOXML specification is not possible anywhere else, I created a dashboard for OOXML Development. I’ll add stuff to it whenever I feel for it.
Open the OOXML Developer Dashboard.
Posted in Just Drops | Tagged docx, drawingml, dxa, emu, ooxml, wordml | Leave a Comment »
Isn’t this title funny? I like it
As I browse through the samples for the SQL Server Modeling CTP I find a lot of odd “M” code. This is sad, because Microsoft should know how to write “M” code. They are inventing it. Sure I’m expressing my personal opinion, but I think I have no hard time finding people that agree with me.
Why I do this in the “public”? Because I care! I like M and it’s concepts. For me M has the potential to become a great replacement for a variety of technologies. Most of all XSD, and maybe parts of SQL. That it comes with a SQL-code-generator is nice, though. But not too exciting. I still hope that the team adjusts their current direction. But more on that in a longer post
I’ll just start with one of the first samples I found:
It comes with four M-Files:
So, what again is the difference between one-to-many and many-to-one?
Well, this is OneToMany.m:
// original OneToMany.cs
module OneToMany {
type A {
Id : Integer32 => AutoNumber();
} where identity Id;
type B {
A : A;
} where value.A in As;
As : {A*};
Bs : {B*};
}
And this is ManyToOne.m:
// original ManyToOne.m
module ManyToOne {
type A {
B : B;
} where value.B in Bs;
type B {
Id : Integer32 => AutoNumber();
} where identity Id;
As : {A*};
Bs : {B*};
}
Do you spot the difference? I do! It would be easier to see, if we changed the ordering on the second one. Now compare this to the first one.
// reordered ManyToOne.m
module ManyToOne {
type B {
Id : Integer32 => AutoNumber();
} where identity Id;
type A {
B : B;
} where value.B in Bs;
Bs : {B*};
As : {A*};
}
Do you see it now? Exactly. The XPath-function translate(‘AB’, ‘BA’) would have done the job! There is exactly NO difference between except for A and B switched around!
Usually the relationship the sample tries to illustrate is called one-to-many, even though in relational databases the reference goes from the many to one.
The funny part is over. Lets look at one-to-one and many-to-many.
This is OK. Although I do not like how coupled the code is. If I used the same style to express the same intent in C# people would blame me for violating every single principle we have learned over the past couple of years. I’ll write about what bothers me here in another post sometime.
// original OneToOne.m
module OneToOne {
type A {
Id : Integer32 => AutoNumber();
} where identity Id;
type B {
A : A where value in As;
} where unique A;
As : {A*};
Bs : {B*};
}
// original ManyToMany.m
module ManyToMany {
type A {
Id : Integer32 => AutoNumber();
} where identity Id;
type B {
Id : Integer32 => AutoNumber();
} where identity Id;
As : {A*};
Bs : {B*};
type AB
{
ReferencedA : A;
ReferencedB : B;
} where value.ReferencedA in As && value.ReferencedB in Bs;
ABs : {AB*};
}
What is that. Natural modeling? What you really want to say is, that A has a n2m-Relationship with B, right? Now tell me, how this M-code is any better than SQL! It does not raise the level of abstraction, at least! IMHO this is not a solution for something that claims to be a modeling language, it’s a hack.
In“M” when you model something that naturally would be called a hierarchy or containment, the SQL compiler projects it as n2m anyway.
Actually M doesn’t really support relationships (or associations) at all today. It just knows about references. What the difference is?
I’m not too sure if I get it right, but I’ll try.
A relationship is always coherent and integer. Something both sides agree on.
A reference, though, is just something holding on something else.
In relational databases relationships are modeled using references plus constraints.
So for example saying to the man, that he isn’t allowed to move as long as this baby holds his finger, you would enforce something that could be called an relation.
I think samples of this quality rather chase away people than buying them into the language. The language team should review all the documentation and samples. They should discuss them and give good guidance.
What I’ve seen so far is rather bad guidance.
Update: Also check out the MSDN Documentation on Relationships. It’s at least better than the samples. (found it after I wrote this post)
Posted in SQL Server Modeling, oslo | Tagged M, msoslo, review, sqlmodeling | Leave a Comment »
After I got confused with the Office Open XML (OOXML) measuring units for a couple of hours, I thought I’d share what I found on it.
I order to avoid floating point calculations and still maintain high precision the format uses some odd measurement units. Don’t think you can get away with inches, centimeters or pixels!
UPDATE: I created a conversion tool for all those units, available here.
The main unit in OOXML is a twentieth of a point. This is used for specifying page dimensions, margins, tabs, etc.
The international default letter size is ISO 216 A4 (210×297mm ~ 8.3×11.7in) and expressed as this:
// pageSize: with and height in 20th of a point <w:pgSz w:w="11906" w:h="16838"/>
Calculations
| 20th of a Point | Points (dxa/20) |
Inches (pt*72) |
Centimeters (in*2,54) |
|
| Width | 11906 | 595.3 | 8,27… | 21.00086… |
| Height | 16838 | 841.9 | 11.69… | 29.70036… |
As you see it doesn’t really come out even, but even enough. As you can see here, word processes files at 72dpi.
Half-points are used to specify font sizes. A font-size of 12pt equals 24 half points:
// run properties <w:rPr> // size value in half-points <w:sz w:val="24"/> </w:rPr>
This is used for relative measurements in some places. It can for example be used for specifying tables total with, cell with and margins.
<w:tbl>
<w:tblPr>
<!-- table width in 50th of a percent -->
<w:tblW w:w="2500" w:type="pct"/>
</w:tblPr>
<w:tblGrid/>
<w:tr>
<w:tc>
<w:p>
<w:r>
<w:t>Hello, World!</w:t>
</w:r>
</w:p>
</w:tc>
</w:tr>
</w:tbl>
This prints a table that takes 50% of the available with. If you want to specify the with in twentieth of points instead, you have to use specify w:type=”dxa”.
Calculation
0.5 * 5000 = 2500pct
or
(50*50)%
EMUs are used for coordinates in vector-based drawings and embedded pictures. The EMU is a virtual unit to bridge both centimeters and inches. One inch equates to 914400 EMUs and a centimeter is 360000. Actually I found out that the number 914400 is calculated by (the least common multiple of 100 and 254) times 72. As I understand it, this ensures that you can convert forth and back between integer 100th inches, millimeters and pixels with out any floating points. Is that correct, anybody?
Since OOXML is too verbose, the full markup would just confuse even more. Lets say we have a picture that we want to fit into a table cell.
The cell with is 4,25cm which equals to 2410 dxa.
<w:tcW w:w="2410" w:type="dxa"/>
The original picture is 295×413px at 72dpi and is embedded using DrawingML. The target picture size in the document has to be specified twice. Once for the drawing canvas (extent) and a second time for the embedded picture itself.
When you try to draw this in word itself you’ll have a hard time to match the actual cell size. This version is set by manually calculating the target picture size.
<w:drawing>
<wp:anchor ...>
...
<!-- drawing canvas size -->
<wp:extent cx="1530350" cy="2142490"/>
...
<a:graphic>
<a:graphicData>
<pic:pic>
...
<!-- shape properties -->
<pic:spPr bwMode="auto">
<!-- 2D transform -->
<a:xfrm>
...
<!-- picture size -->
<a:ext cx="1530350" cy="2142490"/>
</a:xfrm>
...
</pic:spPr>
</pic:pic>
</a:graphicData>
</a:graphic>
</wp:anchor>
</w:drawing>
Calculations
| 20th of a Point | Points (dxa/20) |
Inches (pt/72) |
EMU (in*914400) |
|
| Cell Width | 2410 | 120.5 | 1,67361… | 1530350 |
Even though this is the most logical way to calculate it, it involves floating points. You can simply avoid those by calculating:
2410 * 914400 / 72 / 20 = 1530350
which can be simplified to:
2410 * 635 = 1530350
Since we want to maintain the aspect ratio of the original picture at 295:413 we have to calculate the height for the cell in dxas and for the pictures in EMUs.
The width-to-height-ratio for this picture is 1.4. So the height for the cell is 2410*1.4 = 3374 dxa and 3374*635 = 2142490 emu.
Thanks for reading! I hope this helps.
Posted in Office Open XML | Tagged dpi, drawingml, emu, inch, measurements, Office Open XML, ooxml, points, wordml | Leave a Comment »
I finally found some time to migrate two of my pet projects from the “Oslo” May CTP to the new SQL Server Modeling November 2009 CTP. I didn’t publish the sources so far, but I will soon.
The first application that I want to migrate is a so-called work-breakdown-sheet (WBS). Originally it was a Excel sheet containing tasks and task estimates. Some smart calculations apply a set of statistics to give a forecast that is as close as possible to the real effort required.
The technologies I wanted to try out with that were mostly “Quadrant” and the “Repository”, now SQL Server Modeling Services. Also I wanted to test the team on their ambitious goal to make something that gets close to the experience of Access in ease of use.
The project contains of a set of “M”-based models and functions as well as some basic “Quadrant” customization. No plain old C# code needed, so far.
The basic domain model expressed in M (May CTP):
type Project {
Name : Text;
};
type Story {
Name : Text;
Project : Project;
};
type TaskGroup {
Name : Text;
Story : Story;
};
type Task {
Description : Text;
Comment : Text?;
Group : TaskGroup;
};
type Estimate {
BestCase : Double;
AverageCase : Double;
WorstCase : Double;
} where value.BestCase < value.AverageCase
&& value.AverageCase < value.WorstCase;
I’ll write an introduction to the project soon. But now, I’ll just log the changes I had to make in order to be able to get it running on the new CTP.
In May, both Visual Studio and Intellipad used a *.mproj-File to collect multiple models in a project. In November this is embedded in a *.csproj-File. The easiest thing was to create a new “Oslo Library” in VS 2010 and just add the files that previously were linked in Wbs.mproj.s
Now I got the project both in Visual Studio 2010 and in Intellipad:
Now lets build.
Lets walk through the errors I get, and how the syntax has to be changed to fix them.
So lets switch over to VS. The Messages I get are:
Those were easy to fix. Although the error messages look more explaining then they are.
Actually both first errors had to do with the new collection syntax. This goes for extent declarations as well as functions. This, for example:
TaskEstimates() : PersonalTaskEstimate* {
from e in RawTaskEstimates
select MixEstimates(CalculateEstimate(e), e)
}
Needs to be changed to:
TaskEstimates() : {PersonalTaskEstimate*} {
from e in RawTaskEstimates
select MixEstimates(CalculateEstimate(e), e)
}
The warning about the deprecated item keyword in:
RawStories : (Story & HasFolderAndAutoId)*
where item.Project in RawProjects;
is solved by using value plus making sure, that the constraint goes inside the collection.
RawStories : {((Story & HasFolderAndAutoId)
where value.Project in RawProjects)*};
After having fixed those I get a next set of errors:
This seems to be a implicit change enforced by the new type checker in the current CTP. This is the “invalid” code:
type LifelikeEstimateNumber : Double where value < 24
|| value in SomeFibonacciNumbers;
type SomeFibonacciNumbers : {55, 89, 144, 233, 377, 610};
The problem here is, that the compiler doesn’t infer that SomeFibonacciNumbers actually is a collection of Doubles. So we have to tell her.
There are different ways to do so. We can either ascribe the first value in the collection to a Double by writing:
{55: Double, 89, 144, 233, 377, 610}
or we could ascribe the whole collection to a collection of Doubles
{55, 89, 144, 233, 377, 610} : {Double*}
or we can mix it with a collection of Doubles:
{55, 89, 144, 233, 377, 610} & {Double*}
I don’t really know, what the differences will be. I’ll just go for the last one, because it looks so nice
The next problem is, that my references to models from the “Repository” and “Quadrant” can’t be found. Sure, I didn’t copy the references from the mproj-file, either. As described here, you now have to reference dll files instead of the mx-files that where needed in May.
In my case, I needed a reference to “C:\Program Files\Microsoft Oslo\1.0\bin\Repository.dll” in order to support the SQL Server Modeling Services type HasFolderAndAutoId.
Now all the “M” code seems to be ok. The only thing is, that some concepts do not compile to SQL.
For this code:
type LifelikeEstimateNumber : Double where value < 24
|| value in SomeFibonacciNumbers;
type SomeFibonacciNumbers : {55, 89, 144, 233, 377, 610} & {Double*};
type TaskEstimate : (Estimate & {
Task : Task;
}) where value.BestCase in LifelikeEstimateNumber
&& value.AverageCase in LifelikeEstimateNumber
&& value.WorstCase in LifelikeEstimateNumber;
i get the following error for each occurence in the last three constraints:
It seems, that the constraint expressions can’t handle types completely. I’ll just refactor that to an inline expression plus an extent for the allowed high estimates:
AllowedHighTaskEstimates : {Double*} {
55, 89, 144, 233, 377, 610};
type TaskEstimate : (Estimate & {
Task : Task;
}) where
(value.BestCase < 24
&& value.BestCase in AllowedHighTaskEstimates)
&& (value.AverageCase < 24
&& value.AverageCase in AllowedHighTaskEstimates)
&& (value.WorstCase < 24
&& value.WorstCase in AllowedHighTaskEstimates);
Build succeeded!
Well I cheated a little bit, because I removed the models that drive the quadrant customization. But since those have changed completely anyway, I’ll just rebuild the requirements.
For the May CTP I had a bunch of batch files to manage the build and deploy process. This was also, because I had to install a external SQL function before deploying my module. Lets see how this works with the deployment integration in Visual Studio 2010.
I configured the connection string in the M Deploy settings to a local database called ‘WbsTestRepository’. But trying to deploy the solution fails with a couple of errors. It seems, that the repository is not deployed automatically, allthough I added a project reference.
In Wbs I want to use the Repository (now SQL Server Modelling Services) Rolders as well as the catalog which stores data about my models.
You still need to install the “Repository” on your database using the command line. This should be necessary only once, though.
The commands I ran were (described here):
'create a clean db mx create /d:WbsTestRepository /s:.\SQLExpress /force 'install the rep mx install Repository.mx /database:WbsTestRepository /server:.\SQLExpress
But now redeploying in VS yields another expected error:
Wbs needs the power-function to compute some values. Since M doesn’t know about it, and neither can express it natively, I had to model an so called extern:
extern Power(Expression : Double, Power : Integer32) : Double;
This just makes a concept available to M that has to be implemented in SQL. Since we want to ensure this in the installation, we have to compile it along with the M files. This is done by adding a SQL file containing the “create function [itemis.Wbs].[Power] …” script and set the compile action to “MPreSql”.
As I almost expected, redeploying the model doesn’t work. I’ll post a workaround for that soon.
But for now we just put the two lines in a batch file to recreate a fresh repository before each deploy.
The next problem I run into is:
There are two ways to add a target folder to your initial values. The documented one suggests adding your Folder to the FoldersTable and then specifying that value in every single instance. The much cleaner and simpler is, too set the target folder globally for the whole project.
Since there is no Visual Studio support for that, you have to add this property to the csproj-File manually:
<MTargetFolder>Repository/Wbs</MTargetFolder>
You will also have to create the folder along with the repository every time you deploy, using the following command:
mx createFolder "Repository/Wbs" /database:WbsTestRepository /server:.\SQLExpress
The next thing is some complaints about my constraints on TaskEstimate. Since I have no time left, and those constraints should be weak, instead of hard CHECK constraints anyway, I’ll just comment them "away” for now.
Deployed successfully.
Wonderful. Now lets go to “Quadrant” and see, how we can make use of the model with it’s sample data.
It were not really the syntax changes that made trouble, but rather the integration with Visual Studio. I had a couple of simple customizations for Quadrant, but I’ll rewrite them soon.
The only comment I have to make so far, is, that it is totally unacceptable to have a development cycle that takes more than 5 seconds from M over compile, deploy and look at the changes in Quadrant. Now it takes more than 30 seconds. Most of it is the
I’ll probably elaborate more on WBS next week. I’ll also migrate my DSL pet project called “Web Layout DSL” and integrate it with a MVC Client Application over WBS.
So stay tuned.
Posted in SQL Server Modeling, oslo | Tagged M, Quadrant, sqlmodeling, sqlmodelingservices, wbs | 1 Comment »
This years PDC was great. I think the big deal this year was “Integration”. I’ve never seen so many bits working together at such an early state.
I’ll walk through what I’ve seen and provide some detailed information plus the corresponding downloads I’ve found. It is insane, how many CTPs and Betas Microsoft offers right now.
These are the topics I will cover. Click to jump to the corresponding section.
I’ll start with Visual Studio, because it spans all of it.
In the last years especially Visual Studio was lagging behind. It didn’t even have good support for debugging LINQ in C# – what could we then expect from integration with other products from Microsoft.
But now Visual Studio comes not only with an improved debugger, but also with many, many new project templates, enhanced deployment features for web and SharePoint, an extension manager bound to an online extension gallery, and many-many more features.
Maybe the reason for the more integrated development environment is the huge improvement in Visual Studio Extensibility. Download the SDK if you plan to write your own plugins.
If you want to know more about the “.NET Framework 4.0”, Google has a good coverage on “C# 4.0”, “Windows Workflow 4.0”, “Windows Communication Foundation 4.0”, “Entity Framework 4.0” …
Maybe the announcements around Silverlight 4 were the biggest. The Silverlight team has made incredible progress in the last couple years. With Silverlight 4 they seem to eliminate most of the drawbacks it had compared to WPF. I can’t see yet where this goes, but a Silverlight OS could absolutely be a nice answer to the Chrome OS. And then we are back to terminals and mainframes.
Among the new features are a better out-of-the-browser experience including full-trust mode. Also new is webcam and microphone access, a richtext/html editor and a browser control. The browser control can also embed flash. And it can be used as a brush, in other words, it lets you run YouTube videos while applying any Silverlight effects.
After the entity framework came out in V1, many of the industry’s thought leaders called it a joke. The team has tried to incorporate most of that Feedback in EF V2 (Called V4 to align with .NET 4).
Together with the .NET Framework 4 Beta 2 and the Futures CTP you get code-only and model-first including SQL schema generation. There are also alot improvements in the designer and the query performance. Haven’t really checked out the details so far.
The Open Data Protocol (OData) has been developed to support a convention-oriented REST-style API over data of any kind. It builds on atom/pub and adds optional metadata, querying and projections. Using the .NET OData Client (WCF Data Services) you can use LINQ against any OData source. Sharepoint 2010 will expose all data via OData. Any application that uses the Entity Framework can very simply expose it’s data over the protocol.
Also SQL Server Excel PoverPivot (neé Gemini) supports OData and lets you interact with huge amounts of data the Excel-way.
In a couple of sessions Doug, Chris, Don and Chris showed the new features in the November CTP. The team has made some progress, although it is easy to see, that they have much homework left. Some of the new features are the better Visual Studio Integration, a ASP.NET MVC project supporting “M” for the M in MVC, debugging support in DSLs, richer right-hand grammar productions, support for views in “Quadrant”. Also the Modeling Services where officially announced to be part of SQL Server in some future release.
I’ll spend a new post on more of the changes soon.
Also, today I think, that Quadrant will not replace the DSL Tools in Visual Studio. Those have made much progress and will rather be improved and merged with “M”.
No matte who I asked, nobody liked SharePoint development so far. From what I’ve seen this might change in the future. There has been much focus on the developer experience for SharePoint customization. Deployment and packaging seems to be much more fluent, and the horrible SharePoint web service interfaces will be superseded by the new generic OData implementation over lists and libraries. There is also better support for embedding Silverlight, and Microsoft finally promises a good user experience even when using Firefox or Safari.
I just like Office 2010, but I haven’t done any customization for Office since the good old VBA times. I think the web-versions of Office built into SharePoint are really cool. They allow collaborative editing like in Google Docs. I’ll check out this stuff soon!
In the last couple of weeks I had to do a lot with SQL Server. The thing is, still devs do not care much about new SQL Server versions. They do rather talk about persistence ignorance. Even the Xml/XQuery implementations well the hosting of the CLR inside the SQL Engine did not really touch the developers hearts.
But often the heart of the application is data. And the more you have to do with it with fast response times, the closer you’ll have to operate on it. Another argument is, that Microsoft emerges the brand “SQL” from a relational RDBMS engine to a data platform including Analysis Services, Reporting, Integration Services, and so on …
Some of the new features are StreamInsight, the Excel PoverPivot plugin and more…
“Dublin” was Microsofts promise to deliver a more manageable Application Server for .NET, WF and WCF solutions. But since it was announced there were no public CTPs or anything that we could have played around with.
At the same time “Velocity”, a memory cache, has had more publicity.
Those two are now merged in the AppFabric, promising a reliable host for the workflow foundation runtime and hopefully in the future a good replacement for NT services.
There have been rumors, that it enters the space of EAI, that BizTalk tried to cover so far. But the promise is, that they have different intents and will play nicely together.
I’m not into it yet. But it looks promising. Let me just provide the links to the downloads I found.
The .NET Service Bus is really interesting stuff. Somebody explained it as “Skype knowledge in a box”. This means, the .NET Service Bus helps you to set up secure duplex communication channels through firewalls and routers. It just leads your calls through the NAT jungle.
What you simply do, is creating a public namespace on “the internet”, where you then register your WCF service. Clients may then access your service through the Azure Cloud. Bye, bye DMZ!!
You can also use it to negotiate the connection details and then have it set up a direct TCP/IP connection between your server and the calling client.
In both modes, you’ll also be able to send messages to your clients, through all this expensive infrastructure that is intended to avoid those scenarios
The .NET Service Bus is part of the .NET Services SDK which also contains the Access Control Service and Workflow Services in the cloud.
Federated claims-based security. Everybody is talking about it. After Microsoft tried to reach through with Card Space and Live ID, this finally seems to be their answer to OpenID.
I’ll definitely take some time digging into it. I’m also interested in how it interacts with the SQL Server Modeling Services for System.Identity.
Windows 7 is great! What I’m interested in most, is multi-touch. I think this will be the default for every monitor and notebook in just a couple of years.
If you find any nice multitouch enabled applications, please give me a hint at http://multitouch-apps.com.
Have fun!
Posted in dotnet | Tagged appfabric, azure, dotnet, dotnet4, dotnetservicebus, downloads, entityframework, entityframework4, identity, odata, office, pdc09, servicebus, sharepoint, silverlight, silverlight4, sqlmodeling, vs2010, wcfdataservices, windows7, windowsidentity | 1 Comment »
Bin gerade von meinem Vortrag bei der Usergroup bonn-to-code zurück. Und da sofort schneller geht als irgendwann, habe ich direkt mal die Slides gepostet.
Posted in Deutsch, Talks & Presentations, dotnet | Tagged c#, variance | 3 Comments »
I have heard a couple of variations of these analogies. I do not like them. I think they are simply absurd.
At last PDC, “M” was to “SQL” what C is to Assembler. This year it was, what VB is to C. And now I even read this:
The code name “M” language is like a more manageable (though more limited) form of Transact-SQL, the language normally used to describe data schema and values.
Kraig Blockschmidt, Microsoft Data Development Technologies: Past, Present, and Future
“M” has some overlaps with T-SQL, ok. But far from every concept in “M” can be translated into T-SQL. What about structural subtyping? Types without identities? Polymorphic references and function arguments? Languages/DSLs? Ordered collections? Lot’s more.
And only a very small, although useful subset of T-SQL maps to “M”. Also most of the translation to SQL is opinionated, not natural.
What the schema and values part of M compares much more to, is XML and XSD.
Would you even try to compare XML to T-SQL?
Posted in SQL Server Modeling, oslo | Tagged M, msoslo, sqlmodelling, tsql | 12 Comments »
After it was hard for me to find any multitouch applications on google or bing, I decided to at least collect those I find on a list and accept submissions for that list.
Some day, I’ll create a multi-touch enabled multi-touch application gallery at http://multitouch-apps.com. But until then enjoy what I’ve found so far and please comment you submissions.
Open here: The Ultimate List of Multitouch Applications
Posted in Just Drops | Tagged multitouch, win7 | 1 Comment »
Beim nächsten Bonn-to-Code-Usergroup-Treffen halte ich einen Kurzvortrag zu Ko- und Kontravarianz in C#.
Eines der meistbegrüßten Features aus .NET 4 und gleichzeitig eines der am wenigsten verstandenen. Leicht dahergesagt, dass Argumente von Methoden und Delegates schon immer kontravariant waren. Und dass in C# 4.0 jetzt noch sichere Ko- und Kontravarianz für generische Typparameter hinzukommt. Und weil man das mit Ko- und Kontra so schnell verwechselt heißt es jetzt einfach "out" und "in". Oder war das andersrum? Nicht ganz sicher?
Ich kann schonmal so viel verraten, dass ich mich sogar an selbstgemalten Bildchen versuchen werde. Außerdem kommen Tiger und Schlangen vor!
Posted in Deutsch, Talks & Presentations | Tagged c#, community, german, presentation | 1 Comment »