|
Let me see if I understood this correctly, you have a console application with a few classes you added on your own ?
If so, you should call functions from your classes in the console application's main function.
Edit: if you have multiple projects, you can just set one as a startup project and run that one.
|
|
|
|
|
|
You can't execute classes. Methods CAN be executed. A console-app will have one (1) method that gets executed when the application starts. From there, you can create other classes and call methods on them.
I'd recommend the book "Head First C#".
Bastard Programmer from Hell
If you can't read my code, try converting it here[^]
|
|
|
|
|
I attempted to create an extension method for a list of my data. For example:
public static class MyExtensions
{
public static List<Foo> GetModified(this List<Foo> list)
{
if ((list == null) || (list.Count == 0))
{
return null;
}
else
{
return list.Where(r => r.IsDirty).ToList();
}
}
}
The code was compiled without any error. The problem is how to consume the feature. The following code does not compile since the extension method can’t be found:
fooList.GetModified();
It appears I need to create a class to wrap up the List of Foo, which is what I try to avoid and keep my code simple. Does anyone know how to call this extension method without create a list wrapper? If not, why doesn’t the compiler present a message for the extension mothed? Is the extension method just syntax correct but can’t be invoked? Sounds odd?
|
|
|
|
|
Add reference and using for the assembly containing the extension method...
Skipper: We'll fix it.
Alex: Fix it? How you gonna fix this?
Skipper: Grit, spit and a whole lotta duct tape.
|
|
|
|
|
I might be mistaken, but I don't think you can create extension methods for a specific generic type. You need to create it for the generic itself (List<T>) and then add a constraint.
public static List<T> GetModified<T>(this List<T> list)
where T : Foo
{
}
something like that... the IDE will filter intellisense on the constraint as well.
|
|
|
|
|
You are mistaken.
https://dotnetfiddle.net/IzJQpY[^]
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
Oh well .
My way is better anyways since you can constraint against multiple interfaces at the same time. You'd have to write a specific exception for each type if you did it your way.
|
|
|
|
|
Interesting, I can't reproduce your compile error in FrameWork 4.5.1. I note the apparently strange fact that you are not assigning the result of the call to 'GetModified to any variable, so the result goes into outer-space.
This works for me:
public static class Extensions
{
public static List<Foo> GetModified(this List<Foo> list)
{
if ((list == null) || (list.Count == 0)) return null;
return list.Where(r => r.GetThisFooDirty()).ToList();
}
}
public class Foo
{
public string Name { private set; get; }
private bool ThisFooIsDirty { set; get; }
public bool GetThisFooDirty() { return ThisFooIsDirty; }
public void SetThisFooDirty(bool dirtyness) { ThisFooIsDirty = dirtyness; }
public Foo(string fooName)
{
Name = fooName;
ThisFooIsDirty = false;
}
} Test:
List<Foo> fooList = new List<Foo>
{
new Foo("foo1"),
new Foo("Foo2"),
new Foo("Foo3")
};
fooList[1].SetThisFooDirty(true);
fooList[2].SetThisFooDirty(true);
var whoIsDirty = fooList.GetModified(); Now, I'm going to go wash my mouth out with soap.
«OOP to me means only messaging, local retention and protection and hiding of state-process, and extreme late-binding of all things. » Alan Kay's clarification on what he meant by the term "Object" in "Object-Oriented Programming."
modified 12-Dec-14 0:09am.
|
|
|
|
|
BillWoodruff wrote: I can't reproduce your compile error in FrameWork 4.5.1.
BillWoodruff wrote: This works for me: That's because from where you have written your "Test" code, the Extensions class is accessible (and so is the extension method).
Your time will come, if you let it be right.
|
|
|
|
|
That's certainly a logical hypothesis: to assume the problem is no-access because (probably) the NameSpace qualifier is missing, and the calling context did not 'import a valid reference that would allow the method to be used without full qualification.
It is true, though, that classes can be defined outside of any 'named NameSpace, and the compiler will stick them in the "global" default NameSpace, although I'd consider any code that used that as probably "smelling"
«OOP to me means only messaging, local retention and protection and hiding of state-process, and extreme late-binding of all things. » Alan Kay's clarification on what he meant by the term "Object" in "Object-Oriented Programming."
|
|
|
|
|
Hello all,
I have applied EF Code-First to Existing Database like this :
1- Created an ADO.NET Entity Data Model
2- Chose Code First from Database
All of the classes generated correctly, except there are a lot of [Key] tags before most of the properties. Should I remove them from unnecessary ones?
Another question is, how can I be sure that EF kept the one-to-many or many-to-many relationships? There is nothing like :
public virtual ICollection<Post> Posts { get; set; }
Thanks in advance.
|
|
|
|
|
|
HI,
I want to superimpose two picture boxes and make the top picture box image transparent.
Thanks in advance
|
|
|
|
|
What type of bitmap is in each of the two PictureBoxes: .png with transparency ? or ... ?
There are several ways you can approach this, and I suggest you start by reading/studying this CodeProject article: [^].
And, then, read the discussion here: [^].
If these references don't assist you to get what you want, then please post more details here, and describe what you've tried, and any error messages.
«OOP to me means only messaging, local retention and protection and hiding of state-process, and extreme late-binding of all things. » Alan Kay's clarification on what he meant by the term "Object" in "Object-Oriented Programming."
|
|
|
|
|
Looking for a simple example (with how to) for a USB plug in and unplug condition. I think I use VID PID?
|
|
|
|
|
For searching, use Google. It will point to this[^] article.
Bastard Programmer from Hell
If you can't read my code, try converting it here[^]
|
|
|
|
|
I want to write the regular expression for the below condition.
1. Allow only A to Z, a to z but not I,O,X and also not 0 to 9
Means if string have a character from I,O,X or digit then it should return false.
Would anyone please help me how to do this?
|
|
|
|
|
Try:
[A-HJ-TP-WYZa-z]*
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
Thanks for the reply but unfortunately it is not working for the below mentioned string
1. "I"
2. "IO"
3. ABCIO
4. IABCOX
In these type of strings, the result should be FALSE but using this expression [A-HJ-TP-WYZa-z]* it is giving TRUE.
|
|
|
|
|
And exactly how did you use it?
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
|
|
|
|
|
I think anchoring the ends of the pattern that Griff gave will do what you want:
^[A-HJ-TP-WYZa-z]*$ This says that everything in the string must meet these conditions.
And if an empty string is not permitted, change the asterisk to plus:
^[A-HJ-TP-WYZa-z]+$
A positive attitude may not solve every problem, but it will annoy enough people to be worth the effort.
|
|
|
|
|
We both missed that the pattern itself was broken:
^[A-HJ-TP-WYZa-z]*$ should be:
^[A-HJ-NP-WYZa-z]*$
(The T should be N.)
A positive attitude may not solve every problem, but it will annoy enough people to be worth the effort.
|
|
|
|
|
See my reply to Griff's comment below.
(I should have replied here...)
A positive attitude may not solve every problem, but it will annoy enough people to be worth the effort.
|
|
|
|
|
I don't think there's "direct" way to do that unless you specify the characters in the expression.
Why not simply use [IOX0-9]+ and invert the match condition?
[EDIT]
Of course you will need to handle the case with the lower case characters - either with RegexOptions.IgnoreCase flag or by specifying appropriate characters in the expression itself.
[/EDIT]
Your time will come, if you let it be right.
modified 11-Dec-14 3:46am.
|
|
|
|