/usr/include/ncbi/pgppop.h is in libncbi6-dev 6.1.20170106-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 | /* $Id: pgppop.h,v 6.42 2016/06/21 21:42:36 kans Exp $
* ===========================================================================
*
* PUBLIC DOMAIN NOTICE
* National Center for Biotechnology Information (NCBI)
*
* This software/database is a "United States Government Work" under the
* terms of the United States Copyright Act. It was written as part of
* the author's official duties as a United States Government employee and
* thus cannot be copyrighted. This software/database is freely available
* to the public for use. The National Library of Medicine and the U.S.
* Government do not place any restriction on its use or reproduction.
* We would, however, appreciate having the NCBI and the author cited in
* any work or product based on this material
*
* Although all reasonable efforts have been taken to ensure the accuracy
* and reliability of the software and data, the NLM and the U.S.
* Government do not and cannot warrant the performance or results that
* may be obtained by using this software or data. The NLM and the U.S.
* Government disclaim all warranties, express or implied, including
* warranties of performance, merchantability or fitness for any particular
* purpose.
*
* ===========================================================================
*
* File Name: pgppop.h
*
* Author: Patrick Durand
*
* Version Creation Date: 05/03/99
*
* $Revision: 6.42 $
*
* File Description:
*
* Modifications:
* --------------------------------------------------------------------------
*
* ==========================================================================
*/
#ifndef _PGPPOP_
#define _PGPPOP_
#include <ncbi.h>
#include <objseq.h>
#include <blocks.h>
#include <udvseq.h>
#include <ddvcolor.h>
#undef NLM_EXTERN
#ifdef NLM_IMPORT
#define NLM_EXTERN NLM_IMPORT
#else
#define NLM_EXTERN extern
#endif
#ifdef __cplusplus
extern "C" {
#endif
#define WWW_SCRIPT_SIZE 1000
#define LETTER_BLOCK_WIDTH 10
#define LETTER_HALF_BLOCK_WIDTH 5
#define SCALE_TICK 1
#define SCALE_NUM 2
#define TABLE_LEFT_MARGIN 16
#define INFO_SIZE 255
#define ParaG_Size 70
/*used by the layout manager (see DDVOptionsBlock
data structure in this file*/
#define DDV_USE_STDCLR ((Uint1)1)/*use standard aa or na colors-mainly used by DDV itself*/
#define DDV_USE_NOMLAYOUT ((Uint1)2)/*layout the Aligned regions*/
#define DDV_USE_UALAYOUT ((Uint1)4)/*layout the UA regions*/
#define DDV_USE_GAPLAYOUT ((Uint1)8)/*layout the GAP*/
#define DDV_USE_MASKLAYOUT ((Uint1)16)/*layout masked regions*/
#define DDV_USE_ISOLAYOUT ((Uint1)32)/*layout ident/simil/other*/
/*used to set the layout for letters (initially designed for new BLAST outputs*/
/*note: it's possible to combine all the values*/
#define DDV_TXTSTYLE_ITALIC ((Uint1)1)
#define DDV_TXTSTYLE_BOLD ((Uint1)2)
#define DDV_TXTSTYLE_UNDERLINE ((Uint1)4)
#define DDV_TXTSTYLE_LOWERCASE ((Uint1)8)
#define DDV_TXTSTYLE_COLOR ((Uint1)16)
typedef struct ddvrulerdescr{
Int4 disp_start;/*start in display coordinate*/
Int4 disp_stop;/*stop in display coordinate*/
Int4 align_start;/*start in align coordinate*/
Boolean bUnAligned;
} DDVRulerDescr, PNTR DDVRulerDescrPtr;
/*****************************************************************************
Populated lists of the elements ready for the display
Note : use the following data structure to display in the
Vibrant viewer/editor
if (DisplayType==DDV_DISP_HORZ) use 'TableHead '
else use 'DisplayVert'
*****************************************************************************/
typedef struct msaparagpoplist {
Int4 LengthAli; /*Alignment size after population from index*/
Int4 nBsp; /*number of Bioseq after...*/
SABlockPtr sabp;/*indexed seqalign*/
SeqAlignPtr sap;
SeqAlignPtr viewed_sap; /* so that DDE can remember DDV's sap */
ValNodePtr PNTR TableHead; /*Table list of the heads of the ValNode
ParaG list for each bioseq*/
ValNodePtr DisplayVert; /*List of ParaG Ready for display*/
BspInfoPtr bspp; /*info for each bsp of the seqalign*/
Uint1 DisplayType;/*see defines above*/
ValNodePtr RulerDescr; /*use by DDV only; ruler descriptor*/
Uint4Ptr entitiesTbl;/* " " " " ; eID, iID of each bioseq*/
} MsaParaGPopList, PNTR MsaParaGPopListPtr;
/*****************************************************************************
Command-Line or URL content
*****************************************************************************/
typedef struct urldata{ /*structure containing the decoded URL*/
BIG_ID gi; /*gi to retrieve in ID1*/
Int4 from; /*want to display from...*/
Int4 to; /*... to (SeqAlign coord)*/
Uint4 disp_format;/*display format (seebelow)*/
CharPtr szFileNameIn;/*used only for Unix command-line*/
CharPtr szFileNameOut;/*used only for Unix command-line*/
SeqEntryPtr sep; /*used by DDV_ToolsScript*/
CharPtr szGIs;/*used of the realign stuff*/
Uint2 eID;/*entityID; used by PopSet viewer to display onSeqAlign
among others*/
} URLData, PNTR URLDataPtr;
/*****************************************************************************
data block to get BioSource(s)
*****************************************************************************/
typedef struct popsource{
CharPtr szTaxName;
CharPtr szCommonName;
} PopSource, PNTR PopSourcePtr;
typedef struct ddvextlayout{
Uint1 style;
Uint1 rgb[3];
Uint1 clr_ident;
Uint1 clr_simil;
Uint1 clr_other;
Uint1 sty_ident;
Uint1 sty_simil;
Uint1 sty_other;
}DDVExtLayout, PNTR DDVExtLayoutPtr;
/*****************************************************************************
data blocks for enhanced display options
*****************************************************************************/
typedef struct ddv_disp_opt{
/*color display ?*/
Boolean bUseColors;
/*styles for a disc. seqalign*/
Boolean ShowLeftTail;
Boolean ShowRightTail;
Uint1 DispDiscStyle;
Uint1 SpacerSize;
Uint1 DiscJustification;
Uint1 UAGapStyle;
Uint1 AGapStyle;
/*this field is here because it's closely related to the SeqAlign*/
Uint1 RulerStyle; /*for bioseq coord system; used only when rebuild the display*/
}DDV_Disp_Opt, PNTR DDV_Disp_OptPtr;
typedef struct ddvoptionsblock{
Int2 LineSize;/*size of a sequence line*/
ByteStorePtr PNTR byteSpp;/*use this to store the formatted align as a
ByteStore*/
/*the following are mainly designed for enhanced HTML BLAST outputs*/
Int4Ptr PNTR matrix;
Boolean bUseLayout;
Uint1 LayoutType;
DDVExtLayout normlayout;
DDVExtLayout UAlayout;
DDVExtLayout GAPlayout;
DDVExtLayout MASKlayout;
DDVExtLayout ISOlayout;
/*additional styles*/
DDV_Disp_OptPtr ddop;
} DDVOptionsBlock, PNTR DDVOptionsBlockPtr;
/*************************************************************************
DISPLAY FORMATS. the following values can be putted in a single Uint4
using the binary operator '|='
*************************************************************************/
/*ruler styles : left, right, top (all), ticks*/
#define RULER_TOP ((Uint4)1)
#define RULER_LEFT ((Uint4)2)
#define RULER_RIGHT ((Uint4)4)
#define RULER_TICK ((Uint4)8)
/*display enhancement : color, show by block of 10 letters*/
#define DISPE_COLOR ((Uint4)16)
#define DISPE_SHOWBLOCK ((Uint4)32)
/*seq. letters to show : all, variations*/
#define VIEW_FULLSEQ ((Uint4)64)
#define VIEW_VARIA ((Uint4)128)
/*output format */
#define DISP_FULL_HTML ((Uint4)256)
#define DISP_PHYLIP_TXT ((Uint4)512)
#define DISP_FASTA_NOGAP ((Uint4)1024)
#define DISP_FASTA_GAP ((Uint4)2048)
#define DISP_FULL_TXT ((Uint4)4096)
/*content of a line */
/* a line is like that : [...] Name < 4125 AGCT AGCT ... 4254*/
/*Name is always displayed*/
#define DISP_ORDER_NUM ((Uint4)8192) /*[...]*/
#define DISP_STRAND ((Uint4)16384) /* < or > */
#define DISP_BSP_COORD ((Uint4)32768)
/*use this flag to force a rebuild a new align*/
#define ALIGN_REBUILD ((Uint4)65536)
/*use this flag to display lower case letters; otherwise upper case is used*/
#define TEXT_LOWERCASE ((Uint4)131072)
/*use this flag to display 'QUERY:' and 'SBJCT:' as seq. name
should be used for BLAST output only*/
#define SEQNAME_BLAST_STD ((Uint4)262144)
#define DISP_BLAST_STD ((Uint4)524288)
/*display a SeqAlign in a table; require to use DISP_FULL_HTML*/
#define DISPE_TABLE ((Uint4)1048576)
/*BLAST only : if set, display the middle line between query & subject*/
#define DISP_BLAST_MIDLINE ((Uint4)2097152)
/*don't add a hot libk on the acc. number*/
#define DISP_NOLINKONNAME ((Uint4)4194304)
#define DDV_AddBlank(_diff, _fp) \
do { Int4 _i; for (_i=0; _i<(Int4)_diff; _i++) fprintf(_fp," "); } while(0)
#define DDV_AddBlank2(_diff, _str) \
do { Int4 _i; for (_i=0; _i<(Int4)_diff; _i++) *_str=DDV_ConcatStr(*_str," "); } while(0)
/*Entrez and PopSet Viewer scripts*/
#define szEntrezScript "http://www.ncbi.nlm.nih.gov/entrez/utils/qmap.cgi?uid=%d&form=6&db=%s&Dopt=g"
#define szEntrezScriptSMART "http://www.ncbi.nlm.nih.gov/entrez/utils/qmap.cgi?uid=%s&form=6&db=%s&Dopt=g"
#define szSeqNameStatus "<a href=\"%s\" onMouseOut=\"window.status=''\" \nonMouseOver=\"window.status='%s';return true\">"
#define WWWDDV_save_script1 "wwwddv.cgi"
#define WWWDDV_script "wwwddv.cgi?gi=%d&from=%d&to=%d&disp=%u"
#define WWWDDV_script2 "wwwddv.cgi?gis=%s&disp=%u"
NLM_EXTERN void DDV_DeleteTxtList(ValNodePtr PNTR vnp);
NLM_EXTERN void DDV_DeleteParaGList(ValNodePtr PNTR vnp);
NLM_EXTERN void DDV_DeleteDisplayList(MsaParaGPopListPtr mpplp);
NLM_EXTERN void DDV_ResetParaGSeqAlignCoord(MsaParaGPopListPtr mpplp,Int2 LineSize);
NLM_EXTERN CharPtr DDV_GetBLASTCompLine_1(CharPtr szQuery, CharPtr szSubject,
Int4Ptr PNTR matrix, Boolean is_aa);
NLM_EXTERN CharPtr DDV_GetBLASTCompLine_2(ParaGPtr pgpQuery, ParaGPtr pgpSubject,
Int4Ptr PNTR matrix);
NLM_EXTERN CharPtr DDV_GetBLASTCompLine_3(CharPtr szQuery, ParaGPtr pgpSubject,
Int4Ptr PNTR matrix);
NLM_EXTERN void DDV_AffichageParaG(MsaParaGPopListPtr mpplp, BIG_ID gi,Int4 from,Int4 to,
Int4 TotalAliLength,Int4 numBlockAffich,Uint4 disp_format,Int2 LineSize,
FILE *fp,ByteStorePtr PNTR bspp,Int4Ptr PNTR matrix,DDV_ColorGlobal * gclr,
ValNodePtr mask);
NLM_EXTERN Boolean DDV_PopDisplay(SABlockPtr sabp,MsaParaGPopListPtr mpplp,
Int4 nBSP,Uint1 MasterScaleStyle,Boolean ShowTick,
Int2 cbl,Int4 nBlockToPop);
NLM_EXTERN Boolean DDV_PopDisplay2(SABlockPtr sabp,MsaParaGPopListPtr mpplp,
Int4 nBSP,Uint1 MasterScaleStyle,Boolean ShowTick,
Int2 cbl,Int4 nBlockToPop,Int4 ali_from,Int4 ali_to);
NLM_EXTERN Boolean DDV_GetSequenceFromParaG(ParaGPtr pgp,
CharPtr PNTR szSequence,Int4 bspLength,Boolean IsAA,Uint1 PNTR bsp_strand,
Int4 PNTR bsp_start,Int4 PNTR bsp_stop);
NLM_EXTERN Boolean DDV_GetFullFASTAforIdxAli(SeqAlignPtr sap,FILE *fp);
NLM_EXTERN Boolean DDV_GetFullGapFASTAforIdxAli(MsaParaGPopListPtr mpplp,FILE *fp);
NLM_EXTERN void DDV_PrintStudyName(CharPtr szPopSetName,CharPtr szPopSetAuth,
CharPtr szJournalTitle,Int4 pmid,FILE *fp);
NLM_EXTERN void DDV_GetArticleInfo(SeqEntryPtr sep,CharPtr szPopSetName,
CharPtr szPopSetAuth,CharPtr szJournalTitle,Int4Ptr pmid);
NLM_EXTERN Boolean DDV_DisplayDefaultAlign(SeqAlignPtr sap, BIG_ID gi,Int4 from,Int4 to,
Uint4 disp_format,Pointer disp_data,FILE *fp);
NLM_EXTERN CharPtr DDV_ReadSeqGivenSpp(SeqPortPtr spp,Int4 from,Int4 to,Uint1 strand,
Boolean IsAA,BoolPtr bError);
NLM_EXTERN SeqPortPtr DDV_OpenBspFullSeqPort(BioseqPtr bsp,Uint1 strand);
NLM_EXTERN BspInfoPtr DDV_BspInfoNew(Boolean InitInfo,Boolean InitSeqPort,SeqIdPtr sip,
Uint1 strand);
NLM_EXTERN BspInfoPtr DDV_BspInfoDelete(BspInfoPtr bip);
NLM_EXTERN BspInfoPtr DDV_BspInfoDeleteList(BspInfoPtr bip);
NLM_EXTERN void DDV_LocateParaG(ValNodePtr PNTR TableHead,Int4 nBsp);
NLM_EXTERN Boolean DDV_CreateDisplay(SeqAlignPtr sap,MsaParaGPopListPtr mpplp);
NLM_EXTERN Boolean DDV_ShowSeqAlign(SeqAlignPtr seqalign, BIG_ID gi, Int4 from, Int4 to,
Uint4 disp_format);
NLM_EXTERN void DDV_GetEntryBioSource(SeqEntryPtr sep,ValNodePtr PNTR vnpp);
NLM_EXTERN void DDV_PrintPopSetSummary(SeqEntryPtr sep, BIG_ID gi, FILE *FileOut);
NLM_EXTERN void DDV_SearchAli(SeqEntryPtr sep, Pointer mydata, Int4 index, Int2 indent);
NLM_EXTERN void DDV_GetSeqAlign(Pointer dataptr, Uint2 datatype,
ValNodePtr PNTR vnp);
NLM_EXTERN void PrintSeqAlignCallback (SeqEntryPtr sep, Pointer mydata,
Int4 index, Int2 indent);
NLM_EXTERN ByteStorePtr SeqAlignToBS (Uint2 entity);
NLM_EXTERN Int4 DDV_GetBspCoordGivenDispCoord(ParaGPtr pgp, Int4 disp_pos);
NLM_EXTERN Int4 DDV_GetBspCoordGivenDispCoord2(ParaGPtr pgp, Int4 disp_pos, Boolean* pUnAligned);
NLM_EXTERN Int4 DDV_GetBspCoordGivenPgpList(ValNodePtr ParaG_List,Int4 disp_pos);
NLM_EXTERN Int4 DDV_GetDispCoordGivenBspCoord(ValNodePtr vnp_head,Int4 bsp_pos);
NLM_EXTERN DDVRulerDescrPtr DDV_RulerDescrNew(DDVRulerDescrPtr pRulerDescr);
NLM_EXTERN DDVRulerDescrPtr DDV_RulerDescrFree(DDVRulerDescrPtr pRulerDescr);
NLM_EXTERN Int4 DDV_GetFirstDispCoordGivenBspCoordRange(ValNodePtr vnp_head,
Int4 disp_start, Int4 disp_stop);
NLM_EXTERN Int4 DDV_GetLastDispCoordGivenBspCoordRange(ValNodePtr vnp_head,
Int4 disp_start, Int4 disp_stop);
#ifdef __cplusplus
}
#endif
#undef NLM_EXTERN
#ifdef NLM_EXPORT
#define NLM_EXTERN NLM_EXPORT
#else
#define NLM_EXTERN
#endif
#endif /* ndef _PGPPOP_ */
|