Misplaced Pages

Talk:C standard library

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

This is an old revision of this page, as edited by 1exec1 (talk | contribs) at 15:23, 4 November 2011 (re). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Revision as of 15:23, 4 November 2011 by 1exec1 (talk | contribs) (re)(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)
WikiProject iconComputing Start‑class Low‑importance
WikiProject iconThis article is within the scope of WikiProject Computing, a collaborative effort to improve the coverage of computers, computing, and information technology on Misplaced Pages. If you would like to participate, please visit the project page, where you can join the discussion and see a list of open tasks.ComputingWikipedia:WikiProject ComputingTemplate:WikiProject ComputingComputing
StartThis article has been rated as Start-class on Misplaced Pages's content assessment scale.
LowThis article has been rated as Low-importance on the project's importance scale.
WikiProject iconC/C++ Unassessed High‑importance
WikiProject iconThis article is within the scope of WikiProject C/C++, a collaborative effort to improve the coverage of C and C++ topics on Misplaced Pages. If you would like to participate, please visit the project page, where you can join the discussion and see a list of open tasks.C/C++Misplaced Pages:WikiProject C/C++Template:WikiProject C/C++C/C++
???This article has not yet received a rating on Misplaced Pages's content assessment scale.
HighThis article has been rated as High-importance on the importance scale.

Archiving icon
Archives
Archive 1Archive 2


This page has archives. Sections older than 60 days may be automatically archived by Lowercase sigmabot III when more than 10 sections are present.

Pages for each function and WP:NOTMANUAL

Hello,

I've noticed that there are quite a lot of new pages (like memccpy, mempcpy, strdup, etc.) for functions in the C standard library and its non-standard extensions. I feel that they serve no purpose, since all the material there falls into either of the following categories: a rehash of the standard or some online reference; a collection of tutorial-like tips or examples. Also, WP:NOTMANUAL explicitly forbids material like that. Thus I think these articles should be deleted. Since there was a lot of disputes regarding the deletion of other similar pages, we could take this opportunity to decide the fate of them too.

In my opinion a better way to document all these functions would be to have only a very concise definition in a page describing several functions (such as string.h) with a link to an actual reference, such as man pages, cplusplus.com, cppreference.com, wikibooks (for tutorials), etc., as is done here or here for example. Even the larger, more established pages (such as strcpy) could be reduced to such footprint, since most of their content is either not notable, fails WP:NOTMANUAL (especially in the case of printf), or would be reasonably represented in the linked reference webpage.

A different problem is with completely established pages, with a lot of WP:RS, such as malloc or printf: they mostly discuss a broader subject, not the function itself. In the case of malloc, different memory allocation strategies are discussed, not the malloc itself. This could be solved by repurposing the article and letting an external reference to do its work. However, this is not the core issue, so we can leave this for a separate future discussion.

Since this is quite controversial subject, that affect a lot of pages, we need to establish consensus over whether we need a change, and what we want to change. I think a usual poll would be a good idea. Since there are a lot of options, I've divided the poll into several separate questions.

Do we want to delete/redirect the pages?
  • 1) Do nothing. Leave everything as it is. It means that eventually each function in the C standard library has its own page. Unfortunately, WP:NOTMANUAL doesn't allow this. This option is doesn't solve anything.
  • 2) Delete/redirect new. Not fair because newer (not yet established) pages are discriminated. Examples of pages affected memccpy, mempcpy, strdup, etc.
  • 3) Delete/redirect all with exceptions. Do not delete/redirect the established pages such as malloc. Examples of pages affected: all of (2), plus strcpy, ect.
  • 4) Delete/redirect all. Delete/redirect all pages that would be deleted by (3). Repurpose existing pages to the actual subject, such as malloc -> memory allocation strategies. Affected pages: all of (3), plus malloc, fprintf, etc.; essentially any page describing a single C function.
  • ... (add your own option)
Do we need links to an external reference such as here or here ?
  • 1) Do not link to an external reference
  • 2) Link to an external reference
External reference website we will use (if we decided we need one)
  • 1) Depends on the situation. Cons: no consistency across pages.
  • 2) man pages, POSIX specifications, e.g. prinf on opengroup. Pros: extensive, complete, covers C99. Cons: covers POSIX, not C, so quite confusing as a lot of additional functions are present.
  • 3) MSDN reference, e.g. printf on MSDN. Pros: extensive, complete, covers C99. Cons: covers Microsoft's implementation of the C standard library, so quite confusing as a lot of additional functions are present.
  • 4) cplusplus.com, e.g. printf on cplusplus.com. Pros: extensive, complete. Cons: does not cover C99.
  • 5) cppreference.com, e.g. printf on cppreference.com. Pros: a public wiki, uses the same content engine and license as the Misplaced Pages - extensibility, familiarity to wikipedians. Covers C99. Extensive. Cons: several functions missing. Looks into the functionality from the C++ point of view, though as per their FAQ, a separate reference for C could be added if there is interest.
  • ... (add your own option)

