Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   *  Copyright 2007-2008, Plutext Pty Ltd.
   *   
   *  This file is part of docx4j.
  
      docx4j is licensed under the Apache License, Version 2.0 (the "License"); 
      you may not use this file except in compliance with the License. 
  
      You may obtain a copy of the License at 
 
         http://www.apache.org/licenses/LICENSE-2.0 
 
     Unless required by applicable law or agreed to in writing, software 
     distributed under the License is distributed on an "AS IS" BASIS, 
     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
     See the License for the specific language governing permissions and 
     limitations under the License.
 
     This file is a translation into Java of a portion of 
     Program.cs from Microsoft's OpenXmlViewer, which was made available to
     the project under the following license:
     
 		(c) Microsoft Corporation
 		
 		Microsoft Public License (Ms-PL)
 		
 		This license governs use of the accompanying software. If you use the
 		software, you accept this license. If you do not accept the license, do
 		not use the software.
 		
 		1. Definitions
 		
 		The terms "reproduce," "reproduction," "derivative works," and "distribution"
 		have the same meaning here as under U.S. copyright law.
 		
 		A "contribution" is the original software, or any additions or changes to the software.
 		
 		A "contributor" is any person that distributes its contribution under this license.
 		
 		"Licensed patents" are a contributor's patent claims that read directly on its contribution.
 		
 		2. Grant of Rights
 		
 		(A) Copyright Grant- Subject to the terms of this license, including the
 		license conditions and limitations in section 3, each contributor
 		grants you a non-exclusive, worldwide, royalty-free copyright license
 		to reproduce its contribution, prepare derivative works of its
 		contribution, and distribute its contribution or any derivative works
 		that you create.
 		
 		(B) Patent Grant- Subject to the terms of this
 		license, including the license conditions and limitations in section 3,
 		each contributor grants you a non-exclusive, worldwide, royalty-free
 		license under its licensed patents to make, have made, use, sell, offer
 		for sale, import, and/or otherwise dispose of its contribution in the
 		software or derivative works of the contribution in the software.
 		
 		3. Conditions and Limitations
 		
 		(A) No Trademark License- This license does not grant you rights to use any contributors' name, logo, or trademarks.
 		
 		(B) If you bring a patent claim against any contributor over patents that
 		you claim are infringed by the software, your patent license from such
 		contributor to the software ends automatically.
 		
 		(C) If you distribute any portion of the software, you must retain all copyright,
 		patent, trademark, and attribution notices that are present in the
 		software.
 		
 		(D) If you distribute any portion of the software in
 		source code form, you may do so only under this license by including a
 		complete copy of this license with your distribution. If you distribute
 		any portion of the software in compiled or object code form, you may
 		only do so under a license that complies with this license.
 		
 		(E) The software is licensed "as-is." You bear the risk of using it. The
 		contributors give no express warranties, guarantees or conditions. You
 		may have additional consumer rights under your local laws which this
 		license cannot change. To the extent permitted under your local laws,
 		the contributors exclude the implied warranties of merchantability,
 		fitness for a particular purpose and non-infringement.
 
  */
 package org.docx4j.model.listnumbering;
 
 
 
 public class ListLevel {
 		
 	/* TODO 2011 02 23: in addition to having numbering in the 
 	 * Main document part, you can have numbering in other 
 	 * stories:
 	 *   - headers/footers
	 *   - comments
	 *   - footnotes/endnotes
	 * This means that ListLevel should have independent counters
	 * for each story, or the there should be a ListLevel defined
	 * for each story! 
	 * 
	 * 2012 01 10: numbering set up on a per-part basis
	 * seems the most sensible approach.
	 * 
	 */
	protected static Logger log = LoggerFactory.getLogger(ListLevel.class);
	public Lvl getJaxbAbstractLvl() {
	}
	public Lvl getJaxbOverrideLvl() {
	}

The counter is kept at the abstract level, since each instance definition shares a single counter.
	private Counter counter
	private boolean encounteredAlready = false;


    
Constructor for a ListLevel in an abstract definition.
    public ListLevel(Lvl levelNode)
    {
    	this. = levelNode;
    	
        this. = levelNode.getIlvl().toString(); 
        
         = new Counter();
        Lvl.Start startValueNode = levelNode.getStart();
        if (startValueNode != null)
        {
        	this. = startValueNode.getVal().subtract(.);
        		// Start value is one less than the user set it to,
        		// since whenever we fetch the number, we first increment it.
            .setCurrentValue(this.);                        
        }
        Lvl.LvlText levelTextNode = levelNode.getLvlText();
        if (levelTextNode != null)
        {
            this. = levelTextNode.getVal(); 
        }
        org.docx4j.wml.RFonts fontNode = null;
        if (levelNode.getRPr() != null) {
            //XmlNode fontNode = levelNode.SelectSingleNode(".//w:rFonts", nsm);
        	fontNode = levelNode.getRPr().getRFonts();
        }
        if (fontNode != null)
        {
            this. = fontNode.getHAnsi(); //getAttributeValue(fontNode, "w:hAnsi");
        }
        //XmlNode enumTypeNode = levelNode.SelectSingleNode("w:numFmt", nsm);
        
        NumFmt enumTypeNode = levelNode.getNumFmt();
        if (enumTypeNode != null)
        {
        	this. =  enumTypeNode.getVal(); 
            // w:numFmt="bullet" indicates a bulleted list
        	this. = .equals. ); 
        	
            // this.isBullet = String.Compare(type, "bullet", StringComparison.OrdinalIgnoreCase) == 0;
        }
    }

    
