Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
K
kicad-source-mirror
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
kicad-source-mirror
Commits
c86a65c9
Commit
c86a65c9
authored
Feb 27, 2011
by
Marco Mattila
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add directory selection to module position and report output in pcbnew.
parent
4ca6c4fb
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
13 deletions
+39
-13
gen_modules_placefile.cpp
pcbnew/gen_modules_placefile.cpp
+39
-13
No files found.
pcbnew/gen_modules_placefile.cpp
View file @
c86a65c9
...
@@ -134,12 +134,19 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -134,12 +134,19 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
return
;
return
;
}
}
wxString
boardFilePath
=
(
(
wxFileName
)
GetScreen
()
->
GetFileName
()).
GetPath
();
wxDirDialog
dirDialog
(
this
,
_
(
"Select Output Directory"
),
boardFilePath
);
if
(
dirDialog
.
ShowModal
()
==
wxID_CANCEL
)
return
;
fnFront
=
GetScreen
()
->
GetFileName
();
fnFront
=
GetScreen
()
->
GetFileName
();
fnFront
.
SetPath
(
dirDialog
.
GetPath
()
);
frontLayerName
=
GetBoard
()
->
GetLayerName
(
LAYER_N_FRONT
);
frontLayerName
=
GetBoard
()
->
GetLayerName
(
LAYER_N_FRONT
);
fnFront
.
SetName
(
fnFront
.
GetName
()
+
frontLayerName
);
fnFront
.
SetName
(
fnFront
.
GetName
()
+
wxT
(
"_"
)
+
frontLayerName
);
fnFront
.
SetExt
(
wxT
(
"pos"
)
);
fnFront
.
SetExt
(
wxT
(
"pos"
)
);
fpFront
=
wxFopen
(
fnFront
.
GetFullPath
(),
wxT
(
"wt"
)
);
fpFront
=
wxFopen
(
fnFront
.
GetFullPath
(),
wxT
(
"wt"
)
);
if
(
fpFront
==
0
)
if
(
fpFront
==
0
)
{
{
msg
=
_
(
"Unable to create "
)
+
fnFront
.
GetFullPath
();
msg
=
_
(
"Unable to create "
)
+
fnFront
.
GetFullPath
();
...
@@ -150,10 +157,10 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -150,10 +157,10 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
if
(
doBoardBack
)
if
(
doBoardBack
)
{
{
fnBack
=
GetScreen
()
->
GetFileName
();
fnBack
=
GetScreen
()
->
GetFileName
();
fnBack
.
SetPath
(
dirDialog
.
GetPath
()
);
backLayerName
=
GetBoard
()
->
GetLayerName
(
LAYER_N_BACK
);
backLayerName
=
GetBoard
()
->
GetLayerName
(
LAYER_N_BACK
);
fnBack
.
SetName
(
fnBack
.
GetName
()
+
backLayerName
);
fnBack
.
SetName
(
fnBack
.
GetName
()
+
wxT
(
"_"
)
+
backLayerName
);
fnBack
.
SetExt
(
wxT
(
"pos"
)
);
fnBack
.
SetExt
(
wxT
(
"pos"
)
);
fpBack
=
wxFopen
(
fnBack
.
GetFullPath
(),
wxT
(
"wt"
)
);
fpBack
=
wxFopen
(
fnBack
.
GetFullPath
(),
wxT
(
"wt"
)
);
if
(
fpBack
==
0
)
if
(
fpBack
==
0
)
...
@@ -169,7 +176,7 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -169,7 +176,7 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
SetLocaleTo_C_standard
(
);
SetLocaleTo_C_standard
(
);
switchedLocale
=
true
;
switchedLocale
=
true
;
/
* Display results */
/
/ Display results
MsgPanel
->
EraseMsgBox
();
MsgPanel
->
EraseMsgBox
();
Affiche_1_Parametre
(
this
,
0
,
_
(
"Component side place file:"
),
Affiche_1_Parametre
(
this
,
0
,
_
(
"Component side place file:"
),
fnFront
.
GetFullPath
(),
BLUE
);
fnFront
.
GetFullPath
(),
BLUE
);
...
@@ -181,7 +188,7 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -181,7 +188,7 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
msg
.
Empty
();
msg
<<
moduleCount
;
msg
.
Empty
();
msg
<<
moduleCount
;
Affiche_1_Parametre
(
this
,
65
,
_
(
"Module count"
),
msg
,
RED
);
Affiche_1_Parametre
(
this
,
65
,
_
(
"Module count"
),
msg
,
RED
);
/
* Sort the list of modules by alphabetical order */
/
/ Sort the list of modules alphabetically
Liste
=
(
LIST_MOD
*
)
MyZMalloc
(
moduleCount
*
sizeof
(
LIST_MOD
)
);
Liste
=
(
LIST_MOD
*
)
MyZMalloc
(
moduleCount
*
sizeof
(
LIST_MOD
)
);
module
=
GetBoard
()
->
m_Modules
;
module
=
GetBoard
()
->
m_Modules
;
...
@@ -201,21 +208,24 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -201,21 +208,24 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
qsort
(
Liste
,
moduleCount
,
sizeof
(
LIST_MOD
),
ListeModCmp
);
qsort
(
Liste
,
moduleCount
,
sizeof
(
LIST_MOD
),
ListeModCmp
);
/
* Generation header file comments. */
/
/ Write file header
sprintf
(
line
,
"### Module positions - created on %s ###
\n
"
,
sprintf
(
line
,
"### Module positions - created on %s ###
\n
"
,
DateAndTime
(
Buff
)
);
DateAndTime
(
Buff
)
);
fputs
(
line
,
fpFront
);
fputs
(
line
,
fpFront
);
if
(
doBoardBack
)
if
(
doBoardBack
)
fputs
(
line
,
fpBack
);
fputs
(
line
,
fpBack
);
Title
=
wxGetApp
().
GetAppName
()
+
wxT
(
" "
)
+
GetBuildVersion
();
Title
=
wxGetApp
().
GetAppName
()
+
wxT
(
" "
)
+
GetBuildVersion
();
sprintf
(
line
,
"### Printed by PcbNew version %s
\n
"
,
CONV_TO_UTF8
(
Title
)
);
sprintf
(
line
,
"### Printed by PcbNew version %s
\n
"
,
CONV_TO_UTF8
(
Title
)
);
fputs
(
line
,
fpFront
);
fputs
(
line
,
fpFront
);
if
(
doBoardBack
)
if
(
doBoardBack
)
fputs
(
line
,
fpBack
);
fputs
(
line
,
fpBack
);
sprintf
(
line
,
"## Unit = inches, Angle = deg.
\n
"
);
sprintf
(
line
,
"## Unit = inches, Angle = deg.
\n
"
);
fputs
(
line
,
fpFront
);
fputs
(
line
,
fpFront
);
if
(
doBoardBack
)
if
(
doBoardBack
)
fputs
(
line
,
fpBack
);
fputs
(
line
,
fpBack
);
...
@@ -270,20 +280,23 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
...
@@ -270,20 +280,23 @@ void WinEDA_PcbFrame::GenModulesPosition( wxCommandEvent& event )
}
}
}
}
/
* Generate EOF. */
/
/ Write EOF
fputs
(
"## End
\n
"
,
fpFront
);
fputs
(
"## End
\n
"
,
fpFront
);
if
(
doBoardBack
)
if
(
doBoardBack
)
fputs
(
"## End
\n
"
,
fpBack
);
fputs
(
"## End
\n
"
,
fpBack
);
msg
=
frontLayerName
+
wxT
(
" File: "
)
+
fnFront
.
GetFullPath
();
msg
=
_
(
"Module position files created:"
);
msg
.
Append
(
wxT
(
"
\n\n
"
)
+
frontLayerName
+
wxT
(
":
\n
"
)
);
msg
.
Append
(
fnFront
.
GetFullPath
()
);
if
(
doBoardBack
)
if
(
doBoardBack
)
msg
+=
wxT
(
"
\n\n
"
)
+
backLayerName
+
wxT
(
" File: "
)
+
{
fnBack
.
GetFullPath
(
);
msg
.
Append
(
wxT
(
"
\n\n
"
)
+
backLayerName
+
wxT
(
":
\n
"
)
);
msg
.
Append
(
fnBack
.
GetFullPath
()
);
DisplayInfoMessage
(
this
,
msg
);
}
wxMessageBox
(
msg
,
_
(
"Module Position File"
),
wxICON_INFORMATION
);
exit
:
// the only safe way out of here, no returns please.
exit
:
// the only safe way out of here, no returns please.
...
@@ -320,10 +333,18 @@ void WinEDA_PcbFrame::GenModuleReport( wxCommandEvent& event )
...
@@ -320,10 +333,18 @@ void WinEDA_PcbFrame::GenModuleReport( wxCommandEvent& event )
File_Place_Offset
=
wxPoint
(
0
,
0
);
File_Place_Offset
=
wxPoint
(
0
,
0
);
wxString
boardFilePath
=
(
(
wxFileName
)
GetScreen
()
->
GetFileName
()).
GetPath
();
wxDirDialog
dirDialog
(
this
,
_
(
"Select Output Directory"
),
boardFilePath
);
if
(
dirDialog
.
ShowModal
()
==
wxID_CANCEL
)
return
;
fn
=
GetScreen
()
->
GetFileName
();
fn
=
GetScreen
()
->
GetFileName
();
fn
.
SetPath
(
dirDialog
.
GetPath
()
);
fn
.
SetExt
(
wxT
(
"rpt"
)
);
fn
.
SetExt
(
wxT
(
"rpt"
)
);
rptfile
=
wxFopen
(
fn
.
GetFullPath
(),
wxT
(
"wt"
)
);
rptfile
=
wxFopen
(
fn
.
GetFullPath
(),
wxT
(
"wt"
)
);
if
(
rptfile
==
NULL
)
if
(
rptfile
==
NULL
)
{
{
msg
=
_
(
"Unable to create "
)
+
fn
.
GetFullPath
();
msg
=
_
(
"Unable to create "
)
+
fn
.
GetFullPath
();
...
@@ -467,6 +488,11 @@ void WinEDA_PcbFrame::GenModuleReport( wxCommandEvent& event )
...
@@ -467,6 +488,11 @@ void WinEDA_PcbFrame::GenModuleReport( wxCommandEvent& event )
fputs
(
"$EndDESCRIPTION
\n
"
,
rptfile
);
fputs
(
"$EndDESCRIPTION
\n
"
,
rptfile
);
fclose
(
rptfile
);
fclose
(
rptfile
);
SetLocaleTo_Default
(
);
// revert to the current locale
SetLocaleTo_Default
(
);
// revert to the current locale
msg
=
_
(
"Module report file created:"
);
msg
.
Append
(
wxT
(
"
\n
"
)
+
fn
.
GetFullPath
()
);
wxMessageBox
(
msg
,
_
(
"Module Report"
),
wxICON_INFORMATION
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment