Merge pull request #127 from Sei-Lisa/sei-add-versions
Add version code to most scripts
This commit is contained in:
commit
f6f6fb533a
20 changed files with 121 additions and 24 deletions
|
@ -28,6 +28,9 @@ OSZIP=AVsitter2-oss.zip
|
|||
# End of configuration area
|
||||
|
||||
|
||||
# Version being compiled (LSL string)
|
||||
VERSION="2.2p04"
|
||||
|
||||
|
||||
# Note some of these scripts don't strictly need to be optimized for memory.
|
||||
|
||||
|
@ -101,4 +104,10 @@ $(OSZIP): $(OPENSIM)
|
|||
%.oss: %.lsl
|
||||
$(PYTHON) build-aux.py oss-process $< > $@
|
||||
|
||||
.PHONY : all clean optimized opensim
|
||||
# Bash only, probably GNU make only
|
||||
setvars:
|
||||
for name in $(addprefix ',$(addsuffix ',$(OPTIMIZED:.lslo=.lsl))) $(addprefix ',$(addsuffix ',$(UNOPTIMIZED))); do $(PYTHON) build-aux.py setvars "$$name" version='$(VERSION)' ; done
|
||||
|
||||
release: setvars all
|
||||
|
||||
.PHONY : all clean optimized opensim setvars release
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
* instructions can be found at http://avsitter.github.io
|
||||
*/
|
||||
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string notecard_name = "AVpos";
|
||||
string main_script = "[AV]sitA";
|
||||
key notecard_key;
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
// Placed in prop objects, this script sends the uuid of any Lockguard rings to the script in furniture.
|
||||
// Ring prims in the prop should be named with "ring" in their prim name. e.g. "ring1", "ring2"
|
||||
|
||||
// string #version = "2.2p04";
|
||||
integer COMM_CHANNEL = -57841689;
|
||||
integer comm_handle;
|
||||
list A = [comm_handle]; //OSS::list A; // Force error if not compiled in Mono
|
||||
|
|
|
@ -13,10 +13,10 @@
|
|||
* receive automatic updates and other benefits! All details and user
|
||||
* instructions can be found at http://avsitter.github.io
|
||||
*/
|
||||
|
||||
// For use attaching particle chains to LockGuard V2 compatible cuffs such as Open Collar
|
||||
// This script should be placed inside the prim that contains your poses and props.
|
||||
// Inspiration and function (not code) from the Bright CISS system by Shan Bright & Innula Zenovka.
|
||||
// string #version = "2.2p04";
|
||||
|
||||
// SITTER:
|
||||
// The AVsitter SITTER # the chain settings are for.
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product;
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
integer RELAY_CHANNEL = -1812221819;
|
||||
integer RELAY_GETSTATUS_CHANNEL;
|
||||
integer GETSTATUShandle;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™ RLV";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
integer ignorenextswap;
|
||||
string notecard_name = "AVpos";
|
||||
string unDressScript = "[AV]root-RLV-extra";
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™ Menu Control";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string security_script = "[AV]root-security";
|
||||
string RLV_script = "[AV]root-RLV";
|
||||
list DESIGNATIONS_NOW;
|
||||
|
|
|
@ -43,7 +43,7 @@ integer IsInteger(string data)
|
|||
return data != "" && (string)((integer)("1" + data)) == "1" + data;
|
||||
}
|
||||
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string notecard_name = "AVpos";
|
||||
string main_script = "[AV]sitA";
|
||||
key key_request;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVmenu™";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
integer verbose = 0;
|
||||
string prop_script = "[AV]prop";
|
||||
string notecard_name = "AVpos";
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
* instructions can be found at http://avsitter.github.io
|
||||
*/
|
||||
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string notecard_name = "AVpos";
|
||||
string main_script = "[AV]sitA";
|
||||
key key_request;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™ sequence";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string main_script = "[AV]sitA";
|
||||
list SITTERS;
|
||||
integer DEBUG;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter2 MLP converter";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string notecard_basename = "AVpos";
|
||||
string notecard_name;
|
||||
list NOTECARDS = [notecard_name]; //OSS::list NOTECARDS; // Force error in LSO
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
integer OLD_HELPER_METHOD;
|
||||
key key_request;
|
||||
string url = "https://avsitter.com/settings.php"; // the settings dump service remains up for AVsitter customers. settings clear periodically.
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string helper_name = "[AV]helper";
|
||||
string prop_script = "[AV]prop";
|
||||
string expression_script = "[AV]faces";
|
||||
|
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
string registration_product = "AVsitter2";
|
||||
string product = "AVhelper";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
integer OLD_HELPER_METHOD;
|
||||
list colors = [<1,0.5,1>, <0.5,0.5,1>, <1,0.5,0.5>, <0.5,1,0.5>, <1,1,0.5>, <0.5,1,1>];
|
||||
integer helper_index;
|
||||
|
|
|
@ -14,7 +14,8 @@
|
|||
* instructions can be found at http://avsitter.github.io
|
||||
*/
|
||||
|
||||
string product = "AVsitter™ Security 2.2";
|
||||
string product = "AVsitter™ Security";
|
||||
string #version = "2.2p04";
|
||||
string script_basename = "[AV]sitA";
|
||||
string menucontrol_script = "[AV]root-control";
|
||||
string RLV_script = "[AV]root-RLV";
|
||||
|
@ -60,7 +61,7 @@ check_sitters()
|
|||
if (pass_security(av, "SIT") == FALSE)
|
||||
{
|
||||
llUnSit(av);
|
||||
llDialog(av, product + "\n\nSorry, Sit access is set to: " + llList2String(SIT_TYPES, SIT_INDEX), ["OK"], -164289491);
|
||||
llDialog(av, product + " " + version + "\n\nSorry, Sit access is set to: " + llList2String(SIT_TYPES, SIT_INDEX), ["OK"], -164289491);
|
||||
}
|
||||
i--;
|
||||
}
|
||||
|
@ -98,7 +99,7 @@ register_touch(key id, integer animation_menu_function, integer active_prim, int
|
|||
}
|
||||
else if (giveFailedMessage)
|
||||
{
|
||||
llDialog(id, product + "\n\nSorry, Menu access is set to: " + llList2String(MENU_TYPES, MENU_INDEX), ["OK"], -164289491);
|
||||
llDialog(id, product + " " + version + "\n\nSorry, Menu access is set to: " + llList2String(MENU_TYPES, MENU_INDEX), ["OK"], -164289491);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -117,7 +118,7 @@ dialog(string text, list menu_items)
|
|||
{
|
||||
llListenRemove(menu_handle);
|
||||
menu_handle = llListen((menu_channel = ((integer)llFrand(0x7FFFFF80) + 1) * -1), "", llGetOwner(), ""); // 7FFFFF80 = max float < 2^31
|
||||
llDialog(llGetOwner(), product + "\n\n" + text, order_buttons(menu_items), menu_channel);
|
||||
llDialog(llGetOwner(), product + " " + version + "\n\n" + text, order_buttons(menu_items), menu_channel);
|
||||
llSetTimerEvent(600);
|
||||
}
|
||||
|
||||
|
|
|
@ -13,7 +13,7 @@
|
|||
* receive automatic updates and other benefits! All details and user
|
||||
* instructions can be found at http://avsitter.github.io
|
||||
*/
|
||||
|
||||
//string #version = "2.2p04";
|
||||
string script_basename = "[AV]sitA";
|
||||
string menu_script = "[AV]menu";
|
||||
key A;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™ seat select";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
integer select_type;
|
||||
list BUTTONS;
|
||||
integer reading_notecard_section = -1;
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string notecard_name = "AVpos";
|
||||
string main_script = "[AV]sitA";
|
||||
string memoryscript = "[AV]sitB";
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
*/
|
||||
|
||||
string product = "AVsitter™";
|
||||
string version = "2.2";
|
||||
string #version = "2.2p04";
|
||||
string BRAND;
|
||||
integer OLD_HELPER_METHOD;
|
||||
string main_script = "[AV]sitA";
|
||||
|
|
|
@ -13,6 +13,9 @@ python build-aux.py <command> [<args>]
|
|||
|
||||
Where command can be:
|
||||
|
||||
setvars <file> <var>=<value> ...:
|
||||
Preprocesses the given file in place, to replace values like
|
||||
version and others.
|
||||
oss-process <file>:
|
||||
Processes the given file for OpenSim and outputs the result to
|
||||
standard output. If <file> is not given, read from standard input.
|
||||
|
@ -44,8 +47,12 @@ def oss_process(filename):
|
|||
# Regex that removes /*OSS:: and its matching */ (can't begin on first line)
|
||||
os_block_re = re.compile(r'\n\s*/\* ?OSS::[^\n]*(\n(?:[^\n]|\n(?![ \t]*\*/))*)\n[ \t]*\*/[^\n]*(?=\n)')
|
||||
|
||||
# Regex that reads a token, can be a string or comment or #IDENT or anything else,
|
||||
# capturing a group for IDENT when #IDENT is found.
|
||||
token_re = re.compile(r'"(?:\\.|[^"\\]+)*"|/\*[\S\s]*?\*/|//[^\n]*|/|[^#/"]+|#([a-zA-Z_][a-zA-Z0-9_]*)|#')
|
||||
|
||||
if filename is not None:
|
||||
f = open(filename, "r");
|
||||
f = open(filename, "r")
|
||||
else:
|
||||
f = sys.stdin
|
||||
try:
|
||||
|
@ -59,7 +66,6 @@ def oss_process(filename):
|
|||
'206fcbe2-47b3-41e8-98e6-8909595b8605')
|
||||
s = s.replace('b30c9262-9abf-4cd1-9476-adcf5723c029',
|
||||
'b88526b7-3966-43fd-ae76-1e39881c86aa')
|
||||
# TODO: Replace LockGuard texture UUIDs
|
||||
|
||||
# OpenSim 0.8.0 does not support this constant.
|
||||
#s = s.replace('OBJECT_BODY_SHAPE_TYPE', '26 /*OBJECT_BODY_SHAPE_TYPE*/')
|
||||
|
@ -70,9 +76,87 @@ def oss_process(filename):
|
|||
s = os_line_re.sub(r'\1\2', s)
|
||||
s = sl_block_re.sub('', s)
|
||||
s = os_block_re.sub(r'\1', s)
|
||||
|
||||
new = ''
|
||||
for match in token_re.finditer(s):
|
||||
if match.group(1):
|
||||
new += match.group(1) # remove '#'
|
||||
else:
|
||||
new += match.group(0)
|
||||
s = new
|
||||
|
||||
sys.stdout.write(s)
|
||||
return 0
|
||||
|
||||
def setvars(filename, *settings):
|
||||
"""Preprocess a file in place, to replace values"""
|
||||
import re
|
||||
|
||||
values = {}
|
||||
var_value_re = re.compile(r'^([^=]*)=(.*)$')
|
||||
for v in settings:
|
||||
match = var_value_re.search(v)
|
||||
if not match:
|
||||
sys.stderr.write('Incorrect setting format, it should be key=value\n')
|
||||
return 1
|
||||
values[match.group(1)] = match.group(2)
|
||||
|
||||
#sys.stderr.write(filename + '\n')
|
||||
if filename is not None:
|
||||
f = open(filename, "r")
|
||||
else:
|
||||
f = sys.stdin
|
||||
try:
|
||||
s = f.read()
|
||||
finally:
|
||||
if filename is not None:
|
||||
f.close()
|
||||
|
||||
orig = s
|
||||
# Regex to read a token in the set of expected tokens.
|
||||
# NOTE: This regex deliberately ignores // so that //#variable = value; is still valid.
|
||||
token_re = re.compile(r'"(?:\\.|[^"\\]+)*"|/\*[\S\s]*?\*/|/|;|[^#;/"]+|#([a-zA-Z_][a-zA-Z0-9_]*)\s*=\s*|#')
|
||||
p = 0
|
||||
while True:
|
||||
match = token_re.search(s, p)
|
||||
if not match:
|
||||
break
|
||||
if match.group(1) in values:
|
||||
# found '#variable = ' in the code, and variable matches
|
||||
value = values[match.group(1)]
|
||||
# mark the start of the value as the end of the match
|
||||
vbegin = match.end(0)
|
||||
while True:
|
||||
# keep skipping tokens until we hit a ';'
|
||||
p = match.end(0)
|
||||
match = token_re.search(s, p)
|
||||
if not match:
|
||||
# end of script? this is wrong but better don't crash
|
||||
vend = vbegin
|
||||
break
|
||||
if match.group(0) == ';':
|
||||
# mark end of value before the matching ';'
|
||||
vend = match.start(0)
|
||||
break
|
||||
# Replace the value between vbegin and vend
|
||||
s = s[:vbegin] + value + s[vend:]
|
||||
# Advance past the value to keep searching
|
||||
p = vbegin + len(value)
|
||||
continue
|
||||
# not a token we're interested in - keep searching after it
|
||||
p = match.end(0)
|
||||
|
||||
if s != orig:
|
||||
if filename is not None:
|
||||
f = open(filename, "w")
|
||||
else:
|
||||
f = sys.stdout
|
||||
try:
|
||||
f.write(s)
|
||||
finally:
|
||||
if filename is not None:
|
||||
f.close()
|
||||
|
||||
def main(argc, argv):
|
||||
if argc < 2:
|
||||
usage()
|
||||
|
@ -82,6 +166,9 @@ def main(argc, argv):
|
|||
if cmd == 'rm':
|
||||
return rm(argv[2:])
|
||||
|
||||
if cmd == 'setvars':
|
||||
return setvars(argv[2], *argv[3:])
|
||||
|
||||
if cmd == 'oss-process':
|
||||
if argc > 3:
|
||||
usage()
|
||||
|
|
Loading…
Reference in a new issue