Template:Smcfunc: Difference between revisions From Online Manual

Jump to: navigation, search
No edit summary
(set a parameter for internal functions that the coder should probably never call.)
Line 6: Line 6:
-->{{#if: {{{function|}}}|{{#ifeq: {{lcfirst:{{PAGENAMEE}}}}|{{{function}}}|| ===[[{{{function|}}}]]=== }}
-->{{#if: {{{function|}}}|{{#ifeq: {{lcfirst:{{PAGENAMEE}}}}|{{{function}}}|| ===[[{{{function|}}}]]=== }}
{{#if: {{{usage|}}}|<p>'''Usage''': {{code|1={{{usage}}}}}{{#set:SMC_usage_exm={{{usage}}}}}</p>|}}<!--
{{#if: {{{usage|}}}|<p>'''Usage''': {{code|1={{{usage}}}}}{{#set:SMC_usage_exm={{{usage}}}}}</p>|}}<!--
-->{{#if: {{{internal|}}}|
-->{{#if: {{{internal|}}}|<!--
{{ambox
-->{{#set:SMC_internal={{{internal}}}}}<!--
-->{{ambox
| type      = style
| type      = style
| image      = [[File:Ambox_deletion.png|40px|alt=Question mark]]
| image      = [[File:Ambox_deletion.png|40px|alt=Question mark]]

Revision as of 15:41, 11 October 2012

{{#set:SMC_order_position={{{function}}}}}Template must be given a tag

[edit] [purge] Template documentation

This template should be used for pages describing $smcFunc functions.

Available parameters:

  • function the name of the function (e.g. db_query)
  • order_position (optional) a number defining the order position for sorting purposes.
  • usage how the function is called with all the parameters available
  • description a description of what the function does and how it works
  • parameters a {{parmdesc}} list of the parameters the function accepts and relative description
  • internal if set a box will remind the function is to be used only internally by the database abstraction layer
  • return description of what the function returns if anything is returned
  • notes additional notes if needed
  • example an example of how the function must be used, please use the <nowiki> and </nowiki> tag to surround the code block as described in the {{code}} template documentation
  • additional fields tree additional fields where is possible to specify the name of the parameter and its content, to be used like in {{parmdesc}}: |name of the field|d1=description of the field


{{smcfunc
|function=db_query
|usage=$smcFunc['db_query'](identifier, query, values, connection)
|description=Works similar to how db_query worked in 1.x versions.
|parameters={{parmdesc
  |identifier|d1=is used to identify specific query types in which it is necessary to replace portions of the query for compatability across all Database Management Systems supported by SMF. The query must be written for MYSQL. The db_query function will alter the query.{{parmdesc
    |substring|d1=for the SQLite database, '''SUBSTRING''' will be replaced by '''SUBSTR'''
    |See the function smf_db_query|d2= in Subs-DB-{dbms}.php for the full list of replacements.
  }}
  |values|d2=is an array of values you are intending to use in the query.
}}
|return=a query resource or '''false''' on error.
|example=<nowiki>$result = $smcFunc['db_query'](''', '
	SELECT poster_time
	FROM {db_prefix}messages
	WHERE id_msg = {int:id_msg}
	LIMIT 1',
	array(
		'id_msg' => $user_settings['id_msg_last_visit'],
	)
);
|Example with identifier 'substring'|d1=
{{code|1=$result = $smcFunc['db_query']('substring', '
	SELECT m.subject, 
		'. ($mylimit > 0 ? SUBSTRING(m.body, 1, '.$mylimit.') as body  : 'm.body'). ', 
		IFNULL(mem.real_name, m.poster_name) AS realName, m.poster_time as date, mem.avatar, mem.posts, mem.date_registered as dateRegistered,mem.last_login as lastLogin,
		IFNULL(a.id_attach, 0) AS ID_ATTACH, a.filename, a.attachment_type as attachmentType, t.id_board as category, b.name as category_name,
		array(
			'id_msg' => $user_settings['id_msg_last_visit'],
		)
	);}}
}}

</nowiki>

will result in {{smcfunc |function=db_query |usage=$smcFunc['db_query'] (identifier, query, values, connection) |description=Works Similar to how db_query worked in 1.x versions. |parameters={{parmdesc

 |identifier|d1=is used to identify specific query types in which it is necessary to replace portions of the query for compatability across all Database Management Systems supported by SMF. The query must be written for MYSQL. The db_query function will alter the query.{{parmdesc
   |substring|d1=for the SQLite database, SUBSTRING will be replaced by SUBSTR
   |See the function smf_db_query|d2= in Subs-DB-{dbms}.php for the full list of replacements.
 }}
 |values|d2=is an array of values you are intending to use in the query.

}} |return=a query resource or false on error. |example=$result = $smcFunc['db_query'](''', ' SELECT poster_time FROM {db_prefix}messages WHERE id_msg = {int:id_msg} LIMIT 1', array( 'id_msg' => $user_settings['id_msg_last_visit'], ) ); |Example with identifier 'substring'|d1=

$result = $smcFunc['db_query']('substring', '
	SELECT m.subject, 
		'. ($mylimit > 0 ? SUBSTRING(m.body, 1, '.$mylimit.') as body  : 'm.body'). ', 
		IFNULL(mem.real_name, m.poster_name) AS realName, m.poster_time as date, mem.avatar, mem.posts, mem.date_registered as dateRegistered,mem.last_login as lastLogin,
		IFNULL(a.id_attach, 0) AS ID_ATTACH, a.filename, a.attachment_type as attachmentType, t.id_board as category, b.name as category_name,
		array(
			'id_msg' => $user_settings['id_msg_last_visit'],
		)
	);

}}



Advertisement: