How do I debug pgfkeys?How to list all known pgfkeys?LaTeX3 versus pure LuaHow to best debug...

Mathematica command that allows it to read my intentions

What's the in-universe reasoning behind sorcerers needing material components?

ssTTsSTtRrriinInnnnNNNIiinngg

Arrow those variables!

GFCI outlets - can they be repaired? Are they really needed at the end of a circuit?

What does “the session was packed” mean in this context?

Would Slavery Reparations be considered Bills of Attainder and hence Illegal?

Examples of smooth manifolds admitting inbetween one and a continuum of complex structures

How do I gain back my faith in my PhD degree?

What method can I use to design a dungeon difficult enough that the PCs can't make it through without killing them?

Why is consensus so controversial in Britain?

How do I deal with an unproductive colleague in a small company?

Reverse dictionary where values are lists

Can a virus destroy the BIOS of a modern computer?

How to prevent "they're falling in love" trope

How do I handle a potential work/personal life conflict as the manager of one of my friends?

Assassin's bullet with mercury

Detention in 1997

Cursor Replacement for Newbies

Am I breaking OOP practice with this architecture?

Should I cover my bicycle overnight while bikepacking?

How can saying a song's name be a copyright violation?

Can I run a new neutral wire to repair a broken circuit?

What is the most common color to indicate the input-field is disabled?



How do I debug pgfkeys?


How to list all known pgfkeys?LaTeX3 versus pure LuaHow to best debug LaTeX?“Z-level” in TikZHow can I force TikZ pin angle?Checkers board in TikZ.How to change the level distance in tikz-qtree for one level only?How to know the status of a style? defined? empty?Accessing a style property in TikZ?How to best debug LaTeX?hyperref incorrect links: how to debug?pgfkeys - .is family handlerBack-linking of pgfkeyspgfkeys pass font commandRead other pgfkeys' valueHow to obtain enough debug information?Inheriting pgfkeysReset pgfkeys / Delete pgfkeysOrder dependent pgfkeys













32















I'm sure if you're reading this question you are already familiar with my love for pgfkeys. However, it is absolutely impossible to debug: tracingmacros is a total mess, with every key expanding to dozens of complex internal macros. I would like to be able to debug it the same way I can debug a program built by hand using def: watch the keys absorb their arguments, expand their values or execute their code, and proceed to the next key. I don't care how pgfk@try or whatever is defined, only that it looks for a key and does or doesn't find it, acting accordingly.



Currently, I debug by intimidation: tracingmacros=1 and lots of scrolling plus a bit of pattern recognition for the repetitive macro noise. It's too much to hope that there is some way of coercing pgfkeys into producing nicer output; it would require the author to have hand-coded a selectively populated call stack. I'm wondering, though, if anyone else familiar with this package could tell me how they figure out what's going on with their keys.



Related: How to best debug LaTeX? (by Yossi Farjoun; not coincidentally, this question is also really his, from a recent chat conversation.)










share|improve this question

























  • Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

    – Loop Space
    Nov 13 '11 at 19:02











  • @Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

    – Ryan Reich
    Nov 13 '11 at 19:10






  • 2





    Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

    – Loop Space
    Nov 26 '11 at 19:31











  • @Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

    – Ryan Reich
    Nov 26 '11 at 23:51











  • You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

    – Christian Feuersänger
    Feb 9 '12 at 17:29


















32















I'm sure if you're reading this question you are already familiar with my love for pgfkeys. However, it is absolutely impossible to debug: tracingmacros is a total mess, with every key expanding to dozens of complex internal macros. I would like to be able to debug it the same way I can debug a program built by hand using def: watch the keys absorb their arguments, expand their values or execute their code, and proceed to the next key. I don't care how pgfk@try or whatever is defined, only that it looks for a key and does or doesn't find it, acting accordingly.



Currently, I debug by intimidation: tracingmacros=1 and lots of scrolling plus a bit of pattern recognition for the repetitive macro noise. It's too much to hope that there is some way of coercing pgfkeys into producing nicer output; it would require the author to have hand-coded a selectively populated call stack. I'm wondering, though, if anyone else familiar with this package could tell me how they figure out what's going on with their keys.



Related: How to best debug LaTeX? (by Yossi Farjoun; not coincidentally, this question is also really his, from a recent chat conversation.)










share|improve this question

























  • Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

    – Loop Space
    Nov 13 '11 at 19:02











  • @Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

    – Ryan Reich
    Nov 13 '11 at 19:10






  • 2





    Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

    – Loop Space
    Nov 26 '11 at 19:31











  • @Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

    – Ryan Reich
    Nov 26 '11 at 23:51











  • You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

    – Christian Feuersänger
    Feb 9 '12 at 17:29
















32












32








32


8






I'm sure if you're reading this question you are already familiar with my love for pgfkeys. However, it is absolutely impossible to debug: tracingmacros is a total mess, with every key expanding to dozens of complex internal macros. I would like to be able to debug it the same way I can debug a program built by hand using def: watch the keys absorb their arguments, expand their values or execute their code, and proceed to the next key. I don't care how pgfk@try or whatever is defined, only that it looks for a key and does or doesn't find it, acting accordingly.



Currently, I debug by intimidation: tracingmacros=1 and lots of scrolling plus a bit of pattern recognition for the repetitive macro noise. It's too much to hope that there is some way of coercing pgfkeys into producing nicer output; it would require the author to have hand-coded a selectively populated call stack. I'm wondering, though, if anyone else familiar with this package could tell me how they figure out what's going on with their keys.



Related: How to best debug LaTeX? (by Yossi Farjoun; not coincidentally, this question is also really his, from a recent chat conversation.)










share|improve this question
















I'm sure if you're reading this question you are already familiar with my love for pgfkeys. However, it is absolutely impossible to debug: tracingmacros is a total mess, with every key expanding to dozens of complex internal macros. I would like to be able to debug it the same way I can debug a program built by hand using def: watch the keys absorb their arguments, expand their values or execute their code, and proceed to the next key. I don't care how pgfk@try or whatever is defined, only that it looks for a key and does or doesn't find it, acting accordingly.



Currently, I debug by intimidation: tracingmacros=1 and lots of scrolling plus a bit of pattern recognition for the repetitive macro noise. It's too much to hope that there is some way of coercing pgfkeys into producing nicer output; it would require the author to have hand-coded a selectively populated call stack. I'm wondering, though, if anyone else familiar with this package could tell me how they figure out what's going on with their keys.



Related: How to best debug LaTeX? (by Yossi Farjoun; not coincidentally, this question is also really his, from a recent chat conversation.)







macros debugging pgfkeys






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Apr 13 '17 at 12:35









Community

1




1










asked Nov 13 '11 at 18:42









Ryan ReichRyan Reich

31.5k7100160




31.5k7100160













  • Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

    – Loop Space
    Nov 13 '11 at 19:02











  • @Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

    – Ryan Reich
    Nov 13 '11 at 19:10






  • 2





    Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

    – Loop Space
    Nov 26 '11 at 19:31











  • @Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

    – Ryan Reich
    Nov 26 '11 at 23:51











  • You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

    – Christian Feuersänger
    Feb 9 '12 at 17:29





















  • Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

    – Loop Space
    Nov 13 '11 at 19:02











  • @Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

    – Ryan Reich
    Nov 13 '11 at 19:10






  • 2





    Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

    – Loop Space
    Nov 26 '11 at 19:31











  • @Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

    – Ryan Reich
    Nov 26 '11 at 23:51











  • You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

    – Christian Feuersänger
    Feb 9 '12 at 17:29



















Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

– Loop Space
Nov 13 '11 at 19:02





Do you mean something a bit more advanced than the .show value and so forth? You want to "watch it in action"?

– Loop Space
Nov 13 '11 at 19:02













@Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

– Ryan Reich
Nov 13 '11 at 19:10





@Andrew: Yes, exactly. Like if I defined defa#1{b#1} defb#1{c#1} defc#1{d#1} and called a{x}; tracingmacros=1 would show each macro's replacement text and its argument, one after the other. I want that for "logical" keys, not literal key-handling macros.

– Ryan Reich
Nov 13 '11 at 19:10




2




2





Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

– Loop Space
Nov 26 '11 at 19:31





Given the deafening silence on this one, and the number of votes, I think you have an opportunity here to provide a very useful tool: a pgfkeys debugging extension. I think that will a few little extra bits of code here and there, you could successfully trace all the important action and not get overwhelmed by the unnecessary stuff.

– Loop Space
Nov 26 '11 at 19:31













@Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

– Ryan Reich
Nov 26 '11 at 23:51





@Andrew: I was thinking the same thing. I believe this can be achieved by defining some tracing keys with pgfkeys itself, actually, that would get called in the same manner as handlers. I will think more about this in December once the quarter ends.

– Ryan Reich
Nov 26 '11 at 23:51













You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

– Christian Feuersänger
Feb 9 '12 at 17:29







You may take a look into the key filtering suite which ships with pgfkeys.Its purpose it to present EACH key to some "filter" to decide if the key is to be processed. I suppose that you can easily write some sort of "inspection" key. It has advanced support to handle all available key types.

– Christian Feuersänger
Feb 9 '12 at 17:29












2 Answers
2






active

oldest

votes


















21














I have written a draft of a package that traces pgfkeys. I have tested it as much as I can stand, and it seems both to work and to be useful, but I am reluctant to publish it on CTAN before giving it a beta run. Therefore I am making it available only on my own website (no longer available) for now. It consists (for now) just of a .sty file with a comment block at the top describing how it works.



I would really appreciate any comments you might have, so I'm going to open up a second answer (CW) for feature requests and bug reports. Perhaps it's selfish, but I want reputation from this answer.






share|improve this answer





















  • 1





    In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

    – Ahmed Musa
    Feb 9 '12 at 14:49













  • Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

    – Ahmed Musa
    Feb 9 '12 at 15:14











  • @Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

    – Ryan Reich
    Feb 9 '12 at 18:15













  • @Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

    – Ryan Reich
    Feb 9 '12 at 22:33






  • 1





    @AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

    – doncherry
    May 2 '13 at 0:40



















10














I will reply to items below in the chatroom trace-pgfkeys.



Feature requests




  • (added by Andrew Stacey) I'd like to sometimes see the values that are being passed around. As a first case, when a key uses /.store in I'd like to know what was being stored in what.


  • (Andrew Stacey again) I'd like to be able to follow particular keys, or families of keys. Looking at the output from this package, there's an awful lot going on! Often, I'm just interested in tracing how one piece works.