1exec1 (talk) 09:00, 4 October 2011 (UTC)

Note, that the primary objective of this discussion is to agree on general approach regarding the
pages on C standard library. Specific actions will be discussed later in the talk pages of the articles involved
I’m against actual deletion and prefer redirection. Deletion would make searching harder, and might encourage the same articles to be re-created with alternative names (strtok deleted, yet strtok_r later created). Redirection means you’re still allowed to use the name to link to a relevant article, and this might reduce the need for external linking. Otherwise I have no strong opinions on external links, although I am under the impression that there are subtle differences between some C functions and their C++ equivalents.Vadmium (talk, contribs) 11:13, 4 October 2011 (UTC).
I agree, actually the redirects were what I actually meant (it is still a delete content-wise though). I added a notice regarding that.1exec1 (talk) 11:28, 4 October 2011 (UTC)
I do agree that all these man-page-like articles need fixing up, and I actually started collecting a potential list of them earlier today at User:Vadmium/Man pages. The problem is not limited to functions, for example I’m not sure if stdlib.h and stddef.h are good places to pull together discussion of the things defined by those headers. Vadmium (talk, contribs) 11:13, 4 October 2011 (UTC).
I agree with redirecting the pages to their respective header pages, with some exceptions. malloc is essentially an article covering dynamic memory allocation in C, especially since calloc/realloc/free are all included there. printf should be moved to Format string (which is currently a redirect to there). mmap (POSIX) could be merged into Memory-mapped file. The pages on string functions (strcpy, strcmp, strcat, strlen) could be merged into the relatively short C string article - lots of the information on security implications and caveats is just duplicated on each page.
I think string.h could also be merged into C string. I know it would break the nice "article for every header file" thing, but the C standard library template could just be included there with string.h as a redirect. -- strcat (talk) 14:11, 4 October 2011 (UTC)
In my opinion, a page for each header is in itself not a very good idea, because in C a lot of functions performing similar functionality are dispersed across several headers (e.g. abs in stdlib.h, fabs in math.h). A better way would be to avoid grouping by header completely and use grouping by functionality instead.1exec1 (talk) 15:09, 4 October 2011 (UTC)

Status

Status of all pages involved in this reorganization can be tracked at User:Vadmium/Man pages

Several discussions with regards to validity of the merges/redirects have been opened: Misplaced Pages:Articles_for_deletion/Stdlib.h, Misplaced Pages:Articles_for_deletion/C miscellaneous operations. Please express your opinion there.

Poll

  • Redirect all. Link; use cppreference.com as the external reference. P.S. I use that site regularly so there's slight conflict of interest, shouldn't be a problem though.1exec1 (talk) 09:03, 4 October 2011 (UTC)
  • Redirect; write about groups of functions, header files, etc in articles like C file input/output. Vadmium (talk, contribs) 11:13, 4 October 2011 (UTC).
  • Redirect in almost all cases (ie there should be a redirect page with the name of each function, to avoid people recreating them). However a few articles with significant historical or controversy information must be preserved as-is. In particular the strlcpy article, as this is a common term found when researching controversy about the glibc library. A few others contain large amounts of information, such as printf, but as noted this information is often more of a cs subject and should be moved there.Spitzak (talk) 19:48, 4 October 2011 (UTC)
  • Wait and Transwiki all to WikiBooks, creating an appendix to b:C Programming. We should probably wait until November when Misplaced Pages:India Education Program/Courses/Fall 2011/Data Structures and Algorithms has finished (these people have been fairly uncommunicative so far and will probably stubornly recreate any article that has been deleted or redirected.) I'll request import> rights at WikiBooks and can temporarily undelete a few of the articles that have already been deleted here. —Ruud 13:24, 5 October 2011 (UTC)
