Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Better code folding #433

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

btstream
Copy link
Contributor

Better code folding

By default, sublime text use "%(fold)" and "%...(end)" marks and "tabs" to identify code folding sections in latex source files.

This feature supplies a better code folding behavior. It can recognize "%(fold)" and "%...(end)" mark pairs, if you forget to use this mark, it all OK too. If the marks of "%(fold)" and "%...(end)" are not used, it will auto pair the code folding sections to the next same level's "section start mark" or "parents' start marks". For example, for the code bellow:

\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.

% section hello (end)

\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too
hello world, too
hello world, too

\section{hello again?}
hello again? I am tired.

wil be folded to

\section{hello} % (fold)...
% section hello (end)

\section{hello too} %(fold)...
\section{hello again?}...

shortcut for code folding

Better code folding can ONLY be used by shortcuts!
By default, all of the shortcut bellow can be used.

"Alt+Super+[", "Super+k, Super+1", "Super+k, Super+2", "Super+k, Super+3",
... "Super+k, Super+7" are now can be used in latex source file even there are no "tab" used in source files.

And there are three special shortcuts, which are:
"Super+k, Super+o": unfold current foding. I don't know why set this command to the shortcut of "Alt+Super+]" does not work for me, so I set it to "Super+k, Super+o" as alternative.

"Super+k, Super+9": fold whole buffer to "Table of Content", which is called "fold to toc".

"Super+k, Super+0": fold whole buffer to TOC but keep the current editing section unfold.

About fold_to_toc command

Example of fold to toc(Super+k, Super+9) is like this:

If source cod is :

\chapter{chapter1}

Content before section of hello.

\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.

% section hello (end)

\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too

\subsection{hell subsection}

hello world, too
hello world, too

\section{hello again?}
hello again? I am tired.

will be fold to

\chapter{chapter1}...
\section{hello} % (fold)...
\section{hello too} %(fold)...
\subsection{hell subsection}...
\section{hello again?}...

if "Super+k, Super+0" is triggered, it will be folded to

\chapter{chapter1}...
\section{hello} % (fold)...
\section{hello too} %(fold)...
\subsection{hell subsection}

hello world, too
hello world, too

\section{hello again?}...

it can be seen that the in the fold to toc command, fold marks of "%(fold)" and "%...(end)" are ignored.

"fold_toc_depth" options

There is a "fold_toc_depth" option, which controls the depth of fold_to_toc command fold the buffer.
When "fold_toc_depth" is not set, 4 will be used as default value. If option is set to

"fold_toc_depth": 2

in LaTeXtools config files, and the code like

\chapter{chapter1}

Content before section of hello.

\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.

% section hello (end)

\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too

\subsection{hell subsection}

hello world, too
hello world, too

\section{hello again?}
hello again? I am tired.

will be folded to

\chapter{chapter1}...
\section{hello} % (fold)...
\section{hello too} %(fold)...
\section{hello again?}...

which means \subsection, \subsubsection and others will be folded into \subsection

About extreme fold

These is another fold mode called extreme fold. When extreme fold is used, all fold marks of "%(fold)" and "%...(end)" will be ignored. extreme fold is used only in "fold to toc" by default, but it can be set to other scopes by change the "extreme_fold" option in "laTeXTools.sublime-settings". Detailed description can be found in "laTeXTools.sublime-settings" file.

Better Fold Sections.
@msiniscalchi
Copy link
Contributor

Thank you for these patches! Now I really have no excuse not to pull them
in!
On Sep 19, 2014 12:04 AM, "btstream" [email protected] wrote:

Better code folding

By default, sublime text use "%(fold)" and "%...(end)" marks and "tabs" to
identify code folding sections in latex source files.

This feature supplies a better code folding behavior. It can recognize
"%(fold)" and "%...(end)" mark pairs, if you forget to use this mark, it
all OK too. If the marks of "%(fold)" and "%...(end)" are not used, it will
auto pair the code folding sections to the next same level's "section start
mark" or "parents' start marks". For example, for the code bellow:

\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.
% section hello (end)
\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too
hello world, too
hello world, too
\section{hello again?}
hello again? I am tired.

wil be folded to

\section{hello} % (fold)...% section hello (end)
\section{hello too} %(fold)...\section{hello again?}...