Bugs




  • Processing an unknown key with a defined unknown handler (in the unknown key's path) in the verbose mode yields an error.


Here's a M(N)WE:



documentclass{article}

usepackage{pgfkeys}
usepackage[silent]{trace-pgfkeys}

begin{document}

pgfkeys{/bla/.unknown/.code=blabla}
pgfkeystracelevel{verbose}
pgfkeys{/bla/nonexisting}

end{document}


I investigated a bit and found the source of the error. In the second patch of pgfkeys@unknown, message expandafterunexpandedexpandafter{meaningpgfkeys@code}% introduces an expandafter, which becomes the first expandafter of pgfkeys@unknown. Further patches of pgfkeys@unknown are therefore done in this place. The solution is to replace the offending message by expandonce{meaningpgfkeys@code}%. The full code of the patch command is as follows:



trace@patchcmd@tpgfkverbose@tpgfkpgfkeys@unknown{expandafter}{%
Unknown handler code:\%
expandonce{meaningpgfkeys@code}%
}





share|improve this answer


























  • Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

    – Loop Space
    Feb 9 '12 at 21:54











  • Excellent idea! I have created one.

    – Ryan Reich
    Feb 9 '12 at 21:59











  • As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

    – Sašo Živanović
    Apr 27 '16 at 16:14











  • I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

    – Sašo Živanović
    Apr 27 '16 at 16:16











  • @SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

    – Ryan Reich
    Apr 27 '16 at 17:22












Your Answer








StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "85"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftex.stackexchange.com%2fquestions%2f34712%2fhow-do-i-debug-pgfkeys%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























2 Answers
2






active

oldest

votes








2 Answers
2






active

oldest

votes









active

oldest

votes






active

oldest

votes









21














I have written a draft of a package that traces pgfkeys. I have tested it as much as I can stand, and it seems both to work and to be useful, but I am reluctant to publish it on CTAN before giving it a beta run. Therefore I am making it available only on my own website (no longer available) for now. It consists (for now) just of a .sty file with a comment block at the top describing how it works.



I would really appreciate any comments you might have, so I'm going to open up a second answer (CW) for feature requests and bug reports. Perhaps it's selfish, but I want reputation from this answer.






share|improve this answer





















  • 1





    In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

    – Ahmed Musa
    Feb 9 '12 at 14:49













  • Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

    – Ahmed Musa
    Feb 9 '12 at 15:14











  • @Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

    – Ryan Reich
    Feb 9 '12 at 18:15













  • @Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

    – Ryan Reich
    Feb 9 '12 at 22:33






  • 1





    @AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

    – doncherry
    May 2 '13 at 0:40
















21














I have written a draft of a package that traces pgfkeys. I have tested it as much as I can stand, and it seems both to work and to be useful, but I am reluctant to publish it on CTAN before giving it a beta run. Therefore I am making it available only on my own website (no longer available) for now. It consists (for now) just of a .sty file with a comment block at the top describing how it works.



I would really appreciate any comments you might have, so I'm going to open up a second answer (CW) for feature requests and bug reports. Perhaps it's selfish, but I want reputation from this answer.






share|improve this answer





















  • 1





    In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

    – Ahmed Musa
    Feb 9 '12 at 14:49













  • Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

    – Ahmed Musa
    Feb 9 '12 at 15:14











  • @Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

    – Ryan Reich
    Feb 9 '12 at 18:15













  • @Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

    – Ryan Reich
    Feb 9 '12 at 22:33






  • 1





    @AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

    – doncherry
    May 2 '13 at 0:40














21












21








21







I have written a draft of a package that traces pgfkeys. I have tested it as much as I can stand, and it seems both to work and to be useful, but I am reluctant to publish it on CTAN before giving it a beta run. Therefore I am making it available only on my own website (no longer available) for now. It consists (for now) just of a .sty file with a comment block at the top describing how it works.



I would really appreciate any comments you might have, so I'm going to open up a second answer (CW) for feature requests and bug reports. Perhaps it's selfish, but I want reputation from this answer.






share|improve this answer















I have written a draft of a package that traces pgfkeys. I have tested it as much as I can stand, and it seems both to work and to be useful, but I am reluctant to publish it on CTAN before giving it a beta run. Therefore I am making it available only on my own website (no longer available) for now. It consists (for now) just of a .sty file with a comment block at the top describing how it works.



I would really appreciate any comments you might have, so I'm going to open up a second answer (CW) for feature requests and bug reports. Perhaps it's selfish, but I want reputation from this answer.







share|improve this answer














share|improve this answer



share|improve this answer








edited 10 mins ago









Henri Menke

77.2k8170284




77.2k8170284










answered Feb 7 '12 at 6:42









Ryan ReichRyan Reich

31.5k7100160




31.5k7100160








  • 1





    In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

    – Ahmed Musa
    Feb 9 '12 at 14:49













  • Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

    – Ahmed Musa
    Feb 9 '12 at 15:14











  • @Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

    – Ryan Reich
    Feb 9 '12 at 18:15













  • @Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

    – Ryan Reich
    Feb 9 '12 at 22:33






  • 1





    @AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

    – doncherry
    May 2 '13 at 0:40














  • 1





    In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

    – Ahmed Musa
    Feb 9 '12 at 14:49













  • Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

    – Ahmed Musa
    Feb 9 '12 at 15:14











  • @Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

    – Ryan Reich
    Feb 9 '12 at 18:15













  • @Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

    – Ryan Reich
    Feb 9 '12 at 22:33






  • 1





    @AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

    – doncherry
    May 2 '13 at 0:40








1




1





In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

– Ahmed Musa
Feb 9 '12 at 14:49







In the latest issue of TUGboat (volume 32, number 3) there is an article on '(La)TeX coding standards' and the apparent lack of cooperation among developers. I too, by omission, have been guilty of this. The 'etoolbox' and 'ltxkeys' packages have internal tracing and debugging features. Might it not be better asking the pgf team to consider integrating your code into theirs and acknowledging you? Aside: why does 'add comment' drop my @Ryan Reich?

– Ahmed Musa
Feb 9 '12 at 14:49















Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

– Ahmed Musa
Feb 9 '12 at 15:14





Note: Actually, only the patchcmd command of etoolbox package has the internal tracing utility.

– Ahmed Musa
Feb 9 '12 at 15:14













@Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

– Ryan Reich
Feb 9 '12 at 18:15







@Ahmed The tracing mode of patchcmd was actually very useful for me, as it revealed a catcode change I needed to make in order to use it in my setup code. I have tried to imitate its style, in fact.

– Ryan Reich
Feb 9 '12 at 18:15















@Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

– Ryan Reich
Feb 9 '12 at 22:33





@Ahmed: I have also considered asking the PGF people to support this package. If not by actually merging it, at least by putting in dummy tokens everywhere in their code so it is easier and less fragile to patch in my tracing text.

– Ryan Reich
Feb 9 '12 at 22:33




1




1





@AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

– doncherry
May 2 '13 at 0:40





@AhmedMusa Re your aside: If only one user (besides you), i.e. the author of the post, has so far been involved in the comments to the post, it is clear that he or she is the one addressed. And since the post owner is also always notified of comments to their post, the SE system doesn’t deem such an @-notification necessary and removes it.

– doncherry
May 2 '13 at 0:40











10














I will reply to items below in the chatroom trace-pgfkeys.



Feature requests




  • (added by Andrew Stacey) I'd like to sometimes see the values that are being passed around. As a first case, when a key uses /.store in I'd like to know what was being stored in what.


  • (Andrew Stacey again) I'd like to be able to follow particular keys, or families of keys. Looking at the output from this package, there's an awful lot going on! Often, I'm just interested in tracing how one piece works.



Bugs




  • Processing an unknown key with a defined unknown handler (in the unknown key's path) in the verbose mode yields an error.


Here's a M(N)WE:



documentclass{article}

usepackage{pgfkeys}
usepackage[silent]{trace-pgfkeys}

begin{document}

pgfkeys{/bla/.unknown/.code=blabla}
pgfkeystracelevel{verbose}
pgfkeys{/bla/nonexisting}

end{document}


I investigated a bit and found the source of the error. In the second patch of pgfkeys@unknown, message expandafterunexpandedexpandafter{meaningpgfkeys@code}% introduces an expandafter, which becomes the first expandafter of pgfkeys@unknown. Further patches of pgfkeys@unknown are therefore done in this place. The solution is to replace the offending message by expandonce{meaningpgfkeys@code}%. The full code of the patch command is as follows:



trace@patchcmd@tpgfkverbose@tpgfkpgfkeys@unknown{expandafter}{%
Unknown handler code:\%
expandonce{meaningpgfkeys@code}%
}





share|improve this answer


























  • Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

    – Loop Space
    Feb 9 '12 at 21:54











  • Excellent idea! I have created one.

    – Ryan Reich
    Feb 9 '12 at 21:59











  • As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

    – Sašo Živanović
    Apr 27 '16 at 16:14











  • I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

    – Sašo Živanović
    Apr 27 '16 at 16:16











  • @SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

    – Ryan Reich
    Apr 27 '16 at 17:22
















10














I will reply to items below in the chatroom trace-pgfkeys.



Feature requests




  • (added by Andrew Stacey) I'd like to sometimes see the values that are being passed around. As a first case, when a key uses /.store in I'd like to know what was being stored in what.


  • (Andrew Stacey again) I'd like to be able to follow particular keys, or families of keys. Looking at the output from this package, there's an awful lot going on! Often, I'm just interested in tracing how one piece works.



Bugs




  • Processing an unknown key with a defined unknown handler (in the unknown key's path) in the verbose mode yields an error.


Here's a M(N)WE:



documentclass{article}

usepackage{pgfkeys}
usepackage[silent]{trace-pgfkeys}

begin{document}

pgfkeys{/bla/.unknown/.code=blabla}
pgfkeystracelevel{verbose}
pgfkeys{/bla/nonexisting}

end{document}


I investigated a bit and found the source of the error. In the second patch of pgfkeys@unknown, message expandafterunexpandedexpandafter{meaningpgfkeys@code}% introduces an expandafter, which becomes the first expandafter of pgfkeys@unknown. Further patches of pgfkeys@unknown are therefore done in this place. The solution is to replace the offending message by expandonce{meaningpgfkeys@code}%. The full code of the patch command is as follows:



trace@patchcmd@tpgfkverbose@tpgfkpgfkeys@unknown{expandafter}{%
Unknown handler code:\%
expandonce{meaningpgfkeys@code}%
}





share|improve this answer


























  • Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

    – Loop Space
    Feb 9 '12 at 21:54











  • Excellent idea! I have created one.

    – Ryan Reich
    Feb 9 '12 at 21:59











  • As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

    – Sašo Živanović
    Apr 27 '16 at 16:14











  • I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

    – Sašo Živanović
    Apr 27 '16 at 16:16











  • @SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

    – Ryan Reich
    Apr 27 '16 at 17:22














10












10








10







I will reply to items below in the chatroom trace-pgfkeys.



Feature requests




  • (added by Andrew Stacey) I'd like to sometimes see the values that are being passed around. As a first case, when a key uses /.store in I'd like to know what was being stored in what.


  • (Andrew Stacey again) I'd like to be able to follow particular keys, or families of keys. Looking at the output from this package, there's an awful lot going on! Often, I'm just interested in tracing how one piece works.



Bugs




  • Processing an unknown key with a defined unknown handler (in the unknown key's path) in the verbose mode yields an error.


Here's a M(N)WE:



documentclass{article}

usepackage{pgfkeys}
usepackage[silent]{trace-pgfkeys}

begin{document}

pgfkeys{/bla/.unknown/.code=blabla}
pgfkeystracelevel{verbose}
pgfkeys{/bla/nonexisting}

end{document}


I investigated a bit and found the source of the error. In the second patch of pgfkeys@unknown, message expandafterunexpandedexpandafter{meaningpgfkeys@code}% introduces an expandafter, which becomes the first expandafter of pgfkeys@unknown. Further patches of pgfkeys@unknown are therefore done in this place. The solution is to replace the offending message by expandonce{meaningpgfkeys@code}%. The full code of the patch command is as follows:



trace@patchcmd@tpgfkverbose@tpgfkpgfkeys@unknown{expandafter}{%
Unknown handler code:\%
expandonce{meaningpgfkeys@code}%
}





share|improve this answer















I will reply to items below in the chatroom trace-pgfkeys.



Feature requests




  • (added by Andrew Stacey) I'd like to sometimes see the values that are being passed around. As a first case, when a key uses /.store in I'd like to know what was being stored in what.


  • (Andrew Stacey again) I'd like to be able to follow particular keys, or families of keys. Looking at the output from this package, there's an awful lot going on! Often, I'm just interested in tracing how one piece works.



Bugs




  • Processing an unknown key with a defined unknown handler (in the unknown key's path) in the verbose mode yields an error.


Here's a M(N)WE:



documentclass{article}

usepackage{pgfkeys}
usepackage[silent]{trace-pgfkeys}

begin{document}

pgfkeys{/bla/.unknown/.code=blabla}
pgfkeystracelevel{verbose}
pgfkeys{/bla/nonexisting}

end{document}


I investigated a bit and found the source of the error. In the second patch of pgfkeys@unknown, message expandafterunexpandedexpandafter{meaningpgfkeys@code}% introduces an expandafter, which becomes the first expandafter of pgfkeys@unknown. Further patches of pgfkeys@unknown are therefore done in this place. The solution is to replace the offending message by expandonce{meaningpgfkeys@code}%. The full code of the patch command is as follows:



trace@patchcmd@tpgfkverbose@tpgfkpgfkeys@unknown{expandafter}{%
Unknown handler code:\%
expandonce{meaningpgfkeys@code}%
}






share|improve this answer














share|improve this answer



share|improve this answer








edited Apr 27 '16 at 16:12


























community wiki





6 revs, 3 users 50%
Sašo Živanović














  • Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

    – Loop Space
    Feb 9 '12 at 21:54











  • Excellent idea! I have created one.

    – Ryan Reich
    Feb 9 '12 at 21:59











  • As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

    – Sašo Živanović
    Apr 27 '16 at 16:14











  • I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

    – Sašo Živanović
    Apr 27 '16 at 16:16











  • @SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

    – Ryan Reich
    Apr 27 '16 at 17:22



















  • Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

    – Loop Space
    Feb 9 '12 at 21:54











  • Excellent idea! I have created one.

    – Ryan Reich
    Feb 9 '12 at 21:59











  • As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

    – Sašo Živanović
    Apr 27 '16 at 16:14











  • I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

    – Sašo Živanović
    Apr 27 '16 at 16:16











  • @SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

    – Ryan Reich
    Apr 27 '16 at 17:22

















Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

– Loop Space
Feb 9 '12 at 21:54





Hmm, this could get messy (in terms of replying to stuff)! I admit it was only my first spin with your code and I didn't try all of the gears. ... Idea: have a dedicated chat room for this package. It works well for the Tex-SX stuff (youcould use that one if you like).

– Loop Space
Feb 9 '12 at 21:54













Excellent idea! I have created one.

– Ryan Reich
Feb 9 '12 at 21:59





Excellent idea! I have created one.

– Ryan Reich
Feb 9 '12 at 21:59













As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

– Sašo Živanović
Apr 27 '16 at 16:14





As the chat room is not active anymore, I have added the bug report into the answer. I also support the feature request(s) by @AndrewStacey. (The first one about values is actually easy to achieve. I can add the code if anyone's interested.)

– Sašo Živanović
Apr 27 '16 at 16:14













I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

– Sašo Živanović
Apr 27 '16 at 16:16





I hope @RyanReich reads this as I believe it's time to put this fantastic package to ctan!

– Sašo Živanović
Apr 27 '16 at 16:16













@SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

– Ryan Reich
Apr 27 '16 at 17:22





@SašoŽivanović Thank you. I considered doing this a long time ago but the package is quite version-specific to pgfkeys, and therefore increasingly dated. In addition, these days I don't do any TeX at all. Are you interested in maintaining it?

– Ryan Reich
Apr 27 '16 at 17:22


















draft saved

draft discarded




















































Thanks for contributing an answer to TeX - LaTeX Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftex.stackexchange.com%2fquestions%2f34712%2fhow-do-i-debug-pgfkeys%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Paper upload error, “Upload failed: The top margin is 0.715 in on page 3, which is below the required...

Emraan Hashmi Filmografia | Linki zewnętrzne | Menu nawigacyjneGulshan GroverGulshan...

How can I write this formula?newline and italics added with leqWhy does widehat behave differently if I...