I like this idea. But maybe we can do the import earlier, while there's strong momentum? I think it should be possible to negotiate with the curators of that course to continue their work in Wikibooks. It seems pointless to suspend so much cleanup work for a month, especially since most of the pages in question will end up in Wikibooks in any case. 1exec1 (talk) 14:00, 5 October 2011 (UTC)
I've imported mbrlen, which was recreated again, to Wikibooks. I've left a soft redirect behind. Is this an acceptable solution? —Ruud 16:28, 5 October 2011 (UTC)
Generally I think it would be better to redirect to some wikipedia page that mentions the particular function. I imagine that after the cleanup all functions will have entries in summary lists similar to that in wctype.h. Currently I don't know a summary page for mbrlen though. Unrelatedly, what do you think about my above proposal to negotiate with the curators of that India Education course?1exec1 (talk) 17:05, 5 October 2011 (UTC)
It could be redirected to <wchar.h> and we could in turn link to Wikibooks from that page. The question is if we want to keep the pages for the header files as well. I'd argue we'd only need this article on the C standard library and keep most of the detailed stuff in the Wikibook.
I've tried contacting a the ambassadors of the program last week but they simply ignored the request to join the discussion at WikiProject Computing. I'll leave a notice on each students talk page if I move their article to Wikibooks. Maybe they'll get the point eventually? —Ruud 17:29, 5 October 2011 (UTC)
Completely removing the material in these pages for header files would be something too much IMO. A better solution, which was suggested above, would be to merge the content to other pages, while removing non notable and tutorial-like material. However, you should import the header pages to wikibooks also, because these pages will become redirects after the cleanup.
A notice in the user pages would be enough IMO. In any case, if even the ambassadors don't care, why should we? Misplaced Pages is not for homeworks.1exec1 (talk) 17:55, 5 October 2011 (UTC)
I don't think merging e.g. alloc.h with Memory management would be a good idea. That article covers (or at least should cover) memory management at a slightly more abstract level. If we start including C specific stuff their, we would also have to include material for dozens of other languages. I'd have a slight preference for merging the headers here, but keeping separate articles for the header files would probably be okay as well. Let's see what other people have to say on this. I'll import the articles on the header files to Wikibooks as well. —Ruud 18:13, 5 October 2011 (UTC)
Something like C memory management or Memory management in C would be more sensible, I agree. Better yet, we could have C and C++ memory management and to merge several other articles there.1exec1 (talk) 18:46, 5 October 2011 (UTC)
In any way, I think we should only decide general approach in this discussion. Article specific stuff should go into their talk pages.1exec1 (talk) 18:48, 5 October 2011 (UTC)
It would be a fair idea to merge the content in alloc.h with a page like C memory management , but if a page like this is created, it raises the question of creating similar pages for all the programming languages in the world. A compilation of similar pages would also act like a manual, listing out memory management in various languages. Srinathkr3 (talk) 03:11, 6 October 2011 (UTC)
I disagree that we can call such pages manuals. The function list would be a minor detail, compacted as much as possible. The main focus would go into explaining different memory allocation strategies (such as stack or heap) and similar things. This is not a manual. If it was, then we could easily count several thousands of established pages (e.g. C++11), that would need deletion. Here we are against small pages containing material, that would be interesting to a programmer who was about to use some function.1exec1 (talk) 11:35, 7 October 2011 (UTC)
If you’re looking for a C memory management article, check out the current scope of malloc; it even has a section called malloc#Dynamic memory allocation in C. Might be best to start by renaming that page. Vadmium (talk, contribs) 06:00, 6 October 2011 (UTC).
  • Redirect all. Either we have to document ALL the library (which is way out of score of wikipedia) or delete the functions. After all, one that wants to learn about strcpy or anything else will not usually expect Misplaced Pages to contain details. Michael (talk) 20:14, 6 October 2011 (UTC)
  • How can you call this concensus and where is the conclusion then? - Discussing a lot of articles here? I think its rather strange to use this talk page as an argument. Why not include the wikiproject discussion page? Christian75 (talk) 18:33, 23 October 2011 (UTC)
