diff --git a/README.md b/README.md index 0eb8ad2..98e9c67 100644 --- a/README.md +++ b/README.md @@ -28,7 +28,7 @@ This is a recursive Fibonacci function. This algorithm should never be used in production, as iterative approaches are exponentially faster, but it provides a few opportunities to demonstrate Muse's features. -```muse +```muselang fn fib(n) { if n <= 2 { 1 @@ -48,7 +48,7 @@ is an important design goal. Muse also supports *pattern matching*. Here is the same example written using pattern matching instead of if/else: -```muse +```muselang fn fib(n) { match n { n if n <= 2 => 1, @@ -60,7 +60,7 @@ fn fib(n) { Muse also supports *function overloading* using the same pattern match syntax. Here's the same function using function overloading: -```muse +```muselang fn fib { n if n <= 2 => 1, n => fib(n - 1) + fib(n - 2), diff --git a/guide/src/design.md b/guide/src/design.md index c5dde9b..100c52c 100644 --- a/guide/src/design.md +++ b/guide/src/design.md @@ -82,7 +82,7 @@ duck, then it must be a duck. To support various language features, the compiler generates code that tries to use a value in a specific way. For example, the code generated by these two expressions is identical: -```muse +```muselang let a = [0, 1, 2]; # Access the first element using indexing. @@ -112,7 +112,7 @@ Muse, it unwinds the stack to the exception handler. In Rust, it's much easier to check for 0 compared to catching an panic. In Muse, the try operator (`?`) makes it easy to turn any exception into `nil`: -```muse +```muselang # '//' is the integer division operator (1 // 0)? ``` diff --git a/guide/src/reference/assignment.md b/guide/src/reference/assignment.md index 4f91eb9..ace4aa8 100644 --- a/guide/src/reference/assignment.md +++ b/guide/src/reference/assignment.md @@ -16,7 +16,7 @@ When a `let` expression is evaluated, all bound identifiers will not be able to be reassigned to. In Muse, these are simply called *values*. While values cannot be reassigned to, they can be shadowed by another declaration. -```muse +```muselang # Basic value declaration let a = 42; # Values declared using destructuring @@ -37,7 +37,7 @@ done using the `break`, `continue`, `return`, or `throw` expressions. When the `var` keyword is used, all bound identifiers become *variables*. Unlike values, variables can be assigned new values. -```muse +```muselang # Basic declaration var a = 42; # `var`s can have their values updated through assignment. diff --git a/guide/src/reference/bitwise.md b/guide/src/reference/bitwise.md index dbe295c..4f60750 100644 --- a/guide/src/reference/bitwise.md +++ b/guide/src/reference/bitwise.md @@ -30,7 +30,7 @@ functionality. The bitwise or expression produces a new value by performing a logical or operation on each corresponding bit in the two operands. -```muse +```muselang let 0b101 = 0b100 | 0b001 ``` @@ -39,7 +39,7 @@ let 0b101 = 0b100 | 0b001 The bitwise excusive or (xor) expression produces a new value by performing a logical xor operation on each corresponding bit in the two operands. -```muse +```muselang let 0b101 = 0b110 ^ 0b011 ``` @@ -48,7 +48,7 @@ let 0b101 = 0b110 ^ 0b011 The bitwise and expression produces a new value by performing a logical and operation on each corresponding bit in the two operands. -```muse +```muselang let 0b100 = 0b110 & 0b101 ``` @@ -57,14 +57,14 @@ let 0b100 = 0b110 & 0b101 The bitwise shift expressions produce a new value by moving bits left or right by a number of bits, filling in any empty bits with 0. -```muse +```muselang let 0b100 = 0b010 << 1; let 0b001 = 0b010 >> 1; ``` The shift-right expression is sign-preserving when operating on signed integers: -```muse +```muselang let -2 = -4 >> 1; ``` @@ -73,7 +73,7 @@ let -2 = -4 >> 1; The bitwise not expression produces a new value by performing a logical not operation on each bit in the operand. -```muse +```muselang let -1 = !0; let 0uxffff_ffff_ffff_ffff = !0u; ``` diff --git a/guide/src/reference/comparison.md b/guide/src/reference/comparison.md index 2a5abd3..a2061f9 100644 --- a/guide/src/reference/comparison.md +++ b/guide/src/reference/comparison.md @@ -26,7 +26,7 @@ When Muse checks if two values are equal or not equal, Muse will try to approximately compare similar data types. For example, all of these comparisons are true: -```muse +```muselang let true = 1 == 1.0; let true = 1 == true; let true = 1.0 == true; @@ -35,7 +35,7 @@ let true = 1.0 == true; `nil` is only considered equal to `nil` and will be not equal to every other value. -```muse +```muselang let true = nil == nil; let false = nil == false; ``` @@ -58,7 +58,7 @@ Muse interprets `0 < a < 5` as `0 < a && a < 5`. This form of chaining comparisons can mix and match all comparison operators. Consider a longer example: -```muse +```muselang let a = 1; let b = 2; diff --git a/guide/src/reference/errors.md b/guide/src/reference/errors.md index 8648b9b..05c697c 100644 --- a/guide/src/reference/errors.md +++ b/guide/src/reference/errors.md @@ -25,7 +25,7 @@ application. In Rust, the result will be `Err(_)`. Any value can be used as an exception, and handling specific functions is done using pattern matching. Consider this example: -```muse +```muselang fn first(n) { try { second(n) @@ -62,7 +62,7 @@ Catching any error can be done in one of two ways: using an identifier binding or using an arrow catch block. In the next example, both functions are identical: -```muse +```muselang fn identifier_binding() { try { 1 / 0 @@ -86,7 +86,7 @@ fn arrow_catch() { To catch multiple errors raised by inside of a try block, a match block can be used: -```muse +```muselang fn checked_area(width,height) { if width == 0 { throw :invalid_width @@ -111,7 +111,7 @@ A `try` block without a `catch` block will return `nil` if an exception is raised. Similarly, the try operator (`?`) can be used to convert any exception raised to `nil`. These examples produce identical code: -```muse +```muselang try { 1 / 0 diff --git a/guide/src/reference/expressions.md b/guide/src/reference/expressions.md index d4454b6..a9f5785 100644 --- a/guide/src/reference/expressions.md +++ b/guide/src/reference/expressions.md @@ -18,7 +18,7 @@ function](./functions.md#arrow-functions), or an [inline if](./if.md#inline-if). The precedence of these operators matches the order they are listed in. For example, these two ways of assigning to `my_function` are identical: -```muse +```muselang var my_function = nil; my_function = n => n * 2 if n > 0; diff --git a/guide/src/reference/functions.md b/guide/src/reference/functions.md index 140b804..1d72cef 100644 --- a/guide/src/reference/functions.md +++ b/guide/src/reference/functions.md @@ -23,7 +23,7 @@ Anonymous functions do not have a name specified at the time of creation. They can only be called by calling the function returned from the function expression: -```muse +```muselang let square = fn(n) => n ** 2; let 4 = square(2); @@ -49,7 +49,7 @@ using the identifier as its name. These examples are identical to the anonymous function examples, except they utilize named functions instead of `let` expressions to declare the function. -```muse +```muselang fn square(n) => n ** 2; let 4 = square(2); @@ -75,7 +75,7 @@ an open curly brace (`{`) is found after the `fn` keyword or after the function's name, the contents of the braces are interpretted as a set of match patterns: -```muse +```muselang fn area { [width] => width * width, [width, height] => width * height, @@ -100,7 +100,7 @@ When a function executes, the result of the final expression evaluated will be returned. The `return` expression can be used to exit a function without executing any additional code. -```muse +```muselang fn my_function() { return; this_expression_wont_be_evaluated @@ -111,7 +111,7 @@ my_function() The `return` expression can also be provided an expression to return as the result of the function. If no value is provided, `nil` is returned. -```muse +```muselang fn checked_op(numerator, denominator) { if denominator == 0 { return numerator // denominator; diff --git a/guide/src/reference/if.md b/guide/src/reference/if.md index 9f57772..2760ad3 100644 --- a/guide/src/reference/if.md +++ b/guide/src/reference/if.md @@ -16,7 +16,7 @@ the `if` expression: standalone and inline. The standalone `if` expression enables executing an expression when a condition is true: -```muse +```muselang let 42 = if true { 42 }; @@ -30,7 +30,7 @@ let nil = if false then 42; If the `else` keyword is the next token after the "when true" expression, an expression can be evaluated when the condition is false. -```muse +```muselang let 42 = if false { 0 } else { @@ -42,7 +42,7 @@ let 42 = if false then 0 else 42; Because `if` is an expression, the expressions can be chained to create more complex if/else-if expressions: -```muse +```muselang fn clamp_to_ten(n) { if n < 0 { 0 @@ -62,7 +62,7 @@ let 10 = clamp_to_ten(11); An inline if expression returns the *guarded expression* if the condition is true, or `nil` when the condition is false: -```muse +```muselang let 42 = 42 if true; let nil = 42 if false; ``` @@ -70,13 +70,13 @@ let nil = 42 if false; Similar to the standalone `if` expression, `else` can be used to execute a different expression when the condition is false: -```muse +```muselang let 42 = 0 if false else 42; ``` Inline if statements can also be chained: -```muse +```muselang fn clamp_to_ten(n) { 0 if n < 0 else 10 if n > 10 diff --git a/guide/src/reference/label.md b/guide/src/reference/label.md index 0549603..be8a00f 100644 --- a/guide/src/reference/label.md +++ b/guide/src/reference/label.md @@ -21,7 +21,7 @@ A label is the `@` character followed by an identifier, e.g., `@label`. Labels can be applied to blocks or loops to allow controlled execution flow in nested code. -```muse +```muselang var total = 0; @outer: for x in [1, 2, 3] { for y in [1, 2, 3] { diff --git a/guide/src/reference/logic.md b/guide/src/reference/logic.md index 36d50d5..eba67c9 100644 --- a/guide/src/reference/logic.md +++ b/guide/src/reference/logic.md @@ -32,7 +32,7 @@ conditions: The logical or expression is a short-circuiting operator that returns true if either of its operands are truthy. -```muse +```muselang let true = true or true; let true = true or false; let true = false or true; @@ -42,7 +42,7 @@ let false = false or false; The short-circuiting behavior ensures that once the expression is known to return `true`, no remaining chained expressions will be evaluated: -```muse +```muselang # "error" is not evaluated let true = true or error; ``` @@ -52,7 +52,7 @@ let true = true or error; The logical exclusive or (xor) expression is an operator that returns true if one of its operands is truthy, but not both. -```muse +```muselang let true = true xor false; let true = false xor true; let false = true xor true; @@ -66,7 +66,7 @@ This operator can not short-circuit, so both expressions are always evaluated. The logical and expression is a short-circuiting operator that returns true both of its operands are truthy. -```muse +```muselang let true = true or true; let true = true or false; let true = false or true; @@ -76,7 +76,7 @@ let false = false or false; The short-circuiting behavior ensures that once the expression is known to return `false`, no remaining chained expressions will be evaluated: -```muse +```muselang # "error" is not evaluated let false = false and error; ``` diff --git a/guide/src/reference/lookup.md b/guide/src/reference/lookup.md index 0f2178a..2c29cbc 100644 --- a/guide/src/reference/lookup.md +++ b/guide/src/reference/lookup.md @@ -16,7 +16,7 @@ These expression are chainable. For example, this code accesses a value from a list within a list by chaining the index operator after invoking `list.get(0)` function: -```muse +```muselang let list = [[1, 2, 3], [4, 5, 6]]; let 2 = list.get(0)[1]; ``` diff --git a/guide/src/reference/loop.md b/guide/src/reference/loop.md index 3a4e1da..b553b6b 100644 --- a/guide/src/reference/loop.md +++ b/guide/src/reference/loop.md @@ -26,7 +26,7 @@ execution can be affected by these operations: # Infinite Loop -```muse +```muselang var n = 0; let nil = loop { if n % 2 == 0 { @@ -48,7 +48,7 @@ point the loop exits. A while loop checks that a condition is truthy before executing the loop body, and continues repeating until the condition is not truthy. -```muse +```muselang var n = 0; while n < 10 { n = n + 1; @@ -63,7 +63,7 @@ truthy. This is different from a While loop in that the condition is only checked after the first iteration of the loop. The `continue` expression will continue iteration just prior to the condition evaluation. -```muse +```muselang var n = 1; loop { n = n * 3; @@ -82,7 +82,7 @@ If the iterator returns an item that does not match the pattern, the next element will be requested and the loop body will not be executed for that element. -```muse +```muselang var sum = 0; for n in [1, 2, 3] { sum = sum + n diff --git a/guide/src/reference/maps.md b/guide/src/reference/maps.md index 3842cb7..af2240f 100644 --- a/guide/src/reference/maps.md +++ b/guide/src/reference/maps.md @@ -20,7 +20,7 @@ to be an empty block, which results in `nil`. Pairs are specified by placing a colon (`:`) between two expressions. For example, consider this map literal and usage: -```muse +```muselang let map = { "a": 1, "b": 2, @@ -32,7 +32,7 @@ let 2 = map["b"]; Sets in Muse are implemented under the hood using the Map type. Set literals can be specified by using a comma separated list of expressions in curly braces: -```muse +```muselang let set = { 1, 2, diff --git a/guide/src/reference/math.md b/guide/src/reference/math.md index 1926c43..77ef282 100644 --- a/guide/src/reference/math.md +++ b/guide/src/reference/math.md @@ -24,7 +24,7 @@ Arithmetic expressions in Muse honor the traditional [order of operations][ooo]. For example, consider these identical pairs of expressions written without and with parentheses: -```muse +```muselang 2 * 4 + 2 * 3; (2 * 4) + (2 * 3); diff --git a/guide/src/reference/modules.md b/guide/src/reference/modules.md index 2c3fbda..1dbfe5d 100644 --- a/guide/src/reference/modules.md +++ b/guide/src/reference/modules.md @@ -9,7 +9,7 @@ Pub: 'pub' ; Modules provide a way to encapsulate code behind a namespace. Consider this example: -```muse +```muselang mod math { pub fn square(n) => n * n; }; diff --git a/guide/src/reference/pattern-matching.md b/guide/src/reference/pattern-matching.md index e944ce5..9587b27 100644 --- a/guide/src/reference/pattern-matching.md +++ b/guide/src/reference/pattern-matching.md @@ -50,7 +50,7 @@ Multiple matching patterns can be used by chaining patterns together with the vertical bar (`|`). This example uses a match function to try to demonstrate a lot of the flexibility this feature provides: -```muse +```muselang fn test_match { [a, b] if b != 1 => a - b, [a, b] => a + b, diff --git a/guide/src/reference/tuples.md b/guide/src/reference/tuples.md index 2499e61..4bb33dd 100644 --- a/guide/src/reference/tuples.md +++ b/guide/src/reference/tuples.md @@ -7,7 +7,7 @@ Brackets: '[' ']'; A sequence of values stored sequentially is a List in Muse. In other languages, these structures may also be referred to as arrays or tuples. -```muse +```muselang let list = [1, 2, 3]; $assert(list[0] == 1); $assert(list[1] == 2); diff --git a/guide/theme/highlight.js b/guide/theme/highlight.js index 53f9b12..e0b5350 100644 --- a/guide/theme/highlight.js +++ b/guide/theme/highlight.js @@ -52,7 +52,7 @@ hljs.registerLanguage("r", function () { "use strict"; return function (e) { var hljs.registerLanguage("scala", function () { "use strict"; return function (e) { var n = { className: "subst", variants: [{ begin: "\\$[A-Za-z0-9_]+" }, { begin: "\\${", end: "}" }] }, a = { className: "string", variants: [{ begin: '"', end: '"', illegal: "\\n", contains: [e.BACKSLASH_ESCAPE] }, { begin: '"""', end: '"""', relevance: 10 }, { begin: '[a-z]+"', end: '"', illegal: "\\n", contains: [e.BACKSLASH_ESCAPE, n] }, { className: "string", begin: '[a-z]+"""', end: '"""', contains: [n], relevance: 10 }] }, s = { className: "type", begin: "\\b[A-Z][A-Za-z0-9_]*", relevance: 0 }, t = { className: "title", begin: /[^0-9\n\t "'(),.`{}\[\]:;][^\n\t "'(),.`{}\[\]:;]+|[^0-9\n\t "'(),.`{}\[\]:;=]/, relevance: 0 }, i = { className: "class", beginKeywords: "class object trait type", end: /[:={\[\n;]/, excludeEnd: !0, contains: [{ beginKeywords: "extends with", relevance: 10 }, { begin: /\[/, end: /\]/, excludeBegin: !0, excludeEnd: !0, relevance: 0, contains: [s] }, { className: "params", begin: /\(/, end: /\)/, excludeBegin: !0, excludeEnd: !0, relevance: 0, contains: [s] }, t] }, l = { className: "function", beginKeywords: "def", end: /[:={\[(\n;]/, excludeEnd: !0, contains: [t] }; return { name: "Scala", keywords: { literal: "true false null", keyword: "type yield lazy override def with val var sealed abstract private trait object if forSome for while throw finally protected extends import final return else break new catch super class case package default try this match continue throws implicit" }, contains: [e.C_LINE_COMMENT_MODE, e.C_BLOCK_COMMENT_MODE, a, { className: "symbol", begin: "'\\w[\\w\\d_]*(?!')" }, s, l, i, e.C_NUMBER_MODE, { className: "meta", begin: "@[A-Za-z]+" }] } } }()); hljs.registerLanguage("x86asm", function () { "use strict"; return function (s) { return { name: "Intel x86 Assembly", case_insensitive: !0, keywords: { $pattern: "[.%]?" + s.IDENT_RE, keyword: "lock rep repe repz repne repnz xaquire xrelease bnd nobnd aaa aad aam aas adc add and arpl bb0_reset bb1_reset bound bsf bsr bswap bt btc btr bts call cbw cdq cdqe clc cld cli clts cmc cmp cmpsb cmpsd cmpsq cmpsw cmpxchg cmpxchg486 cmpxchg8b cmpxchg16b cpuid cpu_read cpu_write cqo cwd cwde daa das dec div dmint emms enter equ f2xm1 fabs fadd faddp fbld fbstp fchs fclex fcmovb fcmovbe fcmove fcmovnb fcmovnbe fcmovne fcmovnu fcmovu fcom fcomi fcomip fcomp fcompp fcos fdecstp fdisi fdiv fdivp fdivr fdivrp femms feni ffree ffreep fiadd ficom ficomp fidiv fidivr fild fimul fincstp finit fist fistp fisttp fisub fisubr fld fld1 fldcw fldenv fldl2e fldl2t fldlg2 fldln2 fldpi fldz fmul fmulp fnclex fndisi fneni fninit fnop fnsave fnstcw fnstenv fnstsw fpatan fprem fprem1 fptan frndint frstor fsave fscale fsetpm fsin fsincos fsqrt fst fstcw fstenv fstp fstsw fsub fsubp fsubr fsubrp ftst fucom fucomi fucomip fucomp fucompp fxam fxch fxtract fyl2x fyl2xp1 hlt ibts icebp idiv imul in inc incbin insb insd insw int int01 int1 int03 int3 into invd invpcid invlpg invlpga iret iretd iretq iretw jcxz jecxz jrcxz jmp jmpe lahf lar lds lea leave les lfence lfs lgdt lgs lidt lldt lmsw loadall loadall286 lodsb lodsd lodsq lodsw loop loope loopne loopnz loopz lsl lss ltr mfence monitor mov movd movq movsb movsd movsq movsw movsx movsxd movzx mul mwait neg nop not or out outsb outsd outsw packssdw packsswb packuswb paddb paddd paddsb paddsiw paddsw paddusb paddusw paddw pand pandn pause paveb pavgusb pcmpeqb pcmpeqd pcmpeqw pcmpgtb pcmpgtd pcmpgtw pdistib pf2id pfacc pfadd pfcmpeq pfcmpge pfcmpgt pfmax pfmin pfmul pfrcp pfrcpit1 pfrcpit2 pfrsqit1 pfrsqrt pfsub pfsubr pi2fd pmachriw pmaddwd pmagw pmulhriw pmulhrwa pmulhrwc pmulhw pmullw pmvgezb pmvlzb pmvnzb pmvzb pop popa popad popaw popf popfd popfq popfw por prefetch prefetchw pslld psllq psllw psrad psraw psrld psrlq psrlw psubb psubd psubsb psubsiw psubsw psubusb psubusw psubw punpckhbw punpckhdq punpckhwd punpcklbw punpckldq punpcklwd push pusha pushad pushaw pushf pushfd pushfq pushfw pxor rcl rcr rdshr rdmsr rdpmc rdtsc rdtscp ret retf retn rol ror rdm rsdc rsldt rsm rsts sahf sal salc sar sbb scasb scasd scasq scasw sfence sgdt shl shld shr shrd sidt sldt skinit smi smint smintold smsw stc std sti stosb stosd stosq stosw str sub svdc svldt svts swapgs syscall sysenter sysexit sysret test ud0 ud1 ud2b ud2 ud2a umov verr verw fwait wbinvd wrshr wrmsr xadd xbts xchg xlatb xlat xor cmove cmovz cmovne cmovnz cmova cmovnbe cmovae cmovnb cmovb cmovnae cmovbe cmovna cmovg cmovnle cmovge cmovnl cmovl cmovnge cmovle cmovng cmovc cmovnc cmovo cmovno cmovs cmovns cmovp cmovpe cmovnp cmovpo je jz jne jnz ja jnbe jae jnb jb jnae jbe jna jg jnle jge jnl jl jnge jle jng jc jnc jo jno js jns jpo jnp jpe jp sete setz setne setnz seta setnbe setae setnb setnc setb setnae setcset setbe setna setg setnle setge setnl setl setnge setle setng sets setns seto setno setpe setp setpo setnp addps addss andnps andps cmpeqps cmpeqss cmpleps cmpless cmpltps cmpltss cmpneqps cmpneqss cmpnleps cmpnless cmpnltps cmpnltss cmpordps cmpordss cmpunordps cmpunordss cmpps cmpss comiss cvtpi2ps cvtps2pi cvtsi2ss cvtss2si cvttps2pi cvttss2si divps divss ldmxcsr maxps maxss minps minss movaps movhps movlhps movlps movhlps movmskps movntps movss movups mulps mulss orps rcpps rcpss rsqrtps rsqrtss shufps sqrtps sqrtss stmxcsr subps subss ucomiss unpckhps unpcklps xorps fxrstor fxrstor64 fxsave fxsave64 xgetbv xsetbv xsave xsave64 xsaveopt xsaveopt64 xrstor xrstor64 prefetchnta prefetcht0 prefetcht1 prefetcht2 maskmovq movntq pavgb pavgw pextrw pinsrw pmaxsw pmaxub pminsw pminub pmovmskb pmulhuw psadbw pshufw pf2iw pfnacc pfpnacc pi2fw pswapd maskmovdqu clflush movntdq movnti movntpd movdqa movdqu movdq2q movq2dq paddq pmuludq pshufd pshufhw pshuflw pslldq psrldq psubq punpckhqdq punpcklqdq addpd addsd andnpd andpd cmpeqpd cmpeqsd cmplepd cmplesd cmpltpd cmpltsd cmpneqpd cmpneqsd cmpnlepd cmpnlesd cmpnltpd cmpnltsd cmpordpd cmpordsd cmpunordpd cmpunordsd cmppd comisd cvtdq2pd cvtdq2ps cvtpd2dq cvtpd2pi cvtpd2ps cvtpi2pd cvtps2dq cvtps2pd cvtsd2si cvtsd2ss cvtsi2sd cvtss2sd cvttpd2pi cvttpd2dq cvttps2dq cvttsd2si divpd divsd maxpd maxsd minpd minsd movapd movhpd movlpd movmskpd movupd mulpd mulsd orpd shufpd sqrtpd sqrtsd subpd subsd ucomisd unpckhpd unpcklpd xorpd addsubpd addsubps haddpd haddps hsubpd hsubps lddqu movddup movshdup movsldup clgi stgi vmcall vmclear vmfunc vmlaunch vmload vmmcall vmptrld vmptrst vmread vmresume vmrun vmsave vmwrite vmxoff vmxon invept invvpid pabsb pabsw pabsd palignr phaddw phaddd phaddsw phsubw phsubd phsubsw pmaddubsw pmulhrsw pshufb psignb psignw psignd extrq insertq movntsd movntss lzcnt blendpd blendps blendvpd blendvps dppd dpps extractps insertps movntdqa mpsadbw packusdw pblendvb pblendw pcmpeqq pextrb pextrd pextrq phminposuw pinsrb pinsrd pinsrq pmaxsb pmaxsd pmaxud pmaxuw pminsb pminsd pminud pminuw pmovsxbw pmovsxbd pmovsxbq pmovsxwd pmovsxwq pmovsxdq pmovzxbw pmovzxbd pmovzxbq pmovzxwd pmovzxwq pmovzxdq pmuldq pmulld ptest roundpd roundps roundsd roundss crc32 pcmpestri pcmpestrm pcmpistri pcmpistrm pcmpgtq popcnt getsec pfrcpv pfrsqrtv movbe aesenc aesenclast aesdec aesdeclast aesimc aeskeygenassist vaesenc vaesenclast vaesdec vaesdeclast vaesimc vaeskeygenassist vaddpd vaddps vaddsd vaddss vaddsubpd vaddsubps vandpd vandps vandnpd vandnps vblendpd vblendps vblendvpd vblendvps vbroadcastss vbroadcastsd vbroadcastf128 vcmpeq_ospd vcmpeqpd vcmplt_ospd vcmpltpd vcmple_ospd vcmplepd vcmpunord_qpd vcmpunordpd vcmpneq_uqpd vcmpneqpd vcmpnlt_uspd vcmpnltpd vcmpnle_uspd vcmpnlepd vcmpord_qpd vcmpordpd vcmpeq_uqpd vcmpnge_uspd vcmpngepd vcmpngt_uspd vcmpngtpd vcmpfalse_oqpd vcmpfalsepd vcmpneq_oqpd vcmpge_ospd vcmpgepd vcmpgt_ospd vcmpgtpd vcmptrue_uqpd vcmptruepd vcmplt_oqpd vcmple_oqpd vcmpunord_spd vcmpneq_uspd vcmpnlt_uqpd vcmpnle_uqpd vcmpord_spd vcmpeq_uspd vcmpnge_uqpd vcmpngt_uqpd vcmpfalse_ospd vcmpneq_ospd vcmpge_oqpd vcmpgt_oqpd vcmptrue_uspd vcmppd vcmpeq_osps vcmpeqps vcmplt_osps vcmpltps vcmple_osps vcmpleps vcmpunord_qps vcmpunordps vcmpneq_uqps vcmpneqps vcmpnlt_usps vcmpnltps vcmpnle_usps vcmpnleps vcmpord_qps vcmpordps vcmpeq_uqps vcmpnge_usps vcmpngeps vcmpngt_usps vcmpngtps vcmpfalse_oqps vcmpfalseps vcmpneq_oqps vcmpge_osps vcmpgeps vcmpgt_osps vcmpgtps vcmptrue_uqps vcmptrueps vcmplt_oqps vcmple_oqps vcmpunord_sps vcmpneq_usps vcmpnlt_uqps vcmpnle_uqps vcmpord_sps vcmpeq_usps vcmpnge_uqps vcmpngt_uqps vcmpfalse_osps vcmpneq_osps vcmpge_oqps vcmpgt_oqps vcmptrue_usps vcmpps vcmpeq_ossd vcmpeqsd vcmplt_ossd vcmpltsd vcmple_ossd vcmplesd vcmpunord_qsd vcmpunordsd vcmpneq_uqsd vcmpneqsd vcmpnlt_ussd vcmpnltsd vcmpnle_ussd vcmpnlesd vcmpord_qsd vcmpordsd vcmpeq_uqsd vcmpnge_ussd vcmpngesd vcmpngt_ussd vcmpngtsd vcmpfalse_oqsd vcmpfalsesd vcmpneq_oqsd vcmpge_ossd vcmpgesd vcmpgt_ossd vcmpgtsd vcmptrue_uqsd vcmptruesd vcmplt_oqsd vcmple_oqsd vcmpunord_ssd vcmpneq_ussd vcmpnlt_uqsd vcmpnle_uqsd vcmpord_ssd vcmpeq_ussd vcmpnge_uqsd vcmpngt_uqsd vcmpfalse_ossd vcmpneq_ossd vcmpge_oqsd vcmpgt_oqsd vcmptrue_ussd vcmpsd vcmpeq_osss vcmpeqss vcmplt_osss vcmpltss vcmple_osss vcmpless vcmpunord_qss vcmpunordss vcmpneq_uqss vcmpneqss vcmpnlt_usss vcmpnltss vcmpnle_usss vcmpnless vcmpord_qss vcmpordss vcmpeq_uqss vcmpnge_usss vcmpngess vcmpngt_usss vcmpngtss vcmpfalse_oqss vcmpfalsess vcmpneq_oqss vcmpge_osss vcmpgess vcmpgt_osss vcmpgtss vcmptrue_uqss vcmptruess vcmplt_oqss vcmple_oqss vcmpunord_sss vcmpneq_usss vcmpnlt_uqss vcmpnle_uqss vcmpord_sss vcmpeq_usss vcmpnge_uqss vcmpngt_uqss vcmpfalse_osss vcmpneq_osss vcmpge_oqss vcmpgt_oqss vcmptrue_usss vcmpss vcomisd vcomiss vcvtdq2pd vcvtdq2ps vcvtpd2dq vcvtpd2ps vcvtps2dq vcvtps2pd vcvtsd2si vcvtsd2ss vcvtsi2sd vcvtsi2ss vcvtss2sd vcvtss2si vcvttpd2dq vcvttps2dq vcvttsd2si vcvttss2si vdivpd vdivps vdivsd vdivss vdppd vdpps vextractf128 vextractps vhaddpd vhaddps vhsubpd vhsubps vinsertf128 vinsertps vlddqu vldqqu vldmxcsr vmaskmovdqu vmaskmovps vmaskmovpd vmaxpd vmaxps vmaxsd vmaxss vminpd vminps vminsd vminss vmovapd vmovaps vmovd vmovq vmovddup vmovdqa vmovqqa vmovdqu vmovqqu vmovhlps vmovhpd vmovhps vmovlhps vmovlpd vmovlps vmovmskpd vmovmskps vmovntdq vmovntqq vmovntdqa vmovntpd vmovntps vmovsd vmovshdup vmovsldup vmovss vmovupd vmovups vmpsadbw vmulpd vmulps vmulsd vmulss vorpd vorps vpabsb vpabsw vpabsd vpacksswb vpackssdw vpackuswb vpackusdw vpaddb vpaddw vpaddd vpaddq vpaddsb vpaddsw vpaddusb vpaddusw vpalignr vpand vpandn vpavgb vpavgw vpblendvb vpblendw vpcmpestri vpcmpestrm vpcmpistri vpcmpistrm vpcmpeqb vpcmpeqw vpcmpeqd vpcmpeqq vpcmpgtb vpcmpgtw vpcmpgtd vpcmpgtq vpermilpd vpermilps vperm2f128 vpextrb vpextrw vpextrd vpextrq vphaddw vphaddd vphaddsw vphminposuw vphsubw vphsubd vphsubsw vpinsrb vpinsrw vpinsrd vpinsrq vpmaddwd vpmaddubsw vpmaxsb vpmaxsw vpmaxsd vpmaxub vpmaxuw vpmaxud vpminsb vpminsw vpminsd vpminub vpminuw vpminud vpmovmskb vpmovsxbw vpmovsxbd vpmovsxbq vpmovsxwd vpmovsxwq vpmovsxdq vpmovzxbw vpmovzxbd vpmovzxbq vpmovzxwd vpmovzxwq vpmovzxdq vpmulhuw vpmulhrsw vpmulhw vpmullw vpmulld vpmuludq vpmuldq vpor vpsadbw vpshufb vpshufd vpshufhw vpshuflw vpsignb vpsignw vpsignd vpslldq vpsrldq vpsllw vpslld vpsllq vpsraw vpsrad vpsrlw vpsrld vpsrlq vptest vpsubb vpsubw vpsubd vpsubq vpsubsb vpsubsw vpsubusb vpsubusw vpunpckhbw vpunpckhwd vpunpckhdq vpunpckhqdq vpunpcklbw vpunpcklwd vpunpckldq vpunpcklqdq vpxor vrcpps vrcpss vrsqrtps vrsqrtss vroundpd vroundps vroundsd vroundss vshufpd vshufps vsqrtpd vsqrtps vsqrtsd vsqrtss vstmxcsr vsubpd vsubps vsubsd vsubss vtestps vtestpd vucomisd vucomiss vunpckhpd vunpckhps vunpcklpd vunpcklps vxorpd vxorps vzeroall vzeroupper pclmullqlqdq pclmulhqlqdq pclmullqhqdq pclmulhqhqdq pclmulqdq vpclmullqlqdq vpclmulhqlqdq vpclmullqhqdq vpclmulhqhqdq vpclmulqdq vfmadd132ps vfmadd132pd vfmadd312ps vfmadd312pd vfmadd213ps vfmadd213pd vfmadd123ps vfmadd123pd vfmadd231ps vfmadd231pd vfmadd321ps vfmadd321pd vfmaddsub132ps vfmaddsub132pd vfmaddsub312ps vfmaddsub312pd vfmaddsub213ps vfmaddsub213pd vfmaddsub123ps vfmaddsub123pd vfmaddsub231ps vfmaddsub231pd vfmaddsub321ps vfmaddsub321pd vfmsub132ps vfmsub132pd vfmsub312ps vfmsub312pd vfmsub213ps vfmsub213pd vfmsub123ps vfmsub123pd vfmsub231ps vfmsub231pd vfmsub321ps vfmsub321pd vfmsubadd132ps vfmsubadd132pd vfmsubadd312ps vfmsubadd312pd vfmsubadd213ps vfmsubadd213pd vfmsubadd123ps vfmsubadd123pd vfmsubadd231ps vfmsubadd231pd vfmsubadd321ps vfmsubadd321pd vfnmadd132ps vfnmadd132pd vfnmadd312ps vfnmadd312pd vfnmadd213ps vfnmadd213pd vfnmadd123ps vfnmadd123pd vfnmadd231ps vfnmadd231pd vfnmadd321ps vfnmadd321pd vfnmsub132ps vfnmsub132pd vfnmsub312ps vfnmsub312pd vfnmsub213ps vfnmsub213pd vfnmsub123ps vfnmsub123pd vfnmsub231ps vfnmsub231pd vfnmsub321ps vfnmsub321pd vfmadd132ss vfmadd132sd vfmadd312ss vfmadd312sd vfmadd213ss vfmadd213sd vfmadd123ss vfmadd123sd vfmadd231ss vfmadd231sd vfmadd321ss vfmadd321sd vfmsub132ss vfmsub132sd vfmsub312ss vfmsub312sd vfmsub213ss vfmsub213sd vfmsub123ss vfmsub123sd vfmsub231ss vfmsub231sd vfmsub321ss vfmsub321sd vfnmadd132ss vfnmadd132sd vfnmadd312ss vfnmadd312sd vfnmadd213ss vfnmadd213sd vfnmadd123ss vfnmadd123sd vfnmadd231ss vfnmadd231sd vfnmadd321ss vfnmadd321sd vfnmsub132ss vfnmsub132sd vfnmsub312ss vfnmsub312sd vfnmsub213ss vfnmsub213sd vfnmsub123ss vfnmsub123sd vfnmsub231ss vfnmsub231sd vfnmsub321ss vfnmsub321sd rdfsbase rdgsbase rdrand wrfsbase wrgsbase vcvtph2ps vcvtps2ph adcx adox rdseed clac stac xstore xcryptecb xcryptcbc xcryptctr xcryptcfb xcryptofb montmul xsha1 xsha256 llwpcb slwpcb lwpval lwpins vfmaddpd vfmaddps vfmaddsd vfmaddss vfmaddsubpd vfmaddsubps vfmsubaddpd vfmsubaddps vfmsubpd vfmsubps vfmsubsd vfmsubss vfnmaddpd vfnmaddps vfnmaddsd vfnmaddss vfnmsubpd vfnmsubps vfnmsubsd vfnmsubss vfrczpd vfrczps vfrczsd vfrczss vpcmov vpcomb vpcomd vpcomq vpcomub vpcomud vpcomuq vpcomuw vpcomw vphaddbd vphaddbq vphaddbw vphadddq vphaddubd vphaddubq vphaddubw vphaddudq vphadduwd vphadduwq vphaddwd vphaddwq vphsubbw vphsubdq vphsubwd vpmacsdd vpmacsdqh vpmacsdql vpmacssdd vpmacssdqh vpmacssdql vpmacsswd vpmacssww vpmacswd vpmacsww vpmadcsswd vpmadcswd vpperm vprotb vprotd vprotq vprotw vpshab vpshad vpshaq vpshaw vpshlb vpshld vpshlq vpshlw vbroadcasti128 vpblendd vpbroadcastb vpbroadcastw vpbroadcastd vpbroadcastq vpermd vpermpd vpermps vpermq vperm2i128 vextracti128 vinserti128 vpmaskmovd vpmaskmovq vpsllvd vpsllvq vpsravd vpsrlvd vpsrlvq vgatherdpd vgatherqpd vgatherdps vgatherqps vpgatherdd vpgatherqd vpgatherdq vpgatherqq xabort xbegin xend xtest andn bextr blci blcic blsi blsic blcfill blsfill blcmsk blsmsk blsr blcs bzhi mulx pdep pext rorx sarx shlx shrx tzcnt tzmsk t1mskc valignd valignq vblendmpd vblendmps vbroadcastf32x4 vbroadcastf64x4 vbroadcasti32x4 vbroadcasti64x4 vcompresspd vcompressps vcvtpd2udq vcvtps2udq vcvtsd2usi vcvtss2usi vcvttpd2udq vcvttps2udq vcvttsd2usi vcvttss2usi vcvtudq2pd vcvtudq2ps vcvtusi2sd vcvtusi2ss vexpandpd vexpandps vextractf32x4 vextractf64x4 vextracti32x4 vextracti64x4 vfixupimmpd vfixupimmps vfixupimmsd vfixupimmss vgetexppd vgetexpps vgetexpsd vgetexpss vgetmantpd vgetmantps vgetmantsd vgetmantss vinsertf32x4 vinsertf64x4 vinserti32x4 vinserti64x4 vmovdqa32 vmovdqa64 vmovdqu32 vmovdqu64 vpabsq vpandd vpandnd vpandnq vpandq vpblendmd vpblendmq vpcmpltd vpcmpled vpcmpneqd vpcmpnltd vpcmpnled vpcmpd vpcmpltq vpcmpleq vpcmpneqq vpcmpnltq vpcmpnleq vpcmpq vpcmpequd vpcmpltud vpcmpleud vpcmpnequd vpcmpnltud vpcmpnleud vpcmpud vpcmpequq vpcmpltuq vpcmpleuq vpcmpnequq vpcmpnltuq vpcmpnleuq vpcmpuq vpcompressd vpcompressq vpermi2d vpermi2pd vpermi2ps vpermi2q vpermt2d vpermt2pd vpermt2ps vpermt2q vpexpandd vpexpandq vpmaxsq vpmaxuq vpminsq vpminuq vpmovdb vpmovdw vpmovqb vpmovqd vpmovqw vpmovsdb vpmovsdw vpmovsqb vpmovsqd vpmovsqw vpmovusdb vpmovusdw vpmovusqb vpmovusqd vpmovusqw vpord vporq vprold vprolq vprolvd vprolvq vprord vprorq vprorvd vprorvq vpscatterdd vpscatterdq vpscatterqd vpscatterqq vpsraq vpsravq vpternlogd vpternlogq vptestmd vptestmq vptestnmd vptestnmq vpxord vpxorq vrcp14pd vrcp14ps vrcp14sd vrcp14ss vrndscalepd vrndscaleps vrndscalesd vrndscaless vrsqrt14pd vrsqrt14ps vrsqrt14sd vrsqrt14ss vscalefpd vscalefps vscalefsd vscalefss vscatterdpd vscatterdps vscatterqpd vscatterqps vshuff32x4 vshuff64x2 vshufi32x4 vshufi64x2 kandnw kandw kmovw knotw kortestw korw kshiftlw kshiftrw kunpckbw kxnorw kxorw vpbroadcastmb2q vpbroadcastmw2d vpconflictd vpconflictq vplzcntd vplzcntq vexp2pd vexp2ps vrcp28pd vrcp28ps vrcp28sd vrcp28ss vrsqrt28pd vrsqrt28ps vrsqrt28sd vrsqrt28ss vgatherpf0dpd vgatherpf0dps vgatherpf0qpd vgatherpf0qps vgatherpf1dpd vgatherpf1dps vgatherpf1qpd vgatherpf1qps vscatterpf0dpd vscatterpf0dps vscatterpf0qpd vscatterpf0qps vscatterpf1dpd vscatterpf1dps vscatterpf1qpd vscatterpf1qps prefetchwt1 bndmk bndcl bndcu bndcn bndmov bndldx bndstx sha1rnds4 sha1nexte sha1msg1 sha1msg2 sha256rnds2 sha256msg1 sha256msg2 hint_nop0 hint_nop1 hint_nop2 hint_nop3 hint_nop4 hint_nop5 hint_nop6 hint_nop7 hint_nop8 hint_nop9 hint_nop10 hint_nop11 hint_nop12 hint_nop13 hint_nop14 hint_nop15 hint_nop16 hint_nop17 hint_nop18 hint_nop19 hint_nop20 hint_nop21 hint_nop22 hint_nop23 hint_nop24 hint_nop25 hint_nop26 hint_nop27 hint_nop28 hint_nop29 hint_nop30 hint_nop31 hint_nop32 hint_nop33 hint_nop34 hint_nop35 hint_nop36 hint_nop37 hint_nop38 hint_nop39 hint_nop40 hint_nop41 hint_nop42 hint_nop43 hint_nop44 hint_nop45 hint_nop46 hint_nop47 hint_nop48 hint_nop49 hint_nop50 hint_nop51 hint_nop52 hint_nop53 hint_nop54 hint_nop55 hint_nop56 hint_nop57 hint_nop58 hint_nop59 hint_nop60 hint_nop61 hint_nop62 hint_nop63", built_in: "ip eip rip al ah bl bh cl ch dl dh sil dil bpl spl r8b r9b r10b r11b r12b r13b r14b r15b ax bx cx dx si di bp sp r8w r9w r10w r11w r12w r13w r14w r15w eax ebx ecx edx esi edi ebp esp eip r8d r9d r10d r11d r12d r13d r14d r15d rax rbx rcx rdx rsi rdi rbp rsp r8 r9 r10 r11 r12 r13 r14 r15 cs ds es fs gs ss st st0 st1 st2 st3 st4 st5 st6 st7 mm0 mm1 mm2 mm3 mm4 mm5 mm6 mm7 xmm0 xmm1 xmm2 xmm3 xmm4 xmm5 xmm6 xmm7 xmm8 xmm9 xmm10 xmm11 xmm12 xmm13 xmm14 xmm15 xmm16 xmm17 xmm18 xmm19 xmm20 xmm21 xmm22 xmm23 xmm24 xmm25 xmm26 xmm27 xmm28 xmm29 xmm30 xmm31 ymm0 ymm1 ymm2 ymm3 ymm4 ymm5 ymm6 ymm7 ymm8 ymm9 ymm10 ymm11 ymm12 ymm13 ymm14 ymm15 ymm16 ymm17 ymm18 ymm19 ymm20 ymm21 ymm22 ymm23 ymm24 ymm25 ymm26 ymm27 ymm28 ymm29 ymm30 ymm31 zmm0 zmm1 zmm2 zmm3 zmm4 zmm5 zmm6 zmm7 zmm8 zmm9 zmm10 zmm11 zmm12 zmm13 zmm14 zmm15 zmm16 zmm17 zmm18 zmm19 zmm20 zmm21 zmm22 zmm23 zmm24 zmm25 zmm26 zmm27 zmm28 zmm29 zmm30 zmm31 k0 k1 k2 k3 k4 k5 k6 k7 bnd0 bnd1 bnd2 bnd3 cr0 cr1 cr2 cr3 cr4 cr8 dr0 dr1 dr2 dr3 dr8 tr3 tr4 tr5 tr6 tr7 r0 r1 r2 r3 r4 r5 r6 r7 r0b r1b r2b r3b r4b r5b r6b r7b r0w r1w r2w r3w r4w r5w r6w r7w r0d r1d r2d r3d r4d r5d r6d r7d r0h r1h r2h r3h r0l r1l r2l r3l r4l r5l r6l r7l r8l r9l r10l r11l r12l r13l r14l r15l db dw dd dq dt ddq do dy dz resb resw resd resq rest resdq reso resy resz incbin equ times byte word dword qword nosplit rel abs seg wrt strict near far a32 ptr", meta: "%define %xdefine %+ %undef %defstr %deftok %assign %strcat %strlen %substr %rotate %elif %else %endif %if %ifmacro %ifctx %ifidn %ifidni %ifid %ifnum %ifstr %iftoken %ifempty %ifenv %error %warning %fatal %rep %endrep %include %push %pop %repl %pathsearch %depend %use %arg %stacksize %local %line %comment %endcomment .nolist __FILE__ __LINE__ __SECT__ __BITS__ __OUTPUT_FORMAT__ __DATE__ __TIME__ __DATE_NUM__ __TIME_NUM__ __UTC_DATE__ __UTC_TIME__ __UTC_DATE_NUM__ __UTC_TIME_NUM__ __PASS__ struc endstruc istruc at iend align alignb sectalign daz nodaz up down zero default option assume public bits use16 use32 use64 default section segment absolute extern global common cpu float __utf16__ __utf16le__ __utf16be__ __utf32__ __utf32le__ __utf32be__ __float8__ __float16__ __float32__ __float64__ __float80m__ __float80e__ __float128l__ __float128h__ __Infinity__ __QNaN__ __SNaN__ Inf NaN QNaN SNaN float8 float16 float32 float64 float80m float80e float128l float128h __FLOAT_DAZ__ __FLOAT_ROUND__ __FLOAT__" }, contains: [s.COMMENT(";", "$", { relevance: 0 }), { className: "number", variants: [{ begin: "\\b(?:([0-9][0-9_]*)?\\.[0-9_]*(?:[eE][+-]?[0-9_]+)?|(0[Xx])?[0-9][0-9_]*\\.?[0-9_]*(?:[pP](?:[+-]?[0-9_]+)?)?)\\b", relevance: 0 }, { begin: "\\$[0-9][0-9A-Fa-f]*", relevance: 0 }, { begin: "\\b(?:[0-9A-Fa-f][0-9A-Fa-f_]*[Hh]|[0-9][0-9_]*[DdTt]?|[0-7][0-7_]*[QqOo]|[0-1][0-1_]*[BbYy])\\b" }, { begin: "\\b(?:0[Xx][0-9A-Fa-f_]+|0[DdTt][0-9_]+|0[QqOo][0-7_]+|0[BbYy][0-1_]+)\\b" }] }, s.QUOTE_STRING_MODE, { className: "string", variants: [{ begin: "'", end: "[^\\\\]'" }, { begin: "`", end: "[^\\\\]`" }], relevance: 0 }, { className: "symbol", variants: [{ begin: "^\\s*[A-Za-z._?][A-Za-z0-9_$#@~.?]*(:|\\s+label)" }, { begin: "^\\s*%%[A-Za-z0-9_$#@~.?]*:" }], relevance: 0 }, { className: "subst", begin: "%[0-9]+", relevance: 0 }, { className: "subst", begin: "%!S+", relevance: 0 }, { className: "meta", begin: /^\s*\.[\w_-]+/ }] } } }()); -hljs.registerLanguage("muse", function () { +hljs.registerLanguage("muselang", function () { return { name: "Muse", case_insensitive: false, // language is case-insensitive