This file is indexed.

/usr/share/xcrysden/Tcl/fhiPreset.tcl is in xcrysden-data 1.5.60-1build3.

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
#############################################################################
# Author:                                                                   #
# ------                                                                    #
#  Anton Kokalj                                  Email: Tone.Kokalj@ijs.si  #
#  Department of Physical and Organic Chemistry  Phone: x 386 1 477 3523    #
#  Jozef Stefan Institute                          Fax: x 386 1 477 3811    #
#  Jamova 39, SI-1000 Ljubljana                                             #
#  SLOVENIA                                                                 #
#                                                                           #
# Source: $XCRYSDEN_TOPDIR/Tcl/fhiPreset.tcl                                    #
# ------                                                                    #
# Copyright (c) 1996-2003 by Anton Kokalj                                   #
#############################################################################

proc fhiPreset {type file} {
    global system fhi

    if { $type != "inpini" && $type != "coord" } {
	ErrorDialog "invalid type of fhiPreset !!!"
	return 0
    }
    
    # just for any case
    cd $system(SCRDIR)
    if { $type == "inpini" } {
	##############################
	# execute CONVERTING program #
	##############################
	xcCatchExecReturn $system(BINDIR)/fhi_inpini2ftn34 $file getlist
	#if { [catch {exec $system(BINDIR)/fhi_inpini2ftn34 $file getlist}] } {
	#    ErrorDialog "error while executing \"fhi_inpini2ftn34 $file getlist\" program"
	#    return 0
	#}
    } else {
	# type == coord
	##############################
	# execute CONVERTING program #
	##############################
	xcCatchExecReturn $system(BINDIR)/fhi_coord2xcr $file getlist
	#if { [catch {exec $system(BINDIR)/fhi_coord2xcr $file getlist}] } {
	#    ErrorDialog "error while executing \"fhi_coord2xcr $file getlist\" program"
	#    return 0
	#}
    }
    
    # check if "fhi_species_name.list" was created ?!!
    if { ! [file exists fhi_species_name.list] } {
	ErrorDialog "\"FHIxxMD's\" file is probably bad !!!"
	return 0
    } 

    #
    # pop-up the toplevel with corresponding entries
    #

    set t [xcToplevel [WidgetName] "Atomic Numbers of Species" \
	    "Atomic Numbers" . 0 0 1]

    set f1 [frame $t.1]
    set f2 [frame $t.2]
    pack $f1 $f2 -side top -padx 10 -pady 10 -fill x

    frame $f1.title -class StressText
    label $f1.title.l -text "Specify Atomic Numbers of Species" \
	    -relief groove -bd 2
    $f1.title.l config -font [ModifyFontSize $f1.title.l 18]
    pack $f1.title -side top -expand 1
    pack $f1.title.l -ipadx 10 -ipady 3 -padx 10 -pady 10 -expand 1

    #
    # build up for ScrollEntries
    # 
    set list           [split [ReadFile fhi_species_name.list] \n]
    set fhi(n_species) [lindex $list 0]
    set species_names  [concat [lrange $list 1 end]]
    for {set i 0} {$i < $fhi(n_species)} {incr i} {
	set ii [expr $i + 1]
	set fhi(NAME,$ii) [lindex $species_names $i]
    }
    set labellist  [list "Species:" "Atomic Number:"]    
    set arraylist  [list NAME NAT]
    set arraytype  [list text posint]
    set buttonlist [list 1 \
	    [list {Periodic Table} scroll_ptableSelectNAT $t fhi NAT]]	    

    ScrollEntries \
	    $f1 \
	    $fhi(n_species) \
	    "Set Atomic Number for Species #" \
	    $labellist \
	    $arraylist \
	    $arraytype \
	    15 \
	    fhi \
	    $buttonlist \
	    3

    # OK and cancel button should be cerated as well
    set ok  [button $f2.ok -text OK -command [list fhiPresetOK $t]]    
    set can [button $f2.can -text Cancel -command [list fhiPresetCan $t]]
    pack $ok $can -side left -expand 1 -padx 10

    tkwait window $t

    return $fhi(status)
}
    
#
# maybe the program should found out if OK button was pressed by the
# presence of "fhi_species_nat.list" file !!!
#
proc fhiPresetOK t {
    global varlist foclist fhi system
    
    if ![check_var $varlist $foclist] {return 0}
    #
    # its seems OK; write the "fhi_species_nat.list" file and destroy 
    # the toplevel window
    set out "$fhi(n_species)\n"
    for {set i 1} {$i <= $fhi(n_species)} {incr i} {
	append out "$fhi(NAT,$i) "
    }
    ####################
    # just in any case #
    cd $system(SCRDIR)
    ####################
    WriteFile fhi_species_nat.list $out w

    destroy $t
    set fhi(status) 1
}
	    

proc fhiPresetCan t {
    global fhi system

    ####################
    # just in any case #
    cd $system(SCRDIR)
    ####################
    if { [file exists fhi_species_nat.list] } {
	file delete fhi_species_nat.list
    }
    destroy $t
    set fhi(status) 0
}