How to reuse a command inside another environment
Clash Royale CLAN TAG#URR8PPP
up vote
2
down vote
favorite
For my own needs, I am writing a package holding some environments definitions. I also have some commands that I want to be available only inside these environments.
So I define these commands inside the environment definition.
My .sty files looks like this
NeedsTeXFormatLaTeX2e
ProvidesPackagemypackage[version 0.1]
newenvironmentmyenvirA[1]
newcommandmycommandA[1]
%
%... do something
%
% here, the "before" part of code
% here, the "after" part of code
newenvironmentmyenvirB[1]
newcommandmycommandB[1]
%
%.. do something
%
Now, say I want to make mycommandA
available inside myenvirB
blocs. Sure, I can copy/paste, but that is bad programming (error prone).
Question: Does Latex provide a way to handle this case ?
If not, can I put that command definition in a file and input
it? (so I only have to define it once). Will that work once the package is installed in my Latex tree ?
Sorry if unclear, please point me on other question if this appears as a dupe. Couldn't find any, although this one is possibly related (?). But it is unclear to me if the answers apply to my question.
macros packages
add a comment |Â
up vote
2
down vote
favorite
For my own needs, I am writing a package holding some environments definitions. I also have some commands that I want to be available only inside these environments.
So I define these commands inside the environment definition.
My .sty files looks like this
NeedsTeXFormatLaTeX2e
ProvidesPackagemypackage[version 0.1]
newenvironmentmyenvirA[1]
newcommandmycommandA[1]
%
%... do something
%
% here, the "before" part of code
% here, the "after" part of code
newenvironmentmyenvirB[1]
newcommandmycommandB[1]
%
%.. do something
%
Now, say I want to make mycommandA
available inside myenvirB
blocs. Sure, I can copy/paste, but that is bad programming (error prone).
Question: Does Latex provide a way to handle this case ?
If not, can I put that command definition in a file and input
it? (so I only have to define it once). Will that work once the package is installed in my Latex tree ?
Sorry if unclear, please point me on other question if this appears as a dupe. Couldn't find any, although this one is possibly related (?). But it is unclear to me if the answers apply to my question.
macros packages
1
You can define the command outside thenewenvironment
with a private name, say,my@internal@command
, and in the environment you can doletmycommandmy@internal@command
.
â Phelype Oleinik
4 hours ago
add a comment |Â
up vote
2
down vote
favorite
up vote
2
down vote
favorite
For my own needs, I am writing a package holding some environments definitions. I also have some commands that I want to be available only inside these environments.
So I define these commands inside the environment definition.
My .sty files looks like this
NeedsTeXFormatLaTeX2e
ProvidesPackagemypackage[version 0.1]
newenvironmentmyenvirA[1]
newcommandmycommandA[1]
%
%... do something
%
% here, the "before" part of code
% here, the "after" part of code
newenvironmentmyenvirB[1]
newcommandmycommandB[1]
%
%.. do something
%
Now, say I want to make mycommandA
available inside myenvirB
blocs. Sure, I can copy/paste, but that is bad programming (error prone).
Question: Does Latex provide a way to handle this case ?
If not, can I put that command definition in a file and input
it? (so I only have to define it once). Will that work once the package is installed in my Latex tree ?
Sorry if unclear, please point me on other question if this appears as a dupe. Couldn't find any, although this one is possibly related (?). But it is unclear to me if the answers apply to my question.
macros packages
For my own needs, I am writing a package holding some environments definitions. I also have some commands that I want to be available only inside these environments.
So I define these commands inside the environment definition.
My .sty files looks like this
NeedsTeXFormatLaTeX2e
ProvidesPackagemypackage[version 0.1]
newenvironmentmyenvirA[1]
newcommandmycommandA[1]
%
%... do something
%
% here, the "before" part of code
% here, the "after" part of code
newenvironmentmyenvirB[1]
newcommandmycommandB[1]
%
%.. do something
%
Now, say I want to make mycommandA
available inside myenvirB
blocs. Sure, I can copy/paste, but that is bad programming (error prone).
Question: Does Latex provide a way to handle this case ?
If not, can I put that command definition in a file and input
it? (so I only have to define it once). Will that work once the package is installed in my Latex tree ?
Sorry if unclear, please point me on other question if this appears as a dupe. Couldn't find any, although this one is possibly related (?). But it is unclear to me if the answers apply to my question.
macros packages
macros packages
edited 2 mins ago
asked 4 hours ago
kebs
428511
428511
1
You can define the command outside thenewenvironment
with a private name, say,my@internal@command
, and in the environment you can doletmycommandmy@internal@command
.
â Phelype Oleinik
4 hours ago
add a comment |Â
1
You can define the command outside thenewenvironment
with a private name, say,my@internal@command
, and in the environment you can doletmycommandmy@internal@command
.
â Phelype Oleinik
4 hours ago
1
1
You can define the command outside the
newenvironment
with a private name, say, my@internal@command
, and in the environment you can do letmycommandmy@internal@command
.â Phelype Oleinik
4 hours ago
You can define the command outside the
newenvironment
with a private name, say, my@internal@command
, and in the environment you can do letmycommandmy@internal@command
.â Phelype Oleinik
4 hours ago
add a comment |Â
2 Answers
2
active
oldest
votes
up vote
2
down vote
I guess that the definition of mycommandA
in myenvirA
(I won't use numbers, which are illegal in command names) depends on the argument passed to the environment, otherwise the problem is easy to solve, by just defining mycommandA
directly.
newcommandtemporarycommandname % initialize
newenvironmentmyenvirA[1]
%
renewcommandtemporarycommandname[1]something with #1 and ##1%
globalletmycommandAtemporarycommandname
% whatever else
%
% the end part
Now mycommandA
is usable everywhere, after beginmyenvirA
has been executed. Further calls of myenvirA
will change the meaning of mycommandA
, of course.
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
add a comment |Â
up vote
2
down vote
You can't grab a macro definition from another environment where it is defined, since the environment necessarily provides a limited scope for that macro (as it is grouped).
% mycommand does not exist here
beginmyenvironment
% _Local_ definition of mycommand
newcommandmycommand<cmd definition>
% mycommand exists here
% ...
endmyenvironment
% mycommand does not exist here
Perhaps there are ways to do that, but it's not worth the effort. You should instead define the macro to be globally available, or read it in from an external file via input
every time you need it (if properly installed within your installation folder). The latter option would slow down compilation.
The question you have to ask yourself is why you want to have the definition only be available locally to an environment. Do you want to save memory? That would have been a problem a couple of decades ago, but not anymore. Do you think it will provide for a cleaner package? If so, rather define a "namespace" by preceding each macro for your package mypackage
by @mypackage@
. This way your macros will look like
@mypackage@mycommandA
@mypackage@mycommandB
...
The @
symbol in macros can be used without official declaration of a makeatletter
...makeatother
pair within a package, making it somewhat hidden to the end user. The idea of a "namespace" or @
-macros is fairly common in packages.
add a comment |Â
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
2
down vote
I guess that the definition of mycommandA
in myenvirA
(I won't use numbers, which are illegal in command names) depends on the argument passed to the environment, otherwise the problem is easy to solve, by just defining mycommandA
directly.
newcommandtemporarycommandname % initialize
newenvironmentmyenvirA[1]
%
renewcommandtemporarycommandname[1]something with #1 and ##1%
globalletmycommandAtemporarycommandname
% whatever else
%
% the end part
Now mycommandA
is usable everywhere, after beginmyenvirA
has been executed. Further calls of myenvirA
will change the meaning of mycommandA
, of course.
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
add a comment |Â
up vote
2
down vote
I guess that the definition of mycommandA
in myenvirA
(I won't use numbers, which are illegal in command names) depends on the argument passed to the environment, otherwise the problem is easy to solve, by just defining mycommandA
directly.
newcommandtemporarycommandname % initialize
newenvironmentmyenvirA[1]
%
renewcommandtemporarycommandname[1]something with #1 and ##1%
globalletmycommandAtemporarycommandname
% whatever else
%
% the end part
Now mycommandA
is usable everywhere, after beginmyenvirA
has been executed. Further calls of myenvirA
will change the meaning of mycommandA
, of course.
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
add a comment |Â
up vote
2
down vote
up vote
2
down vote
I guess that the definition of mycommandA
in myenvirA
(I won't use numbers, which are illegal in command names) depends on the argument passed to the environment, otherwise the problem is easy to solve, by just defining mycommandA
directly.
newcommandtemporarycommandname % initialize
newenvironmentmyenvirA[1]
%
renewcommandtemporarycommandname[1]something with #1 and ##1%
globalletmycommandAtemporarycommandname
% whatever else
%
% the end part
Now mycommandA
is usable everywhere, after beginmyenvirA
has been executed. Further calls of myenvirA
will change the meaning of mycommandA
, of course.
I guess that the definition of mycommandA
in myenvirA
(I won't use numbers, which are illegal in command names) depends on the argument passed to the environment, otherwise the problem is easy to solve, by just defining mycommandA
directly.
newcommandtemporarycommandname % initialize
newenvironmentmyenvirA[1]
%
renewcommandtemporarycommandname[1]something with #1 and ##1%
globalletmycommandAtemporarycommandname
% whatever else
%
% the end part
Now mycommandA
is usable everywhere, after beginmyenvirA
has been executed. Further calls of myenvirA
will change the meaning of mycommandA
, of course.
answered 4 hours ago
egreg
694k8518443099
694k8518443099
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
add a comment |Â
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
Thanks for answer. Oops, yeah, sorry for number, I'll edit question to make it (at least) correct.
â kebs
4 mins ago
add a comment |Â
up vote
2
down vote
You can't grab a macro definition from another environment where it is defined, since the environment necessarily provides a limited scope for that macro (as it is grouped).
% mycommand does not exist here
beginmyenvironment
% _Local_ definition of mycommand
newcommandmycommand<cmd definition>
% mycommand exists here
% ...
endmyenvironment
% mycommand does not exist here
Perhaps there are ways to do that, but it's not worth the effort. You should instead define the macro to be globally available, or read it in from an external file via input
every time you need it (if properly installed within your installation folder). The latter option would slow down compilation.
The question you have to ask yourself is why you want to have the definition only be available locally to an environment. Do you want to save memory? That would have been a problem a couple of decades ago, but not anymore. Do you think it will provide for a cleaner package? If so, rather define a "namespace" by preceding each macro for your package mypackage
by @mypackage@
. This way your macros will look like
@mypackage@mycommandA
@mypackage@mycommandB
...
The @
symbol in macros can be used without official declaration of a makeatletter
...makeatother
pair within a package, making it somewhat hidden to the end user. The idea of a "namespace" or @
-macros is fairly common in packages.
add a comment |Â
up vote
2
down vote
You can't grab a macro definition from another environment where it is defined, since the environment necessarily provides a limited scope for that macro (as it is grouped).
% mycommand does not exist here
beginmyenvironment
% _Local_ definition of mycommand
newcommandmycommand<cmd definition>
% mycommand exists here
% ...
endmyenvironment
% mycommand does not exist here
Perhaps there are ways to do that, but it's not worth the effort. You should instead define the macro to be globally available, or read it in from an external file via input
every time you need it (if properly installed within your installation folder). The latter option would slow down compilation.
The question you have to ask yourself is why you want to have the definition only be available locally to an environment. Do you want to save memory? That would have been a problem a couple of decades ago, but not anymore. Do you think it will provide for a cleaner package? If so, rather define a "namespace" by preceding each macro for your package mypackage
by @mypackage@
. This way your macros will look like
@mypackage@mycommandA
@mypackage@mycommandB
...
The @
symbol in macros can be used without official declaration of a makeatletter
...makeatother
pair within a package, making it somewhat hidden to the end user. The idea of a "namespace" or @
-macros is fairly common in packages.
add a comment |Â
up vote
2
down vote
up vote
2
down vote
You can't grab a macro definition from another environment where it is defined, since the environment necessarily provides a limited scope for that macro (as it is grouped).
% mycommand does not exist here
beginmyenvironment
% _Local_ definition of mycommand
newcommandmycommand<cmd definition>
% mycommand exists here
% ...
endmyenvironment
% mycommand does not exist here
Perhaps there are ways to do that, but it's not worth the effort. You should instead define the macro to be globally available, or read it in from an external file via input
every time you need it (if properly installed within your installation folder). The latter option would slow down compilation.
The question you have to ask yourself is why you want to have the definition only be available locally to an environment. Do you want to save memory? That would have been a problem a couple of decades ago, but not anymore. Do you think it will provide for a cleaner package? If so, rather define a "namespace" by preceding each macro for your package mypackage
by @mypackage@
. This way your macros will look like
@mypackage@mycommandA
@mypackage@mycommandB
...
The @
symbol in macros can be used without official declaration of a makeatletter
...makeatother
pair within a package, making it somewhat hidden to the end user. The idea of a "namespace" or @
-macros is fairly common in packages.
You can't grab a macro definition from another environment where it is defined, since the environment necessarily provides a limited scope for that macro (as it is grouped).
% mycommand does not exist here
beginmyenvironment
% _Local_ definition of mycommand
newcommandmycommand<cmd definition>
% mycommand exists here
% ...
endmyenvironment
% mycommand does not exist here
Perhaps there are ways to do that, but it's not worth the effort. You should instead define the macro to be globally available, or read it in from an external file via input
every time you need it (if properly installed within your installation folder). The latter option would slow down compilation.
The question you have to ask yourself is why you want to have the definition only be available locally to an environment. Do you want to save memory? That would have been a problem a couple of decades ago, but not anymore. Do you think it will provide for a cleaner package? If so, rather define a "namespace" by preceding each macro for your package mypackage
by @mypackage@
. This way your macros will look like
@mypackage@mycommandA
@mypackage@mycommandB
...
The @
symbol in macros can be used without official declaration of a makeatletter
...makeatother
pair within a package, making it somewhat hidden to the end user. The idea of a "namespace" or @
-macros is fairly common in packages.
answered 3 hours ago
Werner
427k589371611
427k589371611
add a comment |Â
add a comment |Â
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftex.stackexchange.com%2fquestions%2f458080%2fhow-to-reuse-a-command-inside-another-environment%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
1
You can define the command outside the
newenvironment
with a private name, say,my@internal@command
, and in the environment you can doletmycommandmy@internal@command
.â Phelype Oleinik
4 hours ago