I have several things such as the height and hair color that the player can set about the PC from a pre-defined list. Those lists use a basic setup. They are a link that replaces an above span with a phrase describing what they've picked. Basically it's getting to the point of being somewhat hard to figure out what I'm looking at, and I'd like to make all that into a widget. I believe the following should mostly work.
<<widget "pcConfigLink">><<link $args[0]>><<set $playerCharacter.$args[1] = $args[2]>><<replace ".pc"+$args[1]>><<pc+$args[1]>><</replace>><</link>><</widget>><<widget "pcConfigLink">><<link $args[0]>><<set $playerCharacter.$args[1] = $args[2]>><<replace ".pc"+$args[1]>><<pc+$args[1]>><</replace>><</link>><</widget>>
I would be able to call it for example with:
<<pcConfigLink "Towering" Height 4>>
However it's not liking $playerCharacter.$args[1] for some reason. Any suggestion on how to get this working?
Comments
You're attempting to use dot notation, which is only for specific property access using an identifier. You need to use square bracket notation. For example:
Beyond that, you cannot generally pass an expression in an argument slot as you're attempting to with <<replace>>. If you need to use an expression in an argument slot, you'll have to use the backtick expression syntax. For example: Note: Posting from my phone, hopefully the backticks come through.
Also, I'm unsure what you're attempting to do with the following: It's probably not going to do whatever it is you're hoping it will.
Basically I'm trying to replace the upper bit of code with a widget. (I also have things like Height, Race, etc.) In an attempt to make it a bit more readable.
I've rewritten the link thing to (and it still fails, but not as terribly): The replace works, but the widget call does not. To test, I added this to end of the HairType list:
The syntax of your example allows us to guess that you are using one of the SugarCube series (1.x or 2.x) but without knowing the exact version of the story format (or of the Twine 2 application) we can't know what features are available to you (and to us) to use in a solution.
warning: The Twine 2 application does not automatically keep you up to date with the latest releases of SugarCube (1.x or 2.x) or any other story format. That is either left up to you to do yourself manually via the "Add Story Format" option, or it may happen when you install/use a newer release/version of the Twine 2 application.
Why not something array-based, like this:
I think this is a better way to accomplish what I think you're trying to do:
1. You can increase the number of options just by adding a value to the array--no other code needs rewritten.
2. All the code is right there in the passage.
3. No unnecessary macro/widget calls.
4. It's much shorter, more readable, and easier to debug.
5. You could pretty easily turn the above code into a widget for reuse, and you wouldn't have to hard code individual widgets for each player attribute.
Here's an example of how it might work as a widget:
Note: you should try spacing and indenting your code to make it more readable.
I think I understand what you're trying to do. What I don't understand is why you're trying to trick the parser into turning the variable into a widget call and why you're trying to use three different macro calls to accomplish the same thing a variable does. There are better solutions.
If you don't like the array method, I'm not gonna evangelize for it. I do wish that you had at least tested the widget or code I provided so you could see what it does.
If you're committed to trying to force the issue, you could just trick the parser using <<print>>:
Keep in mind, if you need trick the parser, then you need to write better code 99% of the time. Your case is not an exception to this rule.
I'm open to better solutions, and I did read your code to see what it did, it's not a bad solution, more what you provided is the opposite of what I'm trying to accomplish. For the most part I'm just going to use something like: It's specifically in the few places where I'm letting the player choose from the list of everything that I'm trying to be a bit too fancy. The main reason I'm not including the whole code is that it's an adult game, and I'm not sure whether that's allowable to be linked on this forum.
The reason I am trying to basically wrap the link/replace code in a widget is to make it a bit easier to read. I'd rather not trick the parser, if it doesn't work how I want it to, then I have to rethink what I'm trying to do.
You have two possible solutions, other than doing something else completely, either use what's known as the Stupid Print Trick™, which has already been presented to you, or use an intermediate routing widget.
Personally, while I generally advise against use of the Stupid Print Trick™ whenever possible, your case is simple enough that I'd just go with it. For example: Beyond that, if the element you're replacing the contents of will be unique—probably the case here—then use an ID instead of a class.
I don't get why you want the widgets to return the strings instead of a variable. It's a more difficult, more taxing, less flexible way of doing thing.
What I was thinking was something like this--you still only ever need to write the player's options once. You don't have to mess around with numbers and save those to the $playerCharacter properties. You don't have to trick the parser, and you don't have to right tons of code.
Of course, none of it matters if I'm missing the point, which I very well might be. I attached a demo so you can see what I mean without having to copy/paste it all over. Note that I missed a dollar sign at the end of it, and it didn't save right, so the 'next' passage is has an error.
The important thing is that you got it working how you want. I think I just somehow missed the whole point of this, so that's on me, sorry for adding more confusion to everything.