|
Pete O'Hanlon wrote: Or use log4net which has configurable ouput choices such as email, file, event log (or other ones that you could write yourself).
Since the EventLog is included already in log4net, I'd have to admit that it would be redundant to include an extra option to write directly to it.
Pete O'Hanlon wrote: BTW - log4net allows you to target multiple sources simultaneously, and is very configurable.
Good arguments, for both which and why
I are Troll
|
|
|
|
|
as you seen worried about size, I'll assume your logging is more of a technical nature, rather than an application-level statistic or audit trail, and I recommend a do-it-yourself approach, rather than using EventLog which would be rather expensive and cumbersome. See here[^].
|
|
|
|
|
jrahma wrote: i never seen any application showing such message in my life!! what's the best to work wit this?
There's a reason for that. The default size on Windows 7 is 20MB. If your application creates that many entries, you've got a bigger problem than managing the size of the log.
Really, your application shouldn't care about the size of the event logs at all. This is best left up to corporate policies and LAN Admins. There is no guarantee that what your application does to the event logs is going to stick because of policies.
|
|
|
|
|
then i think it's better to go for the local log file.. thx...
|
|
|
|
|
This idea is totally correct, I cannot agree with many of the other posts here. We have seen that happening on some of our customer's computers at the first (!) start of our applications - our LicenseServer writes one entry to the event log telling that it successfully read / or failed to read the license file. And here it crashed. Because the event log was full - since a long time already... It is really not uncommon.
Best to add some try/catch around your event log entries, so it won't crash your programs.
|
|
|
|
|
I want to know how can I create help for my application to be the same as MSDN library layout, I think it's using something called Microsoft Document Explorer
|
|
|
|
|
I am using C# and I want to know how can I change the caption of the MesageBox when MessageBox.Show, for example if I want to change the Ok button caption to WoW!!
|
|
|
|
|
There is not an easy way to achieve this. Better create your own customizable messagebox.
See here[^] for creation details.
Or you can use a ready customizable messagebox clone presented here[^] on CP.
|
|
|
|
|
Hello to All
I want to change the name of my process or hide it from task manager.
also do you think that the anti viruses warn about it?
Best regards
|
|
|
|
|
mobasher wrote: I want to change the name of my process
Change the name of your executable.
mobasher wrote: or hide it from task manager
Why? The user usually owns the machine that he/she is using, and would have every right to see what is running in his/her system.
mobasher wrote: also do you think that the anti viruses warn about it?
Yes, but merely as being "malware", not a virus.
I are Troll
|
|
|
|
|
There is only one method to do this, but I'm not saying what it is.
mobasher wrote: also do you think that the anti viruses warn about it?
No, but, coming from a LAN Admin background, there is no legitimate reason to do this. If I caught your app doing it, it would be, at my highest priority, uninstalled and the systems rebuilt from scratch. Only malware would ever want to do this.
|
|
|
|
|
I have many parameters in my system_parameters table in SQL and I am populating into a hashtable but it seems it's not reading all (and no error raised!).. it's reading 19 out of 68.. this is my code to read from the sql:
while (sql_reader.Read())
{
if (_system_parameters_hash.ContainsKey(sql_reader["system_param_name"])) return;
if (sql_reader["system_param_value"] == DBNull.Value)
{
_system_parameters_hash.Add(sql_reader["system_param_name"].ToString(), null);
}
else
{
if ((string)sql_reader["system_param_type"] == "bit") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToBoolean(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "string") _system_parameters_hash.Add((string)sql_reader["system_param_name"], (string)sql_reader["system_param_value"]);
else if ((string)sql_reader["system_param_type"] == "int") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt32(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "int64") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt64(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "short") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt16(sql_reader["system_param_value"]));
}
}
and this is a sample rows (parameter name, parameter value then parameter type)
APPOINTMENT_DEFAULT_CLINIC 2 int
APPOINTMENT_DEFAULT_DOCTOR 3 int
BACKUP_DESTINATION_FOLDER C:\Temp\cure.bak string
BACKUP_SCHEDULE_DURATION DAILY string
BACKUP_SCHEDULE_ENABLED True bit
what can I do?
|
|
|
|
|
Message Closed
modified 23-Nov-14 6:24am.
|
|
|
|
|
i did but still the same with no error
and my select statement is SELECT * FROM system_parameters
|
|
|
|
|
Message Closed
modified 23-Nov-14 6:23am.
|
|
|
|
|
what's the use of breakpoint if no error and no problem running the application? were do you want me to set the break point?
|
|
|
|
|
The breakpoint that was mentioned by someone you should place at the begin of the while loop
As to the error without exception. In this line:
if (_system_parameters_hash.ContainsKey(sql_reader["system_param_name"])) return;
you return from method. Are you sure names aren't duplicated at least once... in 20th row returned from your command?
This is something you could discover by debugging your code
|
|
|
|
|
start debugging: do NOT set a breakpoint, observe closely what happens, add code to improve visibility; add a try-catch and show Exception.ToString, add an else clause that counts how many entries contain unrecognized types, look at the actual data of the very first row that does not make it to the ArrayList, consider what happens when a DBNull occurs, start thinking and acting.
|
|
|
|
|
i did all that but it's still not working... it's actually existing the while loop when it reaches count 19 with no errors as if my total count in the database table is 19 only!!
any duplicates in the table? that was your question? no, duplicates, I already checked and I have also copied the entire table as excel format in this link:
system_parameters table[^]
this is my full code which I am using:
public void get_system_properties()
{
try
{
_system_parameters_hash = new Hashtable();
_system_parameters_hash.Add("SQL_SERVER_CONNECTION", null);
_system_parameters_hash.Add("SQL_SERVER_DATABASE", "Cure");
_system_parameters_hash.Add("EVENT_LOG_DESCRIPTION", null);
_system_parameters_hash["SQL_SERVER_CONNECTION"] = "Data Source=";
_system_parameters_hash["SQL_SERVER_CONNECTION"] += cure_registry_current_user.GetValue("SQLServer").ToString();
_system_parameters_hash["SQL_SERVER_CONNECTION"] += ";initial catalog=";
_system_parameters_hash["SQL_SERVER_CONNECTION"] += cure_registry_current_user.GetValue("SQLDatabase").ToString();
_system_parameters_hash["SQL_SERVER_CONNECTION"] += ";User Id=";
_system_parameters_hash["SQL_SERVER_CONNECTION"] += cure_registry_current_user.GetValue("SQLUser").ToString();
_system_parameters_hash["SQL_SERVER_CONNECTION"] += ";Password=";
_system_parameters_hash["SQL_SERVER_CONNECTION"] += cure_registry_current_user.GetValue("SQLPassword").ToString();
_system_parameters_hash["SQL_SERVER_CONNECTION"] += ";Connection Timeout=";
_system_parameters_hash["SQL_SERVER_CONNECTION"] += cure_registry_current_user.GetValue("SQLTimeout").ToString();
sql_connection = new SqlConnection((string)_system_parameters_hash["SQL_SERVER_CONNECTION"]);
sql_connection.Open();
sql_command = new SqlCommand("sp_get_system_parameters", sql_connection);
sql_command.CommandType = CommandType.StoredProcedure;
sql_reader = sql_command.ExecuteReader();
while (sql_reader.Read())
{
if (_system_parameters_hash.ContainsKey(sql_reader["system_param_name"])) return;
if (sql_reader["system_param_value"] == DBNull.Value)
{
_system_parameters_hash.Add(sql_reader["system_param_name"].ToString(), null);
}
else
{
if ((string)sql_reader["system_param_type"] == "bit") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToBoolean(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "string") _system_parameters_hash.Add((string)sql_reader["system_param_name"], (string)sql_reader["system_param_value"]);
else if ((string)sql_reader["system_param_type"] == "int") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt32(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "int64") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt64(sql_reader["system_param_value"]));
else if ((string)sql_reader["system_param_type"] == "short") _system_parameters_hash.Add((string)sql_reader["system_param_name"], Convert.ToInt16(sql_reader["system_param_value"]));
}
}
Trace.Write(_system_parameters_hash.Count);
}
catch (Exception exp)
{
create_event("System", "Error populating system properties!!", exp, EventLogEntryType.Error, 1000, false);
MessageBox.Show("Error populating system properties!!" + Environment.NewLine + "Please contact your system administrator.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
Application.Exit();
}
finally
{
if (sql_reader != null) sql_reader.Close();
if (sql_connection != null)
{
if (sql_connection.State == ConnectionState.Open)
sql_connection.Close();
}
}
}
|
|
|
|
|
one of the recommendations I made was "add code to improve visibility", I see none of that.
before the reading loop, add code to show the number of rows returned, so you can check that number right away; identify the last row added, or better yet, the first one missing. Would it perhaps be the first one with type "short"? does that ring a bell?
|
|
|
|
|
i copied the real code but i already did the count before when troubleshooting and I got the correct count as per my stored procedure.
what's wrong with the short? it's a data type and I am already including it in both the table row and the code?
|
|
|
|
|
just log intermediate results and locate the problem. it can't be hard. either the data comes in and doesn't get stored, or it does not come in. use logging, don't trust anything as one of your assumptions or observations is bound to be wrong since you don't agree with the results.
|
|
|
|
|
hi friends $ Seniors,
i am trying to save an image in PNG format, the original image is 24dpi and is 16.2 mb, afterwards i add alpha channel to image and make some portion of the image transperant, after this when i save the image img.save(imagepath, imageformat.png) the size is increased to 33 mb. i wanted to know the image size increased is correct? does the image dpi changed from 24 to 32 increases the image so much?
friends, also debugging my code i found a strange thing, which i would like to share with u
Bitmap bmp = new Bitmap(imagepath);
bmp.save("c:\11.jpg"); // this saved image with 16 mb
Bitmap bmp1 = new Bitmap(bmp);
bmp1.save(c:\\22.jpg); // this saved image with 33 mb
Thanking in Advance
Regards
Samir
|
|
|
|
|
1.
Maybe transparency uses the alpha channel, so now every pixel needs 4 bytes rather than 3?
2.
you should never use Bitmap.Save(string), always use Bitmap.Save(string,ImageFormat).
3.
VCsamir wrote: Bitmap bmp1 = new Bitmap(bmp);
An image may hold metadata, e.g. a camera creating a JPEG file adds a lot of metadata to the pixel data. Copying a bitmap like you do does not copy the metadata.
|
|
|
|
|
hello
I have a DataView and bind it to dataset. for find value in dataview, I use dataview.rowfilter
for Example :
dataview.RowFilter="FirstName like 'D*'";
This will display only those records where the FirstName column begins with D.
If I want to *select* those records where the FirstName column begins with D but still display all the records,
What can I do?
|
|
|
|