puppet top-level property
Implementation
final puppet = Mode(refs: {
'~contains~2': Mode(
className: "string",
contains: [BACKSLASH_ESCAPE, Mode(ref: '~contains~1')],
variants: [Mode(begin: "'", end: "'"), Mode(begin: "\"", end: "\"")]),
'~contains~1':
Mode(className: "variable", begin: "\\\$([A-Za-z_]|::)(\\w|::)*"),
'~contains~0': Mode(className: "comment", begin: "#", end: "\$", contains: [
PHRASAL_WORDS_MODE,
Mode(
className: "doctag",
begin: "(?:TODO|FIXME|NOTE|BUG|XXX):",
relevance: 0)
]),
}, aliases: [
"pp"
], contains: [
Mode(ref: '~contains~0'),
Mode(ref: '~contains~1'),
Mode(ref: '~contains~2'),
Mode(beginKeywords: "class", end: "\\{|;", illegal: "=", contains: [
Mode(className: "title", begin: "([A-Za-z_]|::)(\\w|::)*", relevance: 0),
Mode(ref: '~contains~0')
]),
Mode(beginKeywords: "define", end: "\\{", contains: [
Mode(className: "section", begin: "[a-zA-Z]\\w*", endsParent: true)
]),
Mode(
begin: "[a-zA-Z]\\w*\\s+\\{",
returnBegin: true,
end: "\\S",
contains: [
Mode(className: "keyword", begin: "[a-zA-Z]\\w*"),
Mode(
begin: "\\{",
end: "\\}",
keywords: {
"keyword":
"and case default else elsif false if in import enherits node or true undef unless main settings \$string ",
"literal":
"alias audit before loglevel noop require subscribe tag owner ensure group mode name|0 changes context force incl lens load_path onlyif provider returns root show_diff type_check en_address ip_address realname command environment hour monute month monthday special target weekday creates cwd ogoutput refresh refreshonly tries try_sleep umask backup checksum content ctime force ignore links mtime purge recurse recurselimit replace selinux_ignore_defaults selrange selrole seltype seluser source souirce_permissions sourceselect validate_cmd validate_replacement allowdupe attribute_membership auth_membership forcelocal gid ia_load_module members system host_aliases ip allowed_trunk_vlans description device_url duplex encapsulation etherchannel native_vlan speed principals allow_root auth_class auth_type authenticate_user k_of_n mechanisms rule session_owner shared options device fstype enable hasrestart directory present absent link atboot blockdevice device dump pass remounts poller_tag use message withpath adminfile allow_virtual allowcdrom category configfiles flavor install_options instance package_settings platform responsefile status uninstall_options vendor unless_system_user unless_uid binary control flags hasstatus manifest pattern restart running start stop allowdupe auths expiry gid groups home iterations key_membership keys managehome membership password password_max_age password_min_age profile_membership profiles project purge_ssh_keys role_membership roles salt shell uid baseurl cost descr enabled enablegroups exclude failovermethod gpgcheck gpgkey http_caching include includepkgs keepalive metadata_expire metalink mirrorlist priority protect proxy proxy_password proxy_username repo_gpgcheck s3_enabled skip_if_unavailable sslcacert sslclientcert sslclientkey sslverify mounted",
"built_in":
"architecture augeasversion blockdevices boardmanufacturer boardproductname boardserialnumber cfkey dhcp_servers domain ec2_ ec2_userdata facterversion filesystems ldom fqdn gid hardwareisa hardwaremodel hostname id|0 interfaces ipaddress ipaddress_ ipaddress6 ipaddress6_ iphostnumber is_virtual kernel kernelmajversion kernelrelease kernelversion kernelrelease kernelversion lsbdistcodename lsbdistdescription lsbdistid lsbdistrelease lsbmajdistrelease lsbminordistrelease lsbrelease macaddress macaddress_ macosx_buildversion macosx_productname macosx_productversion macosx_productverson_major macosx_productversion_minor manufacturer memoryfree memorysize netmask metmask_ network_ operatingsystem operatingsystemmajrelease operatingsystemrelease osfamily partitions path physicalprocessorcount processor processorcount productname ps puppetversion rubysitedir rubyversion selinux selinux_config_mode selinux_config_policy selinux_current_mode selinux_current_mode selinux_enforced selinux_policyversion serialnumber sp_ sshdsakey sshecdsakey sshrsakey swapencrypted swapfree swapsize timezone type uniqueid uptime uptime_days uptime_hours uptime_seconds uuid virtual vlans xendomains zfs_version zonenae zones zpool_version"
},
relevance: 0,
contains: [
Mode(ref: '~contains~2'),
Mode(ref: '~contains~0'),
Mode(
begin: "[a-zA-Z_]+\\s*=>",
returnBegin: true,
end: "=>",
contains: [Mode(className: "attr", begin: "[a-zA-Z]\\w*")]),
Mode(
className: "number",
begin:
"(\\b0[0-7_]+)|(\\b0x[0-9a-fA-F_]+)|(\\b[1-9][0-9_]*(\\.[0-9_]+)?)|[0_]\\b",
relevance: 0),
Mode(ref: '~contains~1')
])
],
relevance: 0)
]);