|
Please read correctly! That's real C# because I wrote in pure C# because C/C++ and C# are not same like I wrote without const because I write only in C# and static int Main(string[] args) {...} it means not in C/C++ that's why You need to read carefully.
Check correct my code in starting post:
static int Main(string[] args)
{
printf(CharPointerFromString($"Hello {"DeafMan1983"}!\n"));
}
Where is C/C++ style?
int main (int argc, char** argv)
{
....
return 0;
}
Thanks!
|
|
|
|
|
You are right, I misread some parts.
|
|
|
|
|
It's okay, no worries! I respect everyone.
|
|
|
|
|
My bad. I saw the bottom cod e snippet and assumed the rest was the same language.
|
|
|
|
|
If you don't have a "path", then Path.GetFileName does nothing for you.
This makes more sense in the present context:
string text_txt = "text.txt";
(I didn't try to reproduce your issue).
"Before entering on an understanding, I have meditated for a long time, and have foreseen what might happen. It is not genius which reveals to me suddenly, secretly, what I have to say or to do in a circumstance unexpected by other people; it is reflection, it is meditation." - Napoleon I
|
|
|
|
|
Just a guess...
Try 'text12.txt' and see what happens.
|
|
|
|
|
|
Quote:
char[] charArr = new char[str.Length];
for (int i = 0; i < str.Length; i++)
{
charArr[i] = str.ToCharArray()[i];
} That code is horrendously inefficient!
Every call to the ToCharArray method[^] creates a new array containing a copy of every character in the string.
For a string of 100 characters, you are creating 101 copies of that string, just to return a single copy.
Either use:
char[] charArr = new char[str.Length];
for (int i = 0; i < str.Length; i++)
{
charArr[i] = str[i];
} or simply:
char[] charArr = str.ToCharArray();
Quote:
fixed (char* charPtr = charArr)
{
return charPtr;
} As suggested by the enclosing braces, the fixed keyword[^] pins a managed object until the end of the enclosing block.
You return the pointer from the method, which escapes the fixed block. Once you do that, there is no guarantee that the pointer will still be valid. The GC is free to move the array around in memory as much as it wants. Whilst it may appear to work in your simple test, you can guarantee that as soon as you try to do this in "real" code running on a production system, the GC will kick in at the most inconvenient moment, move your array, and leave you with either an impossible-to-diagnose crash, or worse, corrupt data.
It's not entirely clear what you're trying to do with these functions. But what is clear is that they're not going to do what you expect them to.
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
Hello I am back.
I have tried but I am glad because I found solution.
namespace DeafMan1983.Interop.Runtime.Utilities;
using System;
public static unsafe class UtilitiesForUTF16
{
/*
* string from char* (UTF16)
*/
public static string CharPointerToString(char* ptr)
{
if (ptr == null)
return string.Empty;
<pre>
int length = 0;
while (ptr[length] != '\0')
{
length++;
}
return new string(ptr, 0, length);
}
/*
* char* (UTF16) from string
*/
public static char* StringToCharPointer(string input)
{
if (input == null)
return null;
char* utf16Ptr = stackalloc char[input.Length + 1];
fixed (char* inputPtr = input)
{
for (int i = 0; i < input.Length; i++)
{
utf16Ptr[i] = inputPtr[i];
}
inputPtr[input.Length] = '\0';
return inputPtr;
}
}
/*
* It works like strlen, but it uses only char* (UTF16)
/
public static int CharPointerLength(char charPtrs)
{
if (charPtrs == null)
return 0;
int length = 0;
while (charPtrs[length] != '\0')
{
length++;
}
return length;
}
}
And I resolved it:
1 Test:
Shows Console.WriteLine() :
string string_str1 = "Hello World!";
char* char_str1 = StringToCharPointer(string_str1);
Console.WriteLine($"Result: {CharPointerToString(char_str1)}");
Console.WriteLine($"Length of CharPointer: {CharPointerLength(char_str1)}");
char* char_str2 = stackalloc char[] { 'H', 'e', 'l', 'l', 'o' };
string str2 = CharPointerToString(char_str2);
Console.WriteLine($"Result: {str2}");
Console.WriteLine($"Length of CharPointer: {CharPointerLength(char_str2)}");
Picture 1
And I tested with WinAPI ( TerraFX.Interop.Windows )
I have tested it and it won't show Chinese Language
Picture 2
I am very excited to resolve it.
But I don't know if It works fine. I hope it works anything if UTF16 says wrong like Chinese Fonts show up then we need add some Encoding....
|
|
|
|
|
I have in my view model the following code:
public DateTime? Activation_Date { get; set; }
public DateTime? Deactivation_Date { get; set; }
On the form, if I put the date as "abc" and click Save, I get the following validation error:
The value 'abc' is not valid for Activation_Date.
What I simply want is to modify Activation_Date. I want it to be "Activation Date" so the message will look like below. The end user doesn't want the underscore.
The value 'abc' is not valid for Activation Date.
View Code to display error messages
@Html.ValidationMessageFor(s => s.Activation_Date)
What is the technique to make this kind of change ?
|
|
|
|
|
The ValidationMessageFor extension method has an override that accepts a custom validation message as the second parameter.
@Html.ValidationMessageFor(s => s.Activation_Date, "Where we're going Marty, we don't need roads");
|
|
|
|
|
Hi Pete,
It doesn't work for me.
@Html.ValidationMessageFor(s => s.Activation_Date, "Activation Date is invalid");
1. I always have "Activation Date is invalid" visible beneath the activation date input field
2. Secondly, I have other validation error messages in a Validator class for Activation_Date field
RuleFor(x => x.Activation_Date).NotEmpty().WithMessage("Activation Date is required");
RuleFor(x => x.Activation_Date).GreaterThanOrEqualTo(DateTime.Today).WithMessage("Activation Date must be greater than or equal to the current date");
|
|
|
|
|
You appear to be mixing FluentValidation with ASP MVC Validation. I would choose one and stick with that. In this case, FluentValidation is going to be more flexible for you.
|
|
|
|
|
I have this code
public static void Main(string[] args)
{
var dir = @"C:\temp\TestDir";
PrintDirectoryTree(dir, 2, new string[] { "folder3" });
}
public static void PrintDirectoryTree(string directory, int lvl, string[] excludedFolders = null, string lvlSeperator = "")
{
excludedFolders = excludedFolders ?? new string[0];
foreach (string f in Directory.GetFiles(directory))
{
Console.WriteLine(lvlSeperator + Path.GetFileName(f));
}
foreach (string d in Directory.GetDirectories(directory))
{
Console.WriteLine(lvlSeperator + "-" + Path.GetFileName(d));
if (lvl > 0 && Array.IndexOf(excludedFolders, Path.GetFileName(d)) < 0)
{
PrintDirectoryTree(d, lvl - 1, excludedFolders, lvlSeperator + " ");
}
}
}
How can I display just the first 10 files in all directories found
|
|
|
|
|
Your requirements are not exact.
First you might want to be sure exactly what you mean by "first". That depends on ordering. And if you don't specify/define the ordering then the OS/apis will provide it in whatever order it wants.
Second it is not clear if you want 10 total files or 10 files per directory. But regardless you are going to need something that keeps count.
|
|
|
|
|
There are several ways to do that: the most basic is to add a count to your loop:
int showCount = 10;
foreach (string f in Directory.GetFiles(directory))
{
Console.WriteLine(lvlSeperator + Path.GetFileName(f));
if (--showCount <= 0) break;
}
A better way is to use the array as an Enumerable and only process ten items:
foreach (string f in Directory.GetFiles(directory).Take(10))
{
Console.WriteLine(lvlSeperator + Path.GetFileName(f));
}
But ... the order in which Directory.GetFiles "delivers" files is not defined by the method definition: The order of the returned file names is not guaranteed; use the Sort method if a specific sort order is required. So you need first decide what are "the first ten" and sort them according to that decision: name order? Create date? Modification date? Size? Ascending or descending?
We can't make that decision for you: we don't know your app!
You should also be aware that Directory.GetFiles has a number of overloads, one of which allows you to return all files in all subdirectories in a single call: Directory.GetFiles Method Overload 3[^] which may improve your app performance with large directory structures.
"I have no idea what I did, but I'm taking full credit for it." - ThisOldTony
"Common sense is so rare these days, it should be classified as a super power" - Random T-shirt
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
In addition to the other answers, if you don't want all of the files, it would be better to use EnumerateFiles rather than GetFiles .
Directory.EnumerateFiles Method (System.IO) | Microsoft Learn[^]
GetFiles will enumerate all of the files and store the paths in an array, most of which you will throw away. EnumerateFiles uses lazy enumeration, so it will only enumerate the files you want, and won't store any state.
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
The only problem with that is the lack of sorting on the enumerable - "first 10" requires a sort of some description, or it's just random files that get picked.
"I have no idea what I did, but I'm taking full credit for it." - ThisOldTony
"Common sense is so rare these days, it should be classified as a super power" - Random T-shirt
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
Indeed; even the underlying Win32 API doesn't guarantee the order:
The order in which this function returns the file names is dependent on the file system type. With the NTFS file system and CDFS file systems, the names are usually returned in alphabetical order. With FAT file systems, the names are usually returned in the order the files were written to the disk, which may or may not be in alphabetical order. However, as stated previously, these behaviors are not guaranteed.
However, it's probably still more efficient to use some sort of bounded sorted list to store the 10 "first" files based on your chosen sort order as they're enumerated, rather than getting the list of all files, sorting them, and then picking the "first" 10.
Eg, using SortedList<TKey, TValue> , which unfortunately doesn't support an upper-bound on the number of elements:
const int NumberOfFiles = 10;
const int Capacity = NumberOfFiles + 1;
SortedList<string, string> firstFiles = new(Capacity, StringComparer.OrdinalIgnoreCase);
foreach (string filePath in Path.EnumerateFiles(directoryPath))
{
string fileName = Path.GetFileName(filePath);
firstFiles.Add(fileName, filePath);
if (firstFiles.Count == Capacity)
{
firstFiles.RemoveAt(firstFiles.Count - 1);
}
}
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
NET Framework 4.8 - .NET8 Compatibility
Hello everyone!
I have an old project done in C# using .NET Framework 4.8.
Is it possible to use in this project a dll made later in .NET8?
Thanks for your help.
|
|
|
|
|
It's almost impossible to give a blanket answer to this. It depends on what you have used in there. If you're referencing a .NET package that has no .NET 8 equivalent then, no, you can't use it. You're most likely going to have to do more work to include appropriate NuGet packages for items that you took for granted in the full fat framework.
|
|
|
|
|
I'm trying to load a list of drives. If you went to Windows Explorer and clicked on This PC, you would see all of the drives and devices available to you, physically installed, USB, and phones/tablets. This is the list I want
In addition to my C: hard drive, I have a Lenovo tablet, my Samsung S22 Ultra phone, a USB DVD drive, Seagate USB HDD all plugged in.
So, first I use this to get the HD and DVD drives:
var allDrives = DriveInfo.GetDrives();
First Problem
This gives me the drives, but for the DVD drives the DriveType is showing as 'CDRom'.
Second Problem
I want to get tablets and phones that are plugged in. I found this[^], which works well, with one small problem. Based on that I wrote this bit of code that writes out some of the drive meta data:
I get the ClassId from here[^]. Maybe my class Id is wrong??
public static List GetUSBDevices()
{
var file = @"c:\projects\usbinfo.csv";
if (File.Exists(file))
{
File.Delete(file);
}
var devices = new List();
ManagementObjectCollection collection;
using (var searcher = new ManagementObjectSearcher("Select * From Win32_PnPEntity"))
{
collection = searcher.Get();
}
using (var sw = new StreamWriter(file, true))
{
var line = "";
var keys = new string[]
{
"Name",
"Description",
"Caption",
"ClassGuid",
};
foreach (var key in keys)
{
line += $"{key},";
}
sw.WriteLine(line);
line = "";
foreach (var device in collection)
{
var name = (string)device.GetPropertyValue("Name");
var classGuid = (string)device.GetPropertyValue("ClassGuid");
if (classGuid == "{eec5ad98-8080-425f-922a-dabf3de3f69a}")
{
foreach (var key in keys)
{
try
{
line += $"{(string)device.GetPropertyValue(key)},";
}
catch { }
}
sw.WriteLine(line);
line = "";
}
}
}
collection.Dispose();
return devices;
}
That produced this
Name,Description,Caption,ClassGuid
One Touch,One Touch HDD ,One Touch,{eec5ad98-8080-425f-922a-dabf3de3f69a}
E:\,STORAGE DEVICE ,E:\,{eec5ad98-8080-425f-922a-dabf3de3f69a}
Galaxy S22 Ultra,SM-S908U,Galaxy S22 Ultra,{eec5ad98-8080-425f-922a-dabf3de3f69a}
Lenovo Tab M10,Lenovo TB-X505F,Lenovo Tab M10,{eec5ad98-8080-425f-922a-dabf3de3f69a}
Note the last two, the Galaxy S22 Ultra and Lenovo Tab M10 - these I want. The first two are HDD's, which I already have from GetDriveInfo().
So, to recap
1. With GetDriveInfo, how do I know if a drive that says CDRom is really a DVDRom?
2. Is there some way to get just the tablets & phones?
I'm open to a better way of someone has one.
Thanks!
In theory, theory and practice are the same. But in practice, they never are.”
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
|
|
|
|
|
Kevin Marois wrote: With GetDriveInfo, how do I know if a drive that says CDRom is really a DVDRom?
You can't. GetDriveInfo relies on a Win32 API, and the DriveType enum is mapped to the Win32 drive types, which haven't been updated to include DVD/Blu-Ray types.
DRIVE_UNKNOWN
The drive type cannot be determined.
DRIVE_NO_ROOT_DIR
The root path is invalid; for example, there is no volume mounted at the specified path.
DRIVE_REMOVABLE
The drive has removable media; for example, a floppy drive, thumb drive, or flash card reader.
DRIVE_FIXED
The drive has fixed media; for example, a hard disk drive or flash drive.
DRIVE_REMOTE
The drive is a remote (network) drive.
DRIVE_CDROM
The drive is a CD-ROM drive.
DRIVE_RAMDISK
The drive is a RAM disk.
There is an extended list of disk types defined in the IMAPI2 library:
IMAPI_MEDIA_PHYSICAL_TYPE (imapi2.h) - Win32 apps | Microsoft Learn[^]
You may be able to reference and use that library, as described in this SO answer[^].
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
Great thanks. I'll take a look
In theory, theory and practice are the same. But in practice, they never are.”
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
|
|
|
|
|
Hi All,...
I am reading into a rich text box a small number (0.385 to 0.457) which is read into a Rich Text Box as a string
and my though was to use Text.ConvertTo(float) in the following way
Value_Extract = ((Convert.ToDecimal(rtbIncoming.Text));
Value_Extract is a float...
This does not work compiles and Bang falls over when run, had look on Stack Overflow they seem to do in a similar way. Is this the correct way?? As VS helpfully tells me I need to cast a float as a decimal, decimal.tryparse??
modified 3-Jan-24 8:25am.
|
|
|
|
|