Wikipedia talk:Wikipedia Signpost/2012-01-30/Technology report: Difference between revisions
Appearance
Content deleted Content added
Salix alba (talk | contribs) printf |
unicode |
||
Line 22: | Line 22: | ||
* This sounds '''great'''! I can't wait to get my hands on Lua capabilities in my Semantic templates. [[User:Thingles|Jamie]] ([http://thingelstad.com/ blog] | [http://jjt.me/ hello]) 03:44, 2 February 2012 (UTC) |
* This sounds '''great'''! I can't wait to get my hands on Lua capabilities in my Semantic templates. [[User:Thingles|Jamie]] ([http://thingelstad.com/ blog] | [http://jjt.me/ hello]) 03:44, 2 February 2012 (UTC) |
||
* Lua is a very nice programming language, that isn't that hard to learn. I'm looking forward to being able to use it in templates, ect. '''If you want documentation, you can look [http://www.lua.org/manual/5.2/ here]'''. I presume for output, we'll use print("Hello World"), and stuff like that. It will be interesting to see what gets removed, and what stays when they update. (FYI, people get picky when you call it 'LUA' as it's not an [[Acronym]], or when you call it 'lua', as 'lua' is [[portugues]] for moon. Make sure you call it [[Lua]]. :D) <span style="font-size: 75%; color:#C0C0C0; line-height: inherit;">[[User:Idofen|Idofen]] ([[User talk:Idofen|talk]] | [[Special:Contributions/Idofen|contribs]] | February 2) </span> <span style="font-size: smaller;" class="autosigned">—Preceding [[Wikipedia:Signatures|undated]] comment added 07:39, 2 February 2012 (UTC).</span><!--Template:Undated--> <!--Autosigned by SineBot--> |
* Lua is a very nice programming language, that isn't that hard to learn. I'm looking forward to being able to use it in templates, ect. '''If you want documentation, you can look [http://www.lua.org/manual/5.2/ here]'''. I presume for output, we'll use print("Hello World"), and stuff like that. It will be interesting to see what gets removed, and what stays when they update. (FYI, people get picky when you call it 'LUA' as it's not an [[Acronym]], or when you call it 'lua', as 'lua' is [[portugues]] for moon. Make sure you call it [[Lua]]. :D) <span style="font-size: 75%; color:#C0C0C0; line-height: inherit;">[[User:Idofen|Idofen]] ([[User talk:Idofen|talk]] | [[Special:Contributions/Idofen|contribs]] | February 2) </span> <span style="font-size: smaller;" class="autosigned">—Preceding [[Wikipedia:Signatures|undated]] comment added 07:39, 2 February 2012 (UTC).</span><!--Template:Undated--> <!--Autosigned by SineBot--> |
||
* '''Lua has no native Unicode string support.''' How will this be addressed? [[Special:Contributions/67.6.156.62|67.6.156.62]] ([[User talk:67.6.156.62|talk]]) 22:28, 2 February 2012 (UTC) |
Revision as of 22:28, 2 February 2012
Discuss this story
- So to write templates I need to learn a new language. This could be interesting. I hope that it has more documentation then the current language --Guerillero | My Talk 04:45, 31 January 2012 (UTC)
- It strikes me that it's profoundly unlikely to be worse. As a programming language, ParserFunctions is horrible. At work this month I've been doing large and complicated things with ant ... I've nicknamed it mod_brainfuck. Turing complete is actually a sort of curse - if all you have is a hammer and it's Turing-complete, you will use it as a screwdriver, spanner, soda siphon, nail ... - David Gerard (talk) 08:28, 31 January 2012 (UTC)
- I remember LUA from the old days scripting my World of Warcraft client (they it for the same reasons: security and light weight). It's not a bad language (even if I found it a bit confusing). -- Luk talk 09:27, 31 January 2012 (UTC)
- "The potential for bias within the survey was not examined." what is the point in writing about useless surveys? Bulwersator (talk) 09:51, 31 January 2012 (UTC)
- It's not useless, you just have to take it for what it is: a survey of Wikipedia readers, not a survey of the population in general. - Jarry1250 [Deliberation needed] 13:42, 31 January 2012 (UTC)
- Moving to Lua will reduce the programming complexity of templates, which is good, but it will increase the resource utilization of the scripts, so somehow limitations will need to be introduced to limit script cpu time. Does Lua make this easy to do?Jeff Kubina (talk) 23:08, 31 January 2012 (UTC)
- One of the positives of Lua discussed was the ease with which memory limits can be imposed to prevent accidental/deliberate massive memory allocations taking down whole servers. (Note that I would not be so sure average resource utilisation will go up rather than down: some templates are very resource-intensive at present.) - Jarry1250 [Deliberation needed] 23:19, 31 January 2012 (UTC)
- Excellent! Thanks Jarry. So then in terms of current templates I agree, I suspect many of them would run much more efficiently in Lua. What I suspect will happen though is that templates will evolve to provide much more (better, useful) information using about the same amount of cpu time that they use now to be generated (and be easier to write); so it is a long term win situation. Jeff Kubina (talk) 04:12, 1 February 2012 (UTC)
- I think that would be a very apt analysis. There will of course also be some widespread templates for which no new functionality is available, which would therefore see definite drops in resource intensity ({{convert}} perhaps?) - Jarry1250 [Deliberation needed] 11:22, 1 February 2012 (UTC)
- A lot of the complexity of {{convert}} could be solved by exposing a printf type facility, to do all the fussy rounding of numbers. Many layers templates are needed to mimic this functionality.--Salix (talk): 13:41, 2 February 2012 (UTC)
- I think that would be a very apt analysis. There will of course also be some widespread templates for which no new functionality is available, which would therefore see definite drops in resource intensity ({{convert}} perhaps?) - Jarry1250 [Deliberation needed] 11:22, 1 February 2012 (UTC)
- Excellent! Thanks Jarry. So then in terms of current templates I agree, I suspect many of them would run much more efficiently in Lua. What I suspect will happen though is that templates will evolve to provide much more (better, useful) information using about the same amount of cpu time that they use now to be generated (and be easier to write); so it is a long term win situation. Jeff Kubina (talk) 04:12, 1 February 2012 (UTC)
- One of the positives of Lua discussed was the ease with which memory limits can be imposed to prevent accidental/deliberate massive memory allocations taking down whole servers. (Note that I would not be so sure average resource utilisation will go up rather than down: some templates are very resource-intensive at present.) - Jarry1250 [Deliberation needed] 23:19, 31 January 2012 (UTC)
- Since when is Lua "relatively unheard-of"? --cmelbye (t/c) 00:21, 1 February 2012 (UTC)
- Of course "relatively unheard-of" a subjective term. Since it's an issue that interests me, I thought I might as well do some digging:
- On Github it ranks at #18 for number of repos and #17 for number of users, way behind JavaScript, which was also considered for this role, and PHP, the main language of MediaWiki itself (source).
- Probably due to the fact that it is mainly known in game programming circles, it did not rank in a 2007 survey of job adverts
- It was not included in this top-ten of programming languages by book sales
- In this comprehensive analysis it ranks at #15 by Yahoo! searches, #21 for job adverts, #26 for book sales, and #15 for projects.
- Of course, I have used ordinals, but I could have used cardinals. I agree that maybe people have heard of it (literally speaking) but the point I was trying to make was more figurative, and relates to the fact that Lua is an unfamiliar language to virtually all wiki admins and even a considerable percentage of the "hard core" of WMF techies. - Jarry1250 [Deliberation needed] 00:48, 1 February 2012 (UTC)
- Of course "relatively unheard-of" a subjective term. Since it's an issue that interests me, I thought I might as well do some digging:
- As a programmer, I look forward to this. I don't know any Lua, but I've heard good things about it, and I'm sure I can pick it up. I'm also confident it will be more satisfying to work on than ParserFunctions-based templates. Superm401 - Talk 22:56, 1 February 2012 (UTC)
- I am very excited about Mediawiki supporting a real programming language for extensibility. This will dramatically reduce complexity and improve readability and maintainability, and remove a lot of very annoying limitations due to template nesting limits. It'll also enable new things that heretofore were considered too complex or inefficient to undertake. Dcoetzee 03:33, 2 February 2012 (UTC)
- This sounds great! I can't wait to get my hands on Lua capabilities in my Semantic templates. Jamie (blog | hello) 03:44, 2 February 2012 (UTC)
- Lua is a very nice programming language, that isn't that hard to learn. I'm looking forward to being able to use it in templates, ect. If you want documentation, you can look here. I presume for output, we'll use print("Hello World"), and stuff like that. It will be interesting to see what gets removed, and what stays when they update. (FYI, people get picky when you call it 'LUA' as it's not an Acronym, or when you call it 'lua', as 'lua' is portugues for moon. Make sure you call it Lua. :D) Idofen (talk | contribs | February 2) —Preceding undated comment added 07:39, 2 February 2012 (UTC).
- Lua has no native Unicode string support. How will this be addressed? 67.6.156.62 (talk) 22:28, 2 February 2012 (UTC)
← Back to Technology report