Constructor for a ListLevel in an instance definition.
    public ListLevel(ListLevel masterCopy)
    {
    	this. = masterCopy.jaxbAbstractLvl;
    	
        this. = masterCopy.id;
        this. = masterCopy.levelText;
        this. = masterCopy.startValue;
        //this.counter = this.startValue;
        this. = masterCopy.counter;  // reference the abstract one, since this is shared
        this. = masterCopy.font;
        this. = masterCopy.isBullet;
        this. = masterCopy.numFmt;
    }

    
Get overridden values

Parameters:
levelNode
    public void SetOverrides(Lvl levelNode)
    {
    	this. = levelNode;
    	
        Lvl.Start startValueNode = levelNode.getStart();
        if (startValueNode != null)
        {
        	this. = startValueNode.getVal().subtract(.);
    		// Start value is one less than the user set it to,
    		// since whenever we fetch the number, we first increment it.
        	.setCurrentValue(this.);                        
        }
        Lvl.LvlText levelTextNode = levelNode.getLvlText();
        if (levelTextNode != null)
        {
            this. = levelTextNode.getVal(); 
        }
        //XmlNode fontNode = levelNode.SelectSingleNode(".//w:rFonts", nsm);
        org.docx4j.wml.RFonts fontNode =null;
        if (levelNode.getRPr() != null) {
        	fontNode = levelNode.getRPr().getRFonts();
        }
        
        if (fontNode != null)
        {
            this. = fontNode.getHAnsi(); 
        }
        //XmlNode enumTypeNode = levelNode.SelectSingleNode("w:numFmt", nsm);            
        NumFmt enumTypeNode = levelNode.getNumFmt();
        if (enumTypeNode != null)
        {
        	this. =  enumTypeNode.getVal(); 
            // w:numFmt="bullet" indicates a bulleted list
        	this. = .equals. ); 
        }
    }
    
    
    private String id;

    
returns the ID of the level

Returns:
    public String getID()
    {
            return this.;
    }
    private BigInteger startValue = .;
    public void setStartValue(BigInteger startValue) {
		this. = startValue;
	}

start value of that level

Returns:
    public BigInteger getStartValue()
    {
            return this.;
    }


    
The current number, formatted using numFmt.
    {
    	/*
    	 * If you look at the OpenXML spec or
    	 * STNumberFormat.java, you'll see there are some 60 number formats.
    	 * 
    	 * Of these, we currently aim to support:
    	 * 
		 *     decimal
		 *     upperRoman
		 *     lowerRoman
		 *     upperLetter
		 *     lowerLetter
		 *     bullet
		 *     none
		 *     
		 * What about?
		 *     
		 *     ordinal
		 *     cardinalText
		 *     ordinalText
    	 * 
    	 */
    	
    	if (.equals. ) ) {
    		return this..getCurrentValue().toString();
    	}
    	
    	if (.equals. ) ) {
    		return "";        		
    	}
    	if (.equals. ) ) {
    		
    		// TODO - revisit how this is handled.
    		// The code elsewhere for handling bullets
    		// overlaps with this numFmt stuff.
    		return "*";        		
    	}
    	        	
    	int current = this..getCurrentValue().intValue();
    	
    	if (.equals. ) ) {        		
    		NumberFormatRomanUpper converter = new NumberFormatRomanUpper(); 
    		return converter.format(current);
    	}
    	if (.equals. ) ) {        		
    		NumberFormatRomanLower converter = new NumberFormatRomanLower(); 
    		return converter.format(current);
    	}
    	if (.equals. ) ) {        		
    		NumberFormatLowerLetter converter = new NumberFormatLowerLetter(); 
    		return converter.format(current);
    	}
    	if (.equals. ) ) {        		
    		NumberFormatLowerLetter converter = new NumberFormatLowerLetter(); 
    		return converter.format(current).toUpperCase();
    	}        	
    	if (.equals. ) ) {        		
    		NumberFormatDecimalZero converter = new NumberFormatDecimalZero(); 
    		return converter.format(current);
    	}
    	
    	.error("Unhandled numFmt: " + .name() );
        return this..getCurrentValue().toString();
    }
    
    {        	
        return this..getCurrentValue().toString();
    }    
    
    
increments the current count of list items of that level
    public void IncrementCounter()
    {
    	if (!) {
    		// Defer setting the startValue until the list
    		// is actually encountered in the main document part,
    		// since otherwise earlier numbering (using the
    		// same abstract number) would use this startValue
        	.setCurrentValue(this.);  
        	 = true;
    	}
    	
    	
        .IncrementCounter();
        
    }

    
resets the counter to the start value
    public void ResetCounter()
    {
        .setCurrentValue(this.);
    }
    private String levelText;

    
returns the indicated lvlText value

Returns:
    public String getLevelText()
    {
            return this.;
    }
    private String font;

    
returns the font name

Returns:
    public String getFont()
    {
            return this.;
    }
    
    private NumberFormat numFmt// TODO: alter schema 
    // w:numFmt = RTF's \levelnfcN
//		private void setNumFmt(STNumberFormat numFmt) {
//			this.numFmt = numFmt;
//		}
	protected NumberFormat getNumFmt() {
		return ;
	}
    private boolean isBullet;

    
returns whether the enumeration type is a bulleted list or not

Returns:
    public boolean IsBullet()
    {
            return this.;
    }
    
    protected class Counter {
    	
        private BigInteger currentValue;
        
        Counter() {
        	 = .;
        }
        public void setCurrentValue(BigInteger currentValue) {
			this. = currentValue;
		}

returns the current count of list items of that level

Returns:
        public BigInteger getCurrentValue()
        {        	
        	.debug("counter: " + .intValue() );
            return this.;
        }
    
        
increments the current count of list items of that level
        public void IncrementCounter()
        {
            
            .debug("counter now: " + .intValue() );
            
        }
    	
    }
New to GrepCode? Check out our FAQ X