All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.atomikos.datasource.xa.XID Maven / Gradle / Ivy

There is a newer version: 6.0.0
Show newest version
/**
 * Copyright (C) 2000-2010 Atomikos 
 *
 * This code ("Atomikos TransactionsEssentials"), by itself,
 * is being distributed under the
 * Apache License, Version 2.0 ("License"), a copy of which may be found at
 * http://www.atomikos.com/licenses/apache-license-2.0.txt .
 * You may not use this file except in compliance with the License.
 *
 * While the License grants certain patent license rights,
 * those patent license rights only extend to the use of
 * Atomikos TransactionsEssentials by itself.
 *
 * This code (Atomikos TransactionsEssentials) contains certain interfaces
 * in package (namespace) com.atomikos.icatch
 * (including com.atomikos.icatch.Participant) which, if implemented, may
 * infringe one or more patents held by Atomikos.
 * It should be appreciated that you may NOT implement such interfaces;
 * licensing to implement these interfaces must be obtained separately from Atomikos.
 *
 * 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.
 */

package com.atomikos.datasource.xa;

import java.io.Serializable;
import java.util.Arrays;

import javax.transaction.xa.Xid;

/**
 * 
 * 
 * An adaptor class for mapping a String to Xid type.
 */

public class XID implements Serializable, Xid
{

	private static final long serialVersionUID = 4796496938014754464L;

	private String meAsString_;
    // cached result of toString(), to gain performance

    private int formatId_;
    // required for Xid implementation
    private int branchUsed_ = 0;
    // how many bytes in branch array are used
    private int globalUsed_ = 0;
    // how many bytes in global array are used
    private byte[] branchQualifier_ = new byte[Xid.MAXBQUALSIZE];
    // for Xid
    private byte[] globalTransactionId_ = new byte[Xid.MAXGTRIDSIZE];
    // for Xid
    private static final int DEFAULT_FORMAString = ('A' << 24) + ('T' << 16)
            + ('O' << 8) + 'M';

    // same formatID for each transaction
    // -1 for null Xid, 0 for OSI CCR and positive for proprietary format...

    private XID ( String tid )
    {
        formatId_ = DEFAULT_FORMAString;
        branchQualifier_[0] = 0;
        branchUsed_ = 1;
        globalTransactionId_ = tid.toString ().getBytes ();
        globalUsed_ = tid.toString ().getBytes ().length;
    }

    /**
     * Create a new instance with the resource name as branch. This is the main
     * constructor for new instances.
     * 
     * @param tid
     *            The global transaction identifier.
     * @param resourceURL
     *            The name of the resource in the current configuration
     *            (UNIQUE!), needed for recovering the XIDs for this
     *            configuration. The resulting branch qualifier will ALWAYS
     *            start with the name of the resource, and this can be used
     *            during recovery to identify the XIDs to be recovered.
     */

    public XID ( String tid , String resourceURL )
    {
        this ( tid );
        branchQualifier_ = resourceURL.getBytes ();
        branchUsed_ = branchQualifier_.length;
        if ( branchQualifier_.length > Xid.MAXBQUALSIZE )
            throw new RuntimeException (
                    "Max branch qualifier length exceeded." );
        if ( globalUsed_ > Xid.MAXGTRIDSIZE )
            throw new RuntimeException ( "Max global tid length exceeded." );

    }

    /**
     * Copy constructor needed during recovery: if the data source returns
     * inappropriate instances (that do not implement equals and hashCode) then
     * we will need this constructor.
     * 
     * @param xid
     *            The xid.
     */

    public XID ( Xid xid )
    {
        formatId_ = xid.getFormatId ();
        globalTransactionId_ = xid.getGlobalTransactionId ();
        globalUsed_ = xid.getGlobalTransactionId ().length;
        branchQualifier_ = xid.getBranchQualifier ();
        branchUsed_ = xid.getBranchQualifier ().length;
    }

    public int getFormatId ()
    {
        return formatId_;
    }

    public byte[] getBranchQualifier ()
    {
        return branchQualifier_;
    }

    public byte[] getGlobalTransactionId ()
    {
        return globalTransactionId_;
    }

    public boolean equals ( Object obj )
    {
    	if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
        Xid xid = (Xid) obj;

//        String id1 = new String ( xid.getGlobalTransactionId () ).intern ();
//        String id2 = new String ( xid.getBranchQualifier () ).intern ();
//        String id3 = new String ( getGlobalTransactionId () ).intern ();
//        String id4 = new String ( getBranchQualifier () ).intern ();
//      return (id1.intern ().equals ( id3.intern () ) && id2.intern ().equals (
//      id4.intern () ));        
        //PLQ : this should be faster...
        return Arrays.equals(xid.getGlobalTransactionId (),getGlobalTransactionId ()) && Arrays.equals(xid.getBranchQualifier (), getBranchQualifier ());

    }

    public String toString ()
    {
        if ( meAsString_ == null ) {
            meAsString_ = new String ( getGlobalTransactionId () )
                    + new String ( getBranchQualifier () );
        }
        return meAsString_;
    }

    public int hashCode ()
    {
        return toString ().hashCode ();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy