Difference between revisions of "Talk:Useful Scripts"

From the Fallout3 GECK Wiki
Jump to navigation Jump to search
imported>Illyism
(added example script for FOSE)
imported>Cipscis
m (→‎Iterating through multiple lists: Fixing markup for an internal link)
 
(10 intermediate revisions by 6 users not shown)
Line 1: Line 1:
==FOSE Scripts==
Should we include [[Fallout Script Extender|FOSE]] scripts? --[[User:Illyism|Illyism]] 14:23, 24 February 2009 (UTC)
Should we include [[Fallout Script Extender|FOSE]] scripts? --[[User:Illyism|Illyism]] 14:23, 24 February 2009 (UTC)
:So long as it's made clear that the script requires FOSE, I don't see any problem with using them here.  Looking at the script below, I think that changing the GMSTs while in MenuMode 1057 could potentially cause problems.  Specifically, if a scripted terminal is placed near enough to a regular terminal that its script will be running while the regular terminal is Activated, the GMSTs will still be changed.<br />Perhaps a triggerbox could be used instead, so that the GMSTs are changed to and from their default values in [[OnTriggerEnter]] and [[OnTriggerLeave]] blocks.<br />Once FOSE makes string variables available, this script should be updated to store the original values and restore them, otherwise it will overwrite any other changes that have been made to the relevant GMSTs.<br />-- [[User:Cipscis|Cipscis]] 21:04, 24 February 2009 (UTC)


==Example==
==License?==  
Script requires [[Fallout Script Extender|FOSE]].
I see that only one script notes the license and in that case it is attribution.  For the others should the same be done?  I wonder, does this GECK wiki have an license notes attached to submissions? As in does this wiki release all contributions under some license.  


To be placed on a terminal, it changes the usual "Robco" headers to your liking.
Ah I see I was right, from the Geck: General disclaimer:
<pre>
"You are being granted a limited license to copy anything from this site for non-commercial purposes"
ScriptName TerminalChange
[[User:Warll|Warll]] 04:09, 21 July 2009 (UTC)


Short toggle
:All scripts should be clear of any credits, including the script you mentioned. I noted it at the CS Wiki, where Skingrad posted the same script. We're waiting for him to remove the credit-line.
Float minitimer
:--[[User:Qazaaq|Qazaaq]] 21:50, 21 July 2009 (UTC)


Begin OnActivate
:: Removed the lines also here, but I have a question is this rule just for this wiki, if I remember well in other sites based on wikia there are or were pages with the name of the author [[User:Skingrad24|Skingrad24]] 22:03, 21 July 2009 (UTC)
  Activate ;For people without FOSE.
  con_setgamesetting sComputersHeader1 "GREAT ACADEMY OF VALHALLA"
  con_setgamesetting sComputersHeader2 "Republic of Valhalla"
  con_setgamesetting sHackingHeader "VALHALLA REPUBLIC TERMLINK PROTOCOL"
  con_setgamesetting shackingintro01 "WELCOME TO VALHALLA REPUBLIC TERMLINK"
  con_setgamesetting shackingintro06 "Initializing Valhalla Republic MF Boot Agent v2.1.9"
  con_setgamesetting shackingintro09 "Copyright 2156-2234 Academy of Valhalla"
end


begin gamemode
:::This is a rule specifically for the GECK and the CS Wiki, which are both hosted by Bethesda. The Wikia, which is a fan-created website, has its own rules (I don't know anything about them).
  ;On shutting down the terminal. Makes sure it doesn't show up on others.
:::But even if those lines aren't removed there, it may still not be allowed. The rules weren't enforced on the CS Wiki for a while, which resulted in many pages that still contain an author's signature. At the time it wasn't clear that signing articles was against the rules. The same thing may be going on at the Wikia.
  con_setgamesetting sComputersHeader1 "ROBCO INDUSTRIES UNIFIED OPERATING SYSTEM"
:::Thank you for removing the line and for the scripts.
  con_setgamesetting sComputersHeader2 "COPYRIGHT 2075-2077 ROBCO INDUSTRIES "
:::--[[User:Qazaaq|Qazaaq]] 23:27, 21 July 2009 (UTC)
  con_setgamesetting sHackingHeader "ROBCO INDUSTRIES (TM) TERMLINK PROTOCOL"
  con_setgamesetting shackingintro01 "WELCOME TO ROBCO INDUSTRIES (TM) TERMLINK"
  con_setgamesetting shackingintro06 "Initializing Robco Industries(TM) MF Boot Agent v2.3.0"
  con_setgamesetting shackingintro09 "Copyright 2201-2203 Robco Ind."
end


;Double-check
==Category==
begin menumode 1057
  ;1057 = Terminal
  Con_SetGameSetting sComputersHeader1 "GREAT ACADEMY OF VALHALLA OPERATING SYSTEM"
  con_SetGameSetting sComputersHeader2 "Republic of Valhalla"
  con_SetGameSetting sHackingHeader "VALHALLA REPUBLIC TERMLINK PROTOCOL"
  con_SetGameSetting sHackingIntro01 "WELCOME TO VALHALLA REPUBLIC TERMLINK"
  con_SetGameSetting sHackingIntro06 "Initializing Valhalla Republic MF Boot Agent v2.1.9"
  Con_SetGameSetting SHackingIntro09 "Copyright 2156-2234 Academy of Valhalla"
end


Why are all the scripts placed in only one article? In the CS Wiki there is a category called useful code. There's also one on this Wiki. Can someone consider giving each script its own regular Wiki page and place them in the '''Category:Useful Code'''?
[[User:Darkness X|Darkness X]] 11:21, 21 October 2009 (UTC)


</pre>
== Iterating through multiple lists ==
 
I've a couple of comments about the recently added script, [[Useful_Scripts#Iterating_through_multiple_lists| Iterating through multiple lists]].
 
First, I'm a little confused as to why variables are being used for [[Label]] and [[Goto]]. It is certainly not a requirement to use variables for label IDs. I would recommend just "hard coding" a number to use as each label's ID. For example, instead of:
Label Label1
; ...
Goto Label1
I'd recommend using:
Label 10
; ...
Goto 10
(I tend to use multiples of 10 in my initial write-ups of scripts, as this makes it easier to insert more loops later while maintaining a logical order of label IDs)
 
More importantly, because labels' IDs cannot be higher than 255 (I thought I remembered this information being available on this wiki, but upon checking it wasn't. I have added it now) this script will no longer work after about 256 iterations, as the label's IDs will be higher than the maximum value of 255.
 
I'd recommend using something closer to this, based on the template for ''for'' loops available on [http://cipscis.com/fallout/tutorials/loops.aspx| cipscis.com]:
<pre>ref rOuterList
ref rInnerList
ref rCurrentRef
 
int iOuterLength
int iInnerLength
 
int iOuterCount
int iInnerCount
 
set rOuterList to OuterList
set iOuterLength to ListGetCount rOuterList
 
set iOuterCount to 0
Label 10
if iOuterCount < iOuterLength
 
set rInnerList to ListGetNthForm rOuterList iOuterCount
set iInnerLength to ListGetCount rInnerList
set iInnerCount to 0
Label 20
if iInnerCount < iInnerLength
set rCurrentRef to ListGetNthForm rInnerList iInnerCount
 
; Do Something with rCurrentRef
 
set iInnerCount to iInnerCount + 1
Goto 20
endif
 
set iOuterCount to iOuterCount + 1
Goto 10
endif</pre>
 
Milo, please let me know if you have any comments or questions about what I've had to say. My aim is to help you improve your script, rather than replace it with my own.
- [[User:Cipscis|Cipscis]] 20:44, 30 March 2011 (UTC)

Latest revision as of 15:45, 30 March 2011

FOSE Scripts[edit source]

Should we include FOSE scripts? --Illyism 14:23, 24 February 2009 (UTC)

So long as it's made clear that the script requires FOSE, I don't see any problem with using them here. Looking at the script below, I think that changing the GMSTs while in MenuMode 1057 could potentially cause problems. Specifically, if a scripted terminal is placed near enough to a regular terminal that its script will be running while the regular terminal is Activated, the GMSTs will still be changed.
Perhaps a triggerbox could be used instead, so that the GMSTs are changed to and from their default values in OnTriggerEnter and OnTriggerLeave blocks.
Once FOSE makes string variables available, this script should be updated to store the original values and restore them, otherwise it will overwrite any other changes that have been made to the relevant GMSTs.
-- Cipscis 21:04, 24 February 2009 (UTC)

License?[edit source]

I see that only one script notes the license and in that case it is attribution. For the others should the same be done? I wonder, does this GECK wiki have an license notes attached to submissions? As in does this wiki release all contributions under some license.

Ah I see I was right, from the Geck: General disclaimer: "You are being granted a limited license to copy anything from this site for non-commercial purposes" Warll 04:09, 21 July 2009 (UTC)

All scripts should be clear of any credits, including the script you mentioned. I noted it at the CS Wiki, where Skingrad posted the same script. We're waiting for him to remove the credit-line.
--Qazaaq 21:50, 21 July 2009 (UTC)
Removed the lines also here, but I have a question is this rule just for this wiki, if I remember well in other sites based on wikia there are or were pages with the name of the author Skingrad24 22:03, 21 July 2009 (UTC)
This is a rule specifically for the GECK and the CS Wiki, which are both hosted by Bethesda. The Wikia, which is a fan-created website, has its own rules (I don't know anything about them).
But even if those lines aren't removed there, it may still not be allowed. The rules weren't enforced on the CS Wiki for a while, which resulted in many pages that still contain an author's signature. At the time it wasn't clear that signing articles was against the rules. The same thing may be going on at the Wikia.
Thank you for removing the line and for the scripts.
--Qazaaq 23:27, 21 July 2009 (UTC)

Category[edit source]

Why are all the scripts placed in only one article? In the CS Wiki there is a category called useful code. There's also one on this Wiki. Can someone consider giving each script its own regular Wiki page and place them in the Category:Useful Code? Darkness X 11:21, 21 October 2009 (UTC)

Iterating through multiple lists[edit source]

I've a couple of comments about the recently added script, Iterating through multiple lists.

First, I'm a little confused as to why variables are being used for Label and Goto. It is certainly not a requirement to use variables for label IDs. I would recommend just "hard coding" a number to use as each label's ID. For example, instead of:

Label Label1
; ...
Goto Label1

I'd recommend using:

Label 10
; ...
Goto 10

(I tend to use multiples of 10 in my initial write-ups of scripts, as this makes it easier to insert more loops later while maintaining a logical order of label IDs)

More importantly, because labels' IDs cannot be higher than 255 (I thought I remembered this information being available on this wiki, but upon checking it wasn't. I have added it now) this script will no longer work after about 256 iterations, as the label's IDs will be higher than the maximum value of 255.

I'd recommend using something closer to this, based on the template for for loops available on cipscis.com:

ref rOuterList
ref rInnerList
ref rCurrentRef

int iOuterLength
int iInnerLength

int iOuterCount
int iInnerCount

set rOuterList to OuterList
set iOuterLength to ListGetCount rOuterList

set iOuterCount to 0
Label 10
if iOuterCount < iOuterLength

	set rInnerList to ListGetNthForm rOuterList iOuterCount
	set iInnerLength to ListGetCount rInnerList
	set iInnerCount to 0
	Label 20
	if iInnerCount < iInnerLength
		set rCurrentRef to ListGetNthForm rInnerList iInnerCount

		; Do Something with rCurrentRef

		set iInnerCount to iInnerCount + 1
		Goto 20
	endif

	set iOuterCount to iOuterCount + 1
	Goto 10
endif

Milo, please let me know if you have any comments or questions about what I've had to say. My aim is to help you improve your script, rather than replace it with my own. - Cipscis 20:44, 30 March 2011 (UTC)