shortcut for code folding

Better code folding can ONLY be used by shortcuts!
By default, all of the shortcut bellow can be used.

"Alt+Super+[", "Super+k, Super+1", "Super+k, Super+2", "Super+k, Super+3",
... "Super+k, Super+7" are now can be used in latex source file even there
are no "tab" used in source files.

And there are three special shortcuts, which are:
"Super+k, Super+o": unfold current foding. I don't know why set this
command to the shortcut of "Alt+Super+]" does not work for me, so I set it
to "Super+k, Super+o" as alternative.

"Super+k, Super+9": fold whole buffer to "Table of Content", which is
called "fold to toc".

"Super+k, Super+0": fold whole buffer to TOC but keep the current editing
section unfold.
About fold_to_toc command

Example of fold to toc(Super+k, Super+9) is like this:

If source cod is :

\chapter{chapter1}

Content before section of hello.
\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.
% section hello (end)
\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too
\subsection{hell subsection}

hello world, too
hello world, too
\section{hello again?}
hello again? I am tired.

will be fold to

\chapter{chapter1}...\section{hello} % (fold)...\section{hello too} %(fold)...\subsection{hell subsection}...\section{hello again?}...

if "Super+k, Super+0" is triggered, it will be folded to

\chapter{chapter1}...\section{hello} % (fold)...\section{hello too} %(fold)...\subsection{hell subsection}

hello world, too
hello world, too
\section{hello again?}...

it can be seen that the in the fold to toc command, fold marks of
"%(fold)" and "%...(end)" are ignored.
"fold_toc_depth" options

There is a "fold_toc_depth" option, which controls the depth of
fold_to_toc command fold the buffer.
When "fold_toc_depth" is not set, 4 will be used as default value. If
option is set to

"fold_toc_depth": 2

in LaTeXtools config files, and the code like

\chapter{chapter1}

Content before section of hello.
\section{hello} % (fold)
hello world, hello world.
hello world, hello world.
hello world, hello world.
hello world, hello world.
% section hello (end)
\section{hello too} %(fold)
hello world, too
hello world, too
hello world, too
\subsection{hell subsection}

hello world, too
hello world, too
\section{hello again?}
hello again? I am tired.

will be folded to

\chapter{chapter1}...\section{hello} % (fold)...\section{hello too} %(fold)...\section{hello again?}...

which means \subsection, \subsubsection and others will be folded into
\subsection
About extreme fold

These is another fold mode called extreme fold. When extreme fold is used,
all fold marks of "%(fold)" and "%...(end)" will be ignored. extreme fold
is used only in "fold to toc" by default, but it can be set to other scopes
by change the "extreme_fold" option in "laTeXTools.sublime-settings".

Detailed description can be found in "laTeXTools.sublime-settings" file.

You can merge this Pull Request by running

git pull https://github.com/btstream/LaTeXTools BetterCodeFolding

Or view, comment on, or merge it at:

#433
Commit Summary

  • Add LaTeX-cwl auto-completion support
  • Revert "Revert 517c5a3..bcc745f"
  • Add Better Fold Sections

File Changes

Patch Links:


Reply to this email directly or view it on GitHub
#433.

Add Preamble fold support
@zhuzelong
Copy link

Is the patch in effect in the latest LaTeXTools?

The shortcuts does not work even when there are %(fold) and %...(end) pairs. I have to indent each line to make folding work.

Thank you.

@msiniscalchi
Copy link
Contributor

Not yet... Sorry! I do plan on pulling it as soon as I have some time this
summer.
On Aug 5, 2015 10:37 AM, "Zack" [email protected] wrote:

Is the patch in effect in the latest LaTeXTools?

The shortcuts does not work even when there are %(fold) and %...(end)
pairs. I have to indent each line to make folding work.

Thank you.


Reply to this email directly or view it on GitHub
#433 (comment)
.

@ig0774 ig0774 force-pushed the master branch 3 times, most recently from 3041ae1 to 9a86aef Compare July 10, 2016 13:17
@diego898
Copy link

This sounds like a great feature! Hopefully it gets pulled in!

@deathaxe deathaxe force-pushed the master branch 4 times, most recently from c49c2ff to bd5a43f Compare December 26, 2024 21:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants