SQF Highlighter – Extension
Jump to navigation
Jump to search
Lou Montana (talk | contribs) m (Fix examples) |
Lou Montana (talk | contribs) (Add options documentation) |
||
Line 38: | Line 38: | ||
* Unzip the directory to {{hl|wiki/extensions/SQFHighlighter}} | * Unzip the directory to {{hl|wiki/extensions/SQFHighlighter}} | ||
* Add <syntaxhighlight lang="php" inline>wfLoadExtension( 'SQFHighlighter' );</syntaxhighlight> to {{hl|LocalSettings.php}} | * Add <syntaxhighlight lang="php" inline>wfLoadExtension( 'SQFHighlighter' );</syntaxhighlight> to {{hl|LocalSettings.php}} | ||
* | * there is a {{hl|case-sensitive}} setting in {{hl|extension.json}} (default true). Set to false to highlight improperly-cased commands and functions (e.g [[setDamage|SetDamage]] instead of [[setDamage]], etc) | ||
* The extension creates full path links unless the host is one of the following (then relative links are created): | |||
** {{hl|community.bistudio.com}} | ** {{hl|community.bistudio.com}} | ||
** {{hl|community.bohemia.net}} | ** {{hl|community.bohemia.net}} | ||
Line 45: | Line 46: | ||
== Usage == | == Usage == | ||
Using < | Using <syntaxhighlight lang="html" inline><sqf></syntaxhighlight> tags will auto-generate syntax highlighting '''and''' links to the pages. | ||
{| class="wikitable valign-top" style="min-width: 50em" | {| class="wikitable valign-top" style="min-width: 50em" | ||
Line 202: | Line 203: | ||
== CSS Classes == | == CSS Classes == | ||
All elements are | All elements are <syntaxhighlight lang="html" inline><span></syntaxhighlight> except for some exceptions: | ||
* unless using <syntaxhighlight lang="html" inline><sqf inline></syntaxhighlight>, the parent block is a <syntaxhighlight lang="html" inline><div></syntaxhighlight> holding another one for scrolling purpose; otherwise, is is a <syntaxhighlight lang="html" inline><span></syntaxhighlight> as well. | |||
{| class="wikitable" | {| class="wikitable" | ||
! Element | ! Element | ||
Line 216: | Line 219: | ||
| <sqf></sqf><br><sqs></sqs> | | <sqf></sqf><br><sqs></sqs> | ||
|- | |- | ||
| wild character / bad variable | | wild character / bad variable / unclosed string | ||
| bv, bvl | | bv, bvl | ||
| <sqf> | | <sqf> | ||
@ | @ | ||
private _var = 3RndMag; | private _var = 3RndMag; | ||
hint "hello | |||
</sqf> | </sqf> | ||
|- | |- | ||
| comment | | comment | ||
| cc | | cc | ||
| <sqf>// comment | | <sqf> | ||
// comment | |||
/* | /* | ||
Line 231: | Line 237: | ||
a multiline | a multiline | ||
comment | comment | ||
*/</sqf> | */ | ||
</sqf> | |||
|- | |- | ||
| string | | string | ||
Line 239: | Line 246: | ||
| n | | n | ||
| sqfhighlighter-'''number''' | | sqfhighlighter-'''number''' | ||
| <sqf>42 | | <sqf> | ||
42 | |||
-6.9 | -6.9 | ||
10e10</sqf> | 10e10 | ||
</sqf> | |||
|- | |- | ||
| operator | | operator | ||
Line 271: | Line 280: | ||
| global variable | | global variable | ||
| gv | | gv | ||
| <sqf>// anything will go but UNDERSCORED_ALL_CAPS | | <sqf> | ||
GlobalVar = 1;</sqf> | // anything will go but UNDERSCORED_ALL_CAPS | ||
GlobalVar = 1; | |||
</sqf> | |||
|- | |- | ||
| macro | | macro | ||
| m | | m | ||
| <sqf>#define myVar 1 | | <sqf> | ||
#define myVar 1 | |||
#if | #if | ||
#endif</sqf> | #endif | ||
</sqf> | |||
|- | |- | ||
| constant ({{hl|#define}}d value) | | constant ({{hl|#define}}d value) | ||
| c | | c | ||
| <sqf>// anything #defined only | | <sqf> | ||
// anything #defined only | |||
#define testVar 1 | #define testVar 1 | ||
testVar; | testVar; | ||
otherVar; | otherVar; | ||
MY_CONSTANT;</sqf> | MY_CONSTANT; | ||
</sqf> | |||
|- | |- | ||
| array start ({{hl|[}}) | | array start ({{hl|[}}) |
Revision as of 02:01, 31 July 2022
SQF Highlighter | |
---|---|
Description | Highlights and links SQF commands and functions |
Author | Lou Montana |
Project Start | 2022-03-08: Project start |
Release Date |
|
Version | 0.85b |
This extension highlights and automatically links SQF commands and functions. It also covers SQS (free of charge).
Features
- SQF Syntax support
- SQS Syntax support
- "Copy code to clipboard" button on hover
- #defined constant value on mouse hover
- SQF tag button in the wiki edit toolbar (next to B and I)
- Options:
- inline for inline code
- notrim to remove the auto trim (lines themselves will always be rtrimmed)
Installation
- Unzip the directory to wiki
/extensions /SQFHighlighter - Add
wfLoadExtension( 'SQFHighlighter' );
to LocalSettings.php - there is a case-sensitive setting in extension.json (default true). Set to false to highlight improperly-cased commands and functions (e.g SetDamage instead of setDamage, etc)
- The extension creates full path links unless the host is one of the following (then relative links are created):
- community.bistudio.com
- community.bohemia.net
Usage
Using <sqf>
tags will auto-generate syntax highlighting and links to the pages.
SQF Syntax | |
---|---|
Code | Result |
<sqf/>
|
-no SQF code provided-
|
<sqf></sqf>
|
-no SQF code provided-
|
<sqf> </sqf>
|
-no SQF code provided-
|
<sqf>hint "It Works!";</sqf>
|
hint "It Works!"; |
This is <sqf inline>hint "It Works!";</sqf> absolutely inline.
|
This is hint "It Works!"; absolutely inline. |
<sqf notrim>
hint "It Works!";
</sqf>
|
hint "It Works!";
|
<sqf>
// your code here
hint "good!";
</sqf>
|
|
<sqf>
#define fadeInDuration 3
waitUntil { not alive player };
hint DEATH_MESSAGE;
cutText ["", "Black", playerRespawnTime];
private _deathTime = time;
Deaths = Deaths + 1;
/*
wait for resurrection
*/
waitUntil { alive player && { preloadCamera getPosATL player } };
sleep 3;
cutText ["Welcome!", "Black in", fadeInDuration];
// after 10s, end the mission
sleep 10;
[] call BIS_fnc_endMission;
</sqf>
|
#define fadeInDuration 3
waitUntil { not alive player };
hint DEATH_MESSAGE;
cutText ["", "Black", playerRespawnTime];
private _deathTime = time;
Deaths = Deaths + 1;
/*
wait for resurrection
*/
waitUntil { alive player && { preloadCamera getPosATL player } };
sleep 3;
cutText ["Welcome!", "Black in", fadeInDuration];
// after 10s, end the mission
sleep 10;
[] call BIS_fnc_endMission; |
SQS Syntax | |
Code | Result |
<sqs/>
|
-no SQS code provided-
|
<sqs></sqs>
|
-no SQS code provided-
|
<sqs> </sqs>
|
-no SQS code provided-
|
<sqs>hint "It Works!"</sqs>
|
hint "It Works!"; |
This is <sqs inline>hint "It Works!"</sqs> absolutely inline.
|
This is hint "It Works!" absolutely inline. |
<sqs notrim>
hint "It Works!";
</sqs>
|
hint "It Works!";
|
<sqs>
#loop
@ alive player
; you ok
hint "OK"
~1
@ not alive player
~1
hint "you ded"
; you not ok
goto "loop"
</sqs>
|
CSS Classes
All elements are <span>
except for some exceptions:
- unless using
<sqf inline>
, the parent block is a<div>
holding another one for scrolling purpose; otherwise, is is a<span>
as well.
Element | CSS class | Overview |
---|---|---|
parent block | sqfhighlighter-block contains sqfhighlighter-scroller for blocks |
; |
error message | sqfhighlighter-error | -no SQF code provided- -no SQS code provided-
|
wild character / bad variable / unclosed string | bv, bvl | |
comment | cc | // comment
/*
this is
a multiline
comment
*/ |
string | s | "string" |
n | sqfhighlighter-number | 42
-6.9
10e10 |
operator | o | |
keyword (if, then, waitUntil, etc) | k | |
command | c | |
function | f | |
function (external) | fe | // not just considering BIS_ or BIN_
BIS_fnc_unknownFunction
TAG_fnc_spawnGroup |
local variable | lv | _localVar |
global variable | gv | |
macro | m | #define myVar 1
#if
#endif |
constant (#defined value) | c | // anything #defined only
#define testVar 1
testVar;
otherVar;
MY_CONSTANT; |
array start ([) | as | [ /* ... */ |
array end (]) | ae | /* ... */ ] |
code start ({) | cs | { /* ... */ |
code end (}) | ce | /* ... */ } |
parenthese start ({) | ps | ( /* ... */ |
parenthese end (}) | pe | /* ... */ ) |
Known Issues
Version | Issue | Report Date | Fix Date |
---|---|---|---|
v1 | comment blocks still highlight words as global variables for now | 2022-03-15 | 2022-03-17 |
#if are considered as keywords | 2022-03-15 | 2022-03-17 | |
single-quote strings have issues with other formatting between quotes | 2022-03-15 | w/ v2 | |
negative numbers should see the minus sign coloured as well in the end, they should not |
2022-03-15 | 2022-03-17 | |
numbers in variables are highlighted as numbers (e.g unit1) | 2022-03-22 | w/ v2 | |
v2 | preprocessor instructions are not considered if not at the very beginning of the line (and the parsing of the whole line may be wrong) | 2022-07-11 | 2022-07-12 |