As I've already said in some edit summary, a lot more editors are not watching Wikiproject pages. By the way, there already has been a discussion and there's a link to this discussion there, so this is not an issue. Also, I've placed links to this discussion on each and every page involved, so everyone interested had almost a month to express their opinion. And you've still not expressed yours. 1exec1 (talk) 18:36, 23 October 2011 (UTC)
  • Please stop. A lot of this "reorganizing" that's going on looks to me to be wholesale WP:OR in the form of creating articles on non-notable or, at best, questionably notable topics. The one I've been annoyed by is 1exec1's renaming of Malloc to C dynamic memory allocation despite lack of clear consensus. I concede that it wasn't a particularly good article about malloc and that with the (too many) horrid code examples trimmed, the content has improved. But we've gone from an article on a topic I'm satisfied was probably notable (we can trace it back to dmr's 1973 malloc.c in early 4th edition Unix and its appearance in K&R 2nd ed.) to a phrase that while common enough, may or may not be notable as required by WP:GNG.
    What I've seen also is that 1exec1 seems determined to ignore objections and the need to get consensus. Was it just me, there on the malloc page, I wondered? No, it's not. This is a problem everywhere 1exec1 goes and I can see others stating their concerns, which also seem to go unheard. 1exec1 needs to go a lot slower and show more awareness that what's already here reflects consensus, that if he wants to make changes, he needs consensus and to accept that when someone has to tell that you that don't have consensus, you probably don't. Msnicki (talk) 01:38, 1 November 2011 (UTC)
Can you prove that this part " <...>wholesale WP:OR in the form of creating articles on non-notable or, at best, questionably notable topics" and this part " 1exec1 seems determined to ignore objections and the need to get consensus." are more than allegations?
What WP:OR articles have I created? C miscellaneous operations is the only article I created that has no support of WP:RS. It was created (actually moved from stdlib.h) because I wanted to gather some opinions of the Wikipedians before deciding what to do with that article, not because I though that should be the final version of the reorganization. The editors decided that the article should be deleted; I'm perfectly fine with that.
In the case of malloc, there were 3 editors for a move, you were the only editor against (there was one editor that opposed to the merge of alloc.h, but not to the move of malloc). You failed to directly respond to my comments saying that the actual scope of the article was not malloc. You simply said the article should be improved. You failed to respond to the fact that there was consensus for some move, though not necessarily the one I chose. You failed to respond to my comments saying that most of WP:RS group all C memory allocation functions under the name of memory management or similar, not malloc. Instead, you started to cherry-pick sources (UNIX manuals), say that one of my examples was not exactly correct (the first edition of K&R The C programming language, though I was talking generally and what you've said doesn't apply to the second edition) and talk about things not related to the particular dispute. I may as well choose to ignore things that are not directly related to the move discussion itself, that is, do not bring new points to the discussion or fail to bring an argumentated response to the current ones. Please stop accusing others when it is you who doesn't facilitate a proper discussion. 1exec1 (talk) 18:39, 1 November 2011 (UTC)

Links to an external reference

Hello,

The previous discussion (Talk:C standard library#Pages for each function and WP:NOTMANUAL) resulted to merging of more than 40 manpage-like articles to some summary articles. Since these summary pages had links to the manpage-like articles even before merge, in think that it would be a reasonable compromise to preserve links to reference material for convenience, even if Misplaced Pages does not host that material itself. In this way, the summary articles could be able to describe the C library contents to the fullest extent: having the criticism, history and similar material in the article itself and linking to an external site for the reference which is not allowed in Misplaced Pages. Here by saying reference I mean a factual reference, i.e. functions, their parameters, preconditions, postconditions, etc. which are useful when programming; I'm not meaning tutorials, how-to's which are useful only when learning how to program. For example how a page with links looks like, see here. Note, that the total number of links hasn't increased, because before the merging, the manpage-like articles had at least one link to an external reference. Having said that, there's already some disagreement not only about the format of these links, but about whether we need them at all. Hence I think we need to establish a clear consensus regarding the links to an external reference and then act accordingly. 1exec1 (talk) 11:50, 23 October 2011 (UTC)

I would at least link through a template. That makes it easier to change the formatting and reference used at a later date. We should consider linking to the articles now in Wikibooks, although they're not in a very good shape at the moment (increased visibility might change that though, and multiple external references can in turn be linked to from the those articles.) Otherwise "official" references (The Open Group?) or ad-free free-content wikis would seem appropriate targets. —Ruud 13:21, 23 October 2011 (UTC)
Direct link to list from example given: C mathematical operations#Function overview. If you’re going to make a common practice of the linking, maybe look at how it seems to be done with Category:Javadoc templates, including {{Javadoc:SE}} for example used on java.lang.
 As for formatting, I’d certainly avoid changing font sizes. I also dislike using monospaced fonts inline with ordinary non-monospaced English text unless they actually help make things clearer, but I expect not everyone would agree with me on this. Vadmium (talk, contribs) 13:58, 23 October 2011 (UTC).
You mean those small C, C++? As for monospaced fonts, I think function names and types deserve being in monospace, because e.g. '...such as abs, labs, div, and ldiv, are instead...' is really quite unclear. Or did you have something else in mind? 1exec1 (talk) 18:28, 23 October 2011 (UTC)
Yep I meant the small text for the links. For that monospace example, I hoped using italics would make it clear: “such as abs, labs, div, and ldiv, are . . .” Vadmium (talk, contribs) 14:19, 24 October 2011 (UTC).
I agree, templates can be very useful in such cases.1exec1 (talk) 18:28, 23 October 2011 (UTC)
By the way, could you mark you opinion with Support, Oppose or similar to make it clear whether a consensus is established? There are editors who disagree with this.1exec1 (talk) 18:32, 23 October 2011 (UTC)
I'm not sure if my (or other) comments here can be directly seen as supporting or opposing some (which?) position. Take them more as good advice/constructive criticism. —Ruud 08:37, 24 October 2011 (UTC)
  • Reservations I'm not ready to offer an opinion but will express some reservations. The linking at the given example is very unusual, and certain to attract negative views, particularly from those who regularly oppose linkspam. While convenience links can be convenient, why not have just one link to somewhere with an index of all the functions? Anyone actually needing a man page description of a function would have worked out how to find it long ago (Google if nothing better known). If there is a particularly good site with info on standard functions, add it to external links? Johnuniq (talk) 00:35, 24 October 2011 (UTC)
In that example it should be the function names themselves that should be hyperlinked. I wouldn't be in favour of having more than one link per function in the body of the text either. —Ruud 08:37, 24 October 2011 (UTC)
The problem is that the C++ language inherits the same functions from C, but the definitions themselves are somewhat different. If this wasn't the case we could easily do as in map (C++)#Overview of functions. 1exec1 (talk) 08:52, 24 October 2011 (UTC)
I agree, the current format is not only unusual, but has quite high negative impact on readability. However, I think that removing these links entirely is something too much, as not a lot of time ago lots of these functions (e.g. most in C string) had separate pages. Reducing the availability of detailed information to a mere link at External links is something too much IMO. Thus I'll try to find a solution that involves links to reference first. One thing to note is that this linking is limited to only one section.1exec1 (talk) 12:36, 24 October 2011 (UTC)

Several suggestions how we could improve the current formatting:

1)

or without <small>

2)

  • sinh - computes hyperbolic sine (references: C/C++)
  • asinh (C99, C++11) - computes hyperbolic arc sine (references: C/C++)

or without <small>

  • sinh - computes hyperbolic sine (references: C/C++)
  • asinh (C99, C++11) - computes hyperbolic arc sine (references: C/C++)

3)

or without mentioning C++

  • sinh - computes hyperbolic sine
  • asinh (C99) - computes hyperbolic arc sine

I think all of the above are much better than the initial ( example ) formatting. I personally like the first one. 1exec1 (talk) 12:36, 24 October 2011 (UTC)

Maybe it would be a good idea to explain what the links are and where they lead, rather than leaving it implicit? BTW it looks like the linux.die.net man pages are just rather old versions from the “Linux man-pages” project; http://man7.org/linux/man-pages/online/dir_all_by_section.html#man3 is closer to the source. Vadmium (talk, contribs) 14:19, 24 October 2011 (UTC).
I dislike the 1st and 2nd way of linking (they look like those click here links). The 3rd (4th actually) method is the style that is generally used on Misplaced Pages. The main problem is of course that we're then limited to a single link per function. I see two possible solutions to this:
  1. Link to the Wikibooks articles. In the the Wikibooks we can then link to two, or even more, additional external references, perhaps even from an infobox-like sidebar? (Advatages: increases the visibility of the C Programming Wikibook, requires us to complete the references by adding an articles for each function and improving the existing ones. Disadvantage: Requires us to complete the references by adding an articles for each function and improving the existing ones.)
  2. Make those links anchored to links to items in the References section, from where we can link to one, two or more external references.
Ruud 14:41, 24 October 2011 (UTC)
After some experimentation, I agree that the last option is probably the clearest. Also, I've probably given C++ too much weigh, since actually not much C++ programmers use C stuff, which most of the time has C++y equivalents. Maybe one link to some C++ reference at the top of the function list would be enough. 1exec1 (talk) 22:03, 25 October 2011 (UTC)

Windows and the C library

I'm not sure about what to add there: I know there IS an implementation of it in Windows, and that critical security DLLs depend on it: so in a way, if you take out the C standard library DLL, you take down Windows. Moreover, some compilers (such as MinGW and old versions of Visual Studio) piggyback on it.

But I don't know the official stance of Microsoft about it: My best guess would be that it's not (longer) supposed to be used and that each compiler is expected to provide its own, but I have no citation on it. Medinoc (talk) 08:26, 19 October 2011 (UTC)

Do we need prototypes?

Do we need function prototypes as here? I think that prototypes are not useful because we don't completely explain these functions. Also, complete documentation is enabled one click away in an external page. 1exec1 (talk) 16:45, 28 October 2011 (UTC)

Move articles about C standard library from C *** to *** in C

The current titles of articles about C standard library (namely C mathematical functions, C file input/output, C program control operations, C character classification, C date and time operations, C dynamic memory allocation, C data types) are somewhat bizarre. I suggest to move these pages to *** in C versions, e.g. Mathematical functions in C. I think that doing a centralized discussion would be beneficial, because for consistency we should either move all pages or none of them.

The centralized discussion is made somewhat complicated because there are several ongoing discussions with intentions to split some articles. I think that this discussion are independent from them. 1) discussion about a split off of malloc from C dynamic memory allocation. 2) discussion about a split of C string to null-terminated string or similar and String handling in C/C string handling or similar: if the split discussion concludes that no split is needed, I do not suggest any moves, otherwise the target page (String handling in C/C string handling) should be selected according to the outcome of this discussion.

1exec1 (talk) 12:45, 2 November 2011 (UTC)

  • Oppose. These invented titles are all basically WP:OR. They may be common (like "sunny day in Florida") but there's no way to establish notability for these subjects as they mean only whatever anyone says they mean. Misplaced Pages is not intended to be a giant tutorial on WP:HOWTO use C, all nicely divided into nice chapters, each consistently named. This is an encyclopedia. For example, if, as 1exec1 concedes, there's nothing to talk about except malloc in the bizarre (his word, but on this, I agree) C dynamic memory allocation article, let's move it back to malloc, the name Ritchie gave it when he invented it. Msnicki (talk) 14:14, 2 November 2011 (UTC)
That's an absolutely inappropriate invocation of WP:OR. The article C (programming language) has a section named "Memory management", there is absolutely nothing in WP:OR that prevents us from spinning-off that section into a full article title Memory management in C. By analogy: article Netherlands has a section titled "Floods" and a spin-off article titled Flood control in the Netherlands. Your argumentation now basically boils down to the claim that the article on flood-control should be deleted, as being original research, and only an article on the Delta Works should remain. Also, I think you're putting words in 1exec1's mouth here, but he can comment on that himself. —Ruud 14:59, 2 November 2011 (UTC)
Msnicki, I see that you would like that article to be moved back at malloc, but lying is absolutely wrong way to achieve that. Can you tell when did I say that C dynamic memory allocation contains, or should contain only material about malloc? 1exec1 (talk) 16:30, 2 November 2011 (UTC)
Thank you for making my points. It's impossible to know what "C dynamic memory allocation" should contain because it doesn't have a clear notable meaning. Is this a survey of every published algorithm for doing this in C? Is this a tutorial on the topic? Who knows. You conceded that if we split out the part on malloc, there wasn't enough left for another article on your new subject here. Malloc is very clearly about malloc. We can establish notability for that subject. That's important here on WP.
And thank you also for making my point that you don't show much real interest in consensus; you'll pardon me for pointing out that when I get accused of lying, I don't get the impression that individual is trying very hard to be inclusive or accommodating or even very respectful. And I am not the only one with concerns you're ignoring. You gave pretty much the same brush-off to Deryck C. on your talk page; you weren't nasty to him but you also didn't appear to hear a word he was saying. Go slower and actually get consensus, don't just steamroller mass changes. Msnicki (talk) 16:51, 2 November 2011 (UTC)
Regarding my concession, you pulled the quote out of context. There's in fact less material on malloc as compared to everything else, that was clearly indicated at the talk page (look for a paragraph beginning with I don't think that this article discusses only Malloc as you seem to allege). As for accusation of lying, I am tired of the hypocrisy when you accuse me of failure to cooperate yet don't respond to valid points in the talk pages elsewhere. My further response can be very easily summarised using this quote from this talk page that you still haven't responded to:

<...> In the case of malloc, there were 3 editors for a move, you were the only editor against (there was one editor that opposed to the merge of alloc.h, but not to the move of malloc). You failed to directly respond to my comments saying that the actual scope of the article was not malloc. You simply said the article should be improved. You failed to respond to the fact that there was consensus for some move, though not necessarily the one I chose. You failed to respond to my comments saying that most of WP:RS group all C memory allocation functions under the name of memory management or similar, not malloc. Instead, you started to cherry-pick sources (UNIX manuals), say that one of my examples was not exactly correct (the first edition of K&R The C programming language, though I was talking generally and what you've said doesn't apply to the second edition) and talk about things not related to the particular dispute<...>. 1exec1 (talk) 18:39, 1 November 2011 (UTC)

I can't really discuss further until you respond to the above points without derailing the discussion. 1exec1 (talk) 20:36, 2 November 2011 (UTC)
(Thanks Msnicki for telling me I'm mentioned in this discussion) To be honest, I'm opposed to this mass-move from <***.h> to "C ***" from the outset, largely because the articles, even after being moved, were predominantly about stuff in the headers. The main reason the proposed (and to some extent the current) titles are unhelpful is that all these articles are about built-in functionality of the C language and its derivatives, but the article title gives the impression that it should include other methods of achieving them using C as well. Given that notability and original research are the main concerns here, moving the articles back to the header names is actually the most sensible solution, given that the functions covered by an article collectively have enough notability. (If they don't, the article shouldn't exist anywhere anyway.) Deryck C. 17:45, 2 November 2011 (UTC)
Thank you. I think that's a pretty good, guidelines-based analysis. We don't pick titles for new articles based on whether they'd be helpful. We decide based on whether we can establish notability. If there are particular headers that have undeserved articles, we should AfD them. But if we take them to AfD, e.g., Misplaced Pages:Articles for deletion/Stdlib.h, the standard there, too, should be notability, not whether some different, but questionably notable title would be far more wonderful. Msnicki (talk) 18:27, 2 November 2011 (UTC)
My response will consist of several unrelated ideas so I'll try to express them point by point:
  1. Re: scope of the articles. This is actually one of the purposes of this rename - to clarify the scope of the articles, so that not only standard stuff can be included. You can see that clearly in a discussion that led to this proposal. I actually didn't expect that such a minor change would be so controversial, so I even didn't bother to include scope as an argument. Yet it is an important one, since there exist a lot of notable material that is not really related to the C standard. For example, you can look at C string#Extensions to ISO C and C dynamic memory allocation.
  2. Re: notability and OR. I agree that all of my initial edits were made without clear guidance of reliable sources. However, after several disputes forced me to do quite a lot of research in RS, I think moving back to headers has many more problems. Most of the RS group all functions not by header, but by functionality, which is usually the same as headers, but not always. For example, we can look at the C99 standard: all sections are named in this format Mathematics <math.h>. K&R C programming language (2nd edition) doesn't use header names at all (e.g. Storage management), except in the appendixes. The C++ books don't emphasize headers at all when talking about the functionality inherited from C, for examples we can look at B. Stroustrup The C++ Programming Language (3rd Edition), B. Stroustrup Programming: Principles and Practice Using C++, C++ standard. I did what I could not to cherrypick, these are the most notable books I have.
  3. Much bigger problem with articles about headers is that we can't write an encyclopedic article about them, since reliable sources have only very little information about the header itself. Most of the time they include only a short mention about the header and then go on talking about the contained functions. Thus the real scope is not the specific header, but the functions contained within that header. Since there are a lot of RS that don't group the functions by header at all, I think it is not OR to do similarly. A relevant discussion has been developed at Misplaced Pages:Articles_for_deletion/Stdlib.h.
1exec1 (talk) 20:36, 2 November 2011 (UTC)
Okay, I understand you're skeptical of how one might write an encyclopedic article about a header, so let me explain how I would go about it. But first let me talk a little about notability.
The big hurdle in writing about anything on WP is establishing notability, which has a much more technical meaning here than most people expect from common usage. It's not enough that a topic seem notable or that it just seems like this would be a good way to break things up into a nice set of essays. Each topic has to satisfy the WP:GNG meaning there have to be secondary sources that actually take note of that specific topic. But that's all it takes. They don't have to offer long essays of the politics of why that header used all lower case, no Hungarian or whatever. When multiple writers devote whole sections to the same material, even if it is largely duplicative in the reporting, as long as it's not dismissible as, e.g., routine coverage of a press release, that gets you notability. (This, btw, is also the threshold that keeps out people wanting to use WP to advertise their latest wondergadget, supported only by their website; the answer to them is that they need to get other people to write about them first. If they can convince a couple reliable journalists that their products are notable, that goes a long way toward convincing us.)
I'm very much a deletionist, mostly because I like being able to come here and get verifiable information, which you don't get if you allow spam or allow people to think of WP as a great place to post useful essays. Case-by-case — and that's how we should look at notability — it seems to me there's no question we can establish notability of individual routines and headers. If we find a source talking about stdlib.h or limits.h or malloc(), we can be pretty sure they're about that particular, identifiable, notable thing. That means we can and should have an article on it, which probably will start as a stub and may stay that way for years waiting for someone to put the effort into making it something more than a stub. Otoh, where notability is a question, it does not follow that the problem can be solved with a more generic title; those articles should go or be merged.
Once notability is established, it's just basic research to fill in the rest. It's work, but I think it's fun. I pick the topics I work on to be ones where I already know something about the history to know what to go look for. But if I were to pick up working on one of the header articles, I would start by trying to identify the who, what, when, where facts which might distinguish this from a simple man page. I like filling in is the history. Computer scientists working in the C / Unix community in the 80s left fingerprints all over the place on Usenet discussing what they were doing and why and it's all been captured on Google. They also wrote lots of papers for USENIX or the Bell System Technical Journal. Sites like the Unix tree have archives of old builds. Can we establish who wrote it and when? What was in the earliest release? What did it do? What got added or changed over time? Were there any fights over performance (e.g., the BSD4.3 malloc) or security or standardization? Although the easiest material to fill in for a header file will always be just the man page stuff, that's not what WP is here for. If that's all you have on an otherwise notable topic, that's called a stub. We don't delete them, they just wait for someone with time to do the non-original but, I think, fascinating research. Msnicki (talk) 17:36, 3 November 2011 (UTC)
Alright. Nice story - I disagree with many of the points you brought up, let's ignore that for now - but would you be willing to demonstrate it ("show me the code"-style)? Pick one of the headers - I'd prefer it to be stdlib.h, but any one of them is fine - and expand it, beyond a one-line definition and list of function prototypes, in the way you propose. But, as you also point out above, that expansion should concern only the header file in question, not the implementation of functions whose prototype happen to be listed in that header file, but are properly part of crt.lib or some equivalent. My position is mostly based on the fact that I'm convinced this is not possible, demonstrate me wrong. —Ruud 18:16, 3 November 2011 (UTC)
The test of whether we should have an article is notability, not how much there is to say WP:TOOLITTLE or whether any particular editor is willing to put the effort into creating more than a stub WP:NOEFFORT. Not every objection or demand, including those not supported by the guidelines, has be met to unanimous satisfaction, especially where the objection has been answered but someone just doesn't like the answer. Msnicki (talk) 18:45, 3 November 2011 (UTC)
Repeating this doesn't make it true. You're clearly neither interested in improving the quality of encyclopedic coverage of the C programming language in Misplaced Pages, nor in having an insightful intellectual debate. I will stop wasting my time with trying to communicate with you. Goodbye. —Ruud 19:07, 3 November 2011 (UTC)
Okay, never mind what I say, let's consult the guidelines. From WP:N, "On Misplaced Pages, notability is a test used by editors to decide whether a topic can have its own article." Msnicki (talk) 21:14, 3 November 2011 (UTC)
Yet it is only a prerequisite. Can you show specific papers, books, etc. that allow us to write an article longer than several sentences? If not, can you provide specific reason, why the header can not be covered as a section of another article? 1exec1 (talk) 04:04, 4 November 2011 (UTC)
Your objection about length is irrelevant. From WP:TOOLITTLE, "There is no minimum or maximum length that qualifies an article, just the reliable sourcing of the information. Since nothing is in stone, articles can grow, shrink, merge, split, and change in all different ways over time. But once the subject becomes clearly notable, they do not disappear." But whatever the title, the hurdle is still notability. You need to establish notability for each title with reliable independent secondary sources as required by WP:GNG. That's impossible for "C dynamic memory management" but doable for malloc. This is not a "technical" objection. Notability is a pretty big deal on Misplaced Pages. If you want an article with a given title, you need WP:RS sources. For each and every proposed title, where are they? That's your burden; what have you done about that? Msnicki (talk) 05:19, 4 November 2011 (UTC)
Request. Currently I am yet to see any valid arguments against the moves from C *** titles to *** in C which is technical in nature. The disagreement is mainly about whether these articles should be moved back to header names, which is not very dependent to the proposed moves (if we decided to move the articles back to header titles, it's not important whether the articles are at C *** or *** in C). Can anyone provide at least one argument against the proposed move?
Yes. You do not have consensus. Msnicki (talk) 04:58, 4 November 2011 (UTC)
That's not a valid argument. Per WP:CONSENSUS no consensus by itself is not a reason, the arguments used to build the consensus are.

<...>Consensus discussion has a particular form: editors try to persuade others, using reasons based in policy, sources, and common sense.<...>

No arguments concerning this particular move have been raised so far. 1exec1 (talk) 13:48, 4 November 2011 (UTC)
What do you mean, "no arguments"? You've gotten objections based on concerns of notability and WP:OR to your proposal and you haven't answered them. (And btw, if you do wish to answer them, you should do it with sources, not arguments.) You do not have consensus support. I don't see how this can be unclear. Msnicki (talk) 13:57, 4 November 2011 (UTC)
Sorry, I meant valid arguments. The sources for notability have been already posted:

For example, we can look at the C99 standard: all sections are named in this format Mathematics <math.h>. K&R C programming language (2nd edition) doesn't use header names at all (e.g. Storage management), except in the appendixes. The C++ books don't emphasize headers at all when talking about the functionality inherited from C, for examples we can look at B. Stroustrup The C++ Programming Language (3rd Edition), B. Stroustrup Programming: Principles and Practice Using C++, C++ standard.

However, these are not the only ones. There are lots of sources using *** in C wording: e.g. A.A.Puntambekar - Data Structures with C, S.G. Agarwal - Memory Management in C and C++, L. Ferres Memory management in C: The heap and the stack. All of these sources allow us to write an encyclopedic article about, in this case, dynamic memory allocation in C.
1exec1 (talk) 14:04, 4 November 2011 (UTC)
The fact that a phrase is common or generally descriptive does not make it a notable topic. "Memory management in C" can mean a lot of things and only sometimes does it refer to malloc or any other definitely notable topic. We don't have articles on non-notable topics. I see from your edit history you haven't spent much time in AfDs and it shows here; you need to spend more time understanding how notability works. It's not what you think. Please spend some time reading and thinking about the guidelines. Try to think about what they ask of us, not just how to get your way. Msnicki (talk) 14:39, 4 November 2011 (UTC)
1) I think I understand notability criteria well and that's orthogonal to my editing habits.
2) Please show specific parts of WP:N and/or WP:OR that are being violated.
3) I do not say that Memory management in C should contain only malloc. It will include whatever WP:RS say Dynamic memory allocation in C means, including realloc, free, calloc. Thus there are no issues with scope.
4) The following two WP:RS in addition to the already posted ones establish notability and remove any doubts of WP:OR for Dynamic memory allocation in C: S.G.Ganesh - Dynamic Memory Allocation in C, Dr. M.K. Sharma, Dr. M.P. Thapliyal - Concept of Computer and C Programming. 1exec1 (talk) 14:55, 4 November 2011 (UTC)
Obviously, you're entitled to your opinion. But the point is, there's a difference of opinion. Two of us have opposed based on WP:N and WP:OR and this means you do not have consensus support. I don't know how to be more clear. Msnicki (talk) 15:02, 4 November 2011 (UTC)
1) Consensus is based on arguments not votes WP:NOTDEMOCRACY.
2) Please show specific parts of WP:N and/or WP:OR that are being violated since so many WP:RS have been provided.
3) Please show WP:RS that base your choice of title.
4) You repeatedly do not directly address or rebut the raised points. That's disruptive editing.
1exec1 (talk) 15:14, 4 November 2011 (UTC)
